diff options
author | Scott Moser <smoser@ubuntu.com> | 2011-12-19 22:48:36 -0500 |
---|---|---|
committer | Scott Moser <smoser@ubuntu.com> | 2011-12-19 22:48:36 -0500 |
commit | bf26b04812edd6c6feaf58723bea95c22fb9a9f7 (patch) | |
tree | c5ecdec26215125cd28945a54dcc5f7f01845a91 | |
parent | 4ee421211816b9f40e09585137b42a8fcec42218 (diff) | |
parent | e75dc94a288ecec8f6096658b96c1d1154ce0bdd (diff) | |
download | vyos-cloud-init-bf26b04812edd6c6feaf58723bea95c22fb9a9f7.tar.gz vyos-cloud-init-bf26b04812edd6c6feaf58723bea95c22fb9a9f7.zip |
revert default handling of /etc/hosts to 0.6.1 style (Ubuntu 11.04)
The default management of /etc/hosts in 0.6.2 (Ubuntu 11.10)
was problematic for a couple different uses, and represented a change
in what was present in previous releases.
This changes the default behavior back to the way it was in 11.04/0.6.1.
It makes 'manage_etc_hosts' in cloud-config more than just a boolean.
It can now have 3 values:
* False (default): do not update /etc/hosts ever
* "localhost": manage /etc/hosts' 127.0.1.1 entry (the way it was done
in 11.10/0.6.2)
* True (or "template"): manage /etc/hosts via template file
This addresses bugs
* LP: #890501
* LP: #871966
LP: #890501, #871966
-rw-r--r-- | ChangeLog | 1 | ||||
-rw-r--r-- | cloudinit/CloudConfig/cc_update_etc_hosts.py | 36 | ||||
-rw-r--r-- | doc/examples/cloud-config.txt | 106 |
3 files changed, 90 insertions, 53 deletions
@@ -9,6 +9,7 @@ - DataSourceEc2: more resilliant to slow metadata service - config change: 'retries' dropped, 'max_wait' added, timeout increased - close stdin in all cloud-init programs that are launched at boot (LP: #903993) + - revert management of /etc/hosts to 0.6.1 style (LP: #890501, LP: #871966) 0.6.2: - fix bug where update was not done unless update was explicitly set. It would not be run if 'upgrade' or packages were set to be installed diff --git a/cloudinit/CloudConfig/cc_update_etc_hosts.py b/cloudinit/CloudConfig/cc_update_etc_hosts.py index 6012b8a3..1dc9c1e9 100644 --- a/cloudinit/CloudConfig/cc_update_etc_hosts.py +++ b/cloudinit/CloudConfig/cc_update_etc_hosts.py @@ -24,25 +24,29 @@ frequency = per_always def handle(name,cfg,cloud,log,args): ( hostname, fqdn ) = util.get_hostname_fqdn(cfg, cloud) - use_template = util.get_cfg_option_bool(cfg,"manage_etc_hosts", False) - if not use_template: - # manage_etc_hosts not true, update the 127.0.1.1 entry via update_etc_hosts - log.debug("manage_etc_hosts is not set, checking sanity of /etc/hosts") + manage_hosts = util.get_cfg_option_bool(cfg,"manage_etc_hosts", False) + if manage_hosts in ("True", "true", True, "template"): + # render from template file + try: + if not hostname: + log.info("manage_etc_hosts was set, but no hostname found") + return + + util.render_to_file('hosts', '/etc/hosts', \ + { 'hostname' : hostname, 'fqdn' : fqdn }) + except Exception as e: + log.warn("failed to update /etc/hosts") + raise + elif manage_hosts == "localhost": + log.debug("managing 127.0.1.1 in /etc/hosts") update_etc_hosts(hostname, fqdn, log) return + else: + if manage_hosts not in ("False", False): + log.warn("Unknown value for manage_etc_hosts. Assuming False") + else: + log.debug("not managing /etc/hosts") - # manage_etc_hosts is set, render from template file - try: - if not hostname: - log.info("manage_etc_hosts was set, but no hostname found") - return - - util.render_to_file('hosts', '/etc/hosts', \ - { 'hostname' : hostname, 'fqdn' : fqdn }) - - except Exception as e: - log.warn("failed to update /etc/hosts") - raise def update_etc_hosts(hostname, fqdn, log): with open('/etc/hosts', 'r') as etchosts: diff --git a/doc/examples/cloud-config.txt b/doc/examples/cloud-config.txt index e73b8743..3c9e4b2e 100644 --- a/doc/examples/cloud-config.txt +++ b/doc/examples/cloud-config.txt @@ -341,48 +341,80 @@ rsyslog: resize_rootfs: True ## hostname and /etc/hosts management -# cloud-init will do its best to set up a sane hostname and corresponding -# entries in /etc/hosts. -# -# if you do nothing, you should get the system generally correctly -# configured. -# * /etc/hostname (and thus `hostname` output) set with hostname (not fqdn) -# * an entry in /etc/hosts for both hostname and fqdn -# that are obtained from the metadata service -# * On each boot, the above will again be set -# * cloud-init generally "owns" the 127.0.1.1 entry. The -# rest of the file will not be modified +# cloud-init can handle updating some entries in /etc/hosts, +# and can set your hostname for you. +# +# if you do nothing you'll end up with: +# * /etc/hostname (and `hostname`) managed via: 'preserve_hostame: false' +# if you do not change /etc/hostname, it will be updated with the cloud +# provided hostname on each boot. If you make a change, then manual +# maintenance takes over, and cloud-init will not modify it. +# +# * /etc/hosts managed via: 'manage_etc_hosts: false' +# cloud-init will not manage /etc/hosts at all. It is in full manual +# maintenance mode. # # You can change the above behavior with the following config variables: # Remember that these can be set in cloud-config via user-data, # /etc/cloud/cloud.cfg or any file in /etc/cloud/cloud.cfg.d/ # -# hostname: -# this option will be used wherever the 'hostname' is needed -# simply substitute it in the description above. -# ** If you wish to set your hostname, set it here ** -# default: 'hostname' as returned by the metadata service -# on EC2, the hostname portion of 'local-hostname' is used -# which is something like 'ip-10-244-170-199' -# -# fqdn: -# this option will be used wherever 'fqdn' is needed. -# simply substitue it in the description above. -# default: fqdn as returned by the metadata service. on EC2 'hostname' -# is used, so this is like: ip-10-244-170-199.ec2.internal -# -# manage_etc_hosts: -# default: false -# Setting this config variable to 'true' will mean that on every -# boot, /etc/hosts will be re-written from /etc/cloud/templates/hosts.tmpl -# The strings '$hostname' and '$fqdn' are replaced in the template -# with the appropriate values. -# -# preserve_hostname: -# default: False -# If this option is set to True, then /etc/hostname will never updated -# The default behavior is to update it if it has not been modified by -# the user. +# == Hostname management (via /etc/hostname) == +# * preserve_hostname: +# default: False +# If this option is set to True, then /etc/hostname will never updated +# The default behavior is to update it if it has not been modified by +# the user. +# +# * hostname: +# this option will be used wherever the 'hostname' is needed +# simply substitute it in the description above. +# ** If you wish to set your hostname, set it here ** +# default: 'hostname' as returned by the metadata service +# on EC2, the hostname portion of 'local-hostname' is used +# which is something like 'ip-10-244-170-199' +# +# * fqdn: +# this option will be used wherever 'fqdn' is needed. +# simply substitue it in the description above. +# default: fqdn as returned by the metadata service. on EC2 'hostname' +# is used, so this is like: ip-10-244-170-199.ec2.internal +# +# == /etc/hosts management == +# +# The cloud-config variable that covers management of /etc/hosts is +# 'manage_etc_hosts' +# +# By default, its value is 'false' (boolean False) +# +# * manage_etc_hosts: +# default: false +# +# false: +# cloud-init will not modify /etc/hosts at all. +# * Whatever is present at instance boot time will be present after boot. +# * User changes will not be overwritten +# +# true or 'template': +# on every boot, /etc/hosts will be re-written from +# /etc/cloud/templates/hosts.tmpl. +# The strings '$hostname' and '$fqdn' are replaced in the template +# with the appropriate values. +# To make modifications persistant across a reboot, you must make +# modificatoins to /etc/cloud/templates/hosts.tmpl +# +# localhost: +# This option ensures that an entry is present for fqdn as described in +# section 5.1.2 of the debian manual +# http://www.debian.org/doc/manuals/debian-reference/ch05.en.html +# +# cloud-init will generally own the 127.0.1.1 entry, and will update +# it to the hostname and fqdn on every boot. All other entries will +# be left as is. 'ping `hostname`' will ping 127.0.1.1 +# +# If you want a fqdn entry with aliases other than 'hostname' to resolve +# to a localhost interface, you'll need to use something other than +# 127.0.1.1. For example: +# 127.0.1.2 myhost.fqdn.example.com myhost whatup.example.com # final_message # default: cloud-init boot finished at $TIMESTAMP. Up $UPTIME seconds |