Merge "Remove --include-header and --include-footer parameter"
This commit is contained in:
commit
044a6afffc
@ -145,21 +145,14 @@ the best use of the docker cache.
|
||||
type = local
|
||||
location = /tmp/ironic.tar.gz
|
||||
|
||||
To build RHEL containers, it is necessary to use the ``-i`` (include header)
|
||||
feature to include registration with RHN of the container runtime operating
|
||||
system. To obtain a RHN username/password/pool id, contact Red Hat.
|
||||
|
||||
First create a file called ``rhel-include``:
|
||||
|
||||
::
|
||||
To build RHEL containers, it is necessary to include registration with RHN
|
||||
of the container runtime operating system. To obtain a RHN
|
||||
username/password/pool id, contact Red Hat. Use a template's header block
|
||||
overrides file, add the following::
|
||||
|
||||
RUN subscription-manager register --user=<user-name> --password=<password> \
|
||||
&& subscription-manager attach --pool <pool-id>
|
||||
|
||||
Then build RHEL containers::
|
||||
|
||||
kolla-build -b rhel -i ./rhel-include
|
||||
|
||||
Dockerfile Customisation
|
||||
========================
|
||||
|
||||
@ -371,32 +364,22 @@ insecure registry. See
|
||||
Building behind a proxy
|
||||
-----------------------
|
||||
|
||||
The build script supports augmenting the Dockerfiles under build via so called
|
||||
`header` and `footer` files. Statements in the `header` file are included at
|
||||
the top of the `base` image, while those in `footer` are included at the bottom
|
||||
of every Dockerfile in the build.
|
||||
|
||||
A common use case for this is to insert http_proxy settings into the images to
|
||||
We can insert http_proxy settings into the images to
|
||||
fetch packages during build, and then unset them at the end to avoid having
|
||||
them carry through to the environment of the final images. Note however, it's
|
||||
not possible to drop the info completely using this method; it will still be
|
||||
visible in the layers of the image.
|
||||
|
||||
To use this feature, create a file called ``.header``, with the following
|
||||
content for example::
|
||||
To set the proxy settings, we can add this to the template's header block::
|
||||
|
||||
ENV http_proxy=https://evil.corp.proxy:80
|
||||
ENV https_proxy=https://evil.corp.proxy:80
|
||||
|
||||
Then create another file called ``.footer``, with the following content::
|
||||
To unset the proxy settings, we can add this to the template's footer block::
|
||||
|
||||
ENV http_proxy=""
|
||||
ENV https_proxy=""
|
||||
|
||||
Finally, pass them to the build script using the ``-i`` and ``-I`` flags::
|
||||
|
||||
kolla-build -i .header -I .footer
|
||||
|
||||
Besides this configuration options, the script will automatically read these
|
||||
environment variables. If the host system proxy parameters match the ones
|
||||
going to be used, no other input parameters will be needed. These are the
|
||||
|
@ -76,18 +76,6 @@ _CLI_OPTS = [
|
||||
help='Turn on debugging log level'),
|
||||
cfg.DictOpt('build-args',
|
||||
help='Set docker build time variables'),
|
||||
cfg.StrOpt('include-header', short='i',
|
||||
deprecated_for_removal=True,
|
||||
deprecated_reason=('Use a header block within a template'
|
||||
' overrides file instead'),
|
||||
help=('Path to custom file to be added at '
|
||||
'beginning of base Dockerfile')),
|
||||
cfg.StrOpt('include-footer', short='I',
|
||||
deprecated_for_removal=True,
|
||||
deprecated_reason=('Use a footer block within a template'
|
||||
' overrides file instead'),
|
||||
help=('Path to custom file to be added at '
|
||||
'end of Dockerfiles for final images')),
|
||||
cfg.BoolOpt('keep', default=False,
|
||||
help='Keep failed intermediate containers'),
|
||||
cfg.BoolOpt('list-dependencies', short='l',
|
||||
|
8
kolla/image/build.py
Normal file → Executable file
8
kolla/image/build.py
Normal file → Executable file
@ -526,8 +526,6 @@ class KollaWorker(object):
|
||||
|
||||
self.image_prefix = self.base + '-' + self.install_type + '-'
|
||||
|
||||
self.include_header = conf.include_header
|
||||
self.include_footer = conf.include_footer
|
||||
self.regex = conf.regex
|
||||
self.image_statuses_bad = dict()
|
||||
self.image_statuses_good = dict()
|
||||
@ -669,12 +667,6 @@ class KollaWorker(object):
|
||||
env.filters.update(self._get_filters())
|
||||
env.globals.update(self._get_methods())
|
||||
template = env.get_template(template_name)
|
||||
if self.include_header:
|
||||
with open(self.include_header, 'r') as f:
|
||||
values['include_header'] = f.read()
|
||||
if self.include_footer:
|
||||
with open(self.include_footer, 'r') as f:
|
||||
values['include_footer'] = f.read()
|
||||
content = template.render(values)
|
||||
content_path = os.path.join(path, 'Dockerfile')
|
||||
with open(content_path, 'w') as f:
|
||||
|
@ -0,0 +1,6 @@
|
||||
---
|
||||
upgrade:
|
||||
- The --include-header and --include-footer parameters were deprecated
|
||||
as of the Newton release. They should be move use header and footer
|
||||
block in template overrides file. The two parameters are removed in
|
||||
the Ocata-release.
|
Loading…
x
Reference in New Issue
Block a user