improve the updating of /etc/hosts with correct fqdn when possible
Thanks to Adam Gandalman and Marc Cluet for this fix.
This commit is contained in:
parent
42624e5604
commit
370ee8f4b9
@ -17,17 +17,36 @@
|
|||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
import cloudinit.util as util
|
import cloudinit.util as util
|
||||||
from cloudinit.CloudConfig import per_always
|
from cloudinit.CloudConfig import per_always
|
||||||
import platform
|
|
||||||
import StringIO
|
import StringIO
|
||||||
|
|
||||||
frequency = per_always
|
frequency = per_always
|
||||||
|
|
||||||
def handle(name,cfg,cloud,log,args):
|
def handle(name,cfg,cloud,log,args):
|
||||||
if not util.get_cfg_option_bool(cfg,"manage_etc_hosts",False):
|
hostname = util.get_cfg_option_str(cfg,"hostname",cloud.get_hostname())
|
||||||
|
fqdn = util.get_cfg_option_str(cfg,"fqdn",cloud.get_hostname(fqdn=True))
|
||||||
|
|
||||||
|
if util.get_cfg_option_bool(cfg,"manage_etc_hosts", True):
|
||||||
|
# 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")
|
log.debug("manage_etc_hosts is not set, checking sanity of /etc/hosts")
|
||||||
|
update_etc_hosts(hostname, fqdn, log)
|
||||||
|
return
|
||||||
|
|
||||||
|
# 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:
|
with open('/etc/hosts', 'r') as etchosts:
|
||||||
current_hostname = platform.node()
|
hosts_line = "# Added by cloud-init\n127.0.1.1\t%s %s\n" % (fqdn, hostname)
|
||||||
hosts_line = "# Added by cloud-init\n127.0.1.1\t%s.localdomain %s\n" % (current_hostname, current_hostname)
|
|
||||||
need_write = False
|
need_write = False
|
||||||
need_change = True
|
need_change = True
|
||||||
new_etchosts = StringIO.StringIO()
|
new_etchosts = StringIO.StringIO()
|
||||||
@ -36,10 +55,9 @@ def handle(name,cfg,cloud,log,args):
|
|||||||
# skip over malformed /etc/hosts entries
|
# skip over malformed /etc/hosts entries
|
||||||
if len(split_line) < 2:
|
if len(split_line) < 2:
|
||||||
continue
|
continue
|
||||||
ip, hostnames = split_line[0], split_line[1:]
|
ip, hosts = split_line[0], split_line[1:]
|
||||||
if ip == "127.0.1.1":
|
if ip == "127.0.1.1":
|
||||||
for hostname in hostnames:
|
if sorted([hostname, fqdn]) == sorted(hosts):
|
||||||
if hostname == current_hostname:
|
|
||||||
need_change = False
|
need_change = False
|
||||||
if need_change == True:
|
if need_change == True:
|
||||||
line = hosts_line
|
line = hosts_line
|
||||||
@ -56,18 +74,3 @@ def handle(name,cfg,cloud,log,args):
|
|||||||
new_etcfile.close()
|
new_etcfile.close()
|
||||||
new_etchosts.close()
|
new_etchosts.close()
|
||||||
return
|
return
|
||||||
|
|
||||||
try:
|
|
||||||
hostname = util.get_cfg_option_str(cfg,"hostname",cloud.get_hostname())
|
|
||||||
if not hostname:
|
|
||||||
hostname = cloud.get_hostname()
|
|
||||||
|
|
||||||
if not hostname:
|
|
||||||
log.info("manage_etc_hosts was set, but no hostname found")
|
|
||||||
return
|
|
||||||
|
|
||||||
util.render_to_file('hosts', '/etc/hosts', { 'hostname' : hostname })
|
|
||||||
|
|
||||||
except Exception as e:
|
|
||||||
log.warn("failed to update /etc/hosts")
|
|
||||||
raise
|
|
||||||
|
@ -22,6 +22,7 @@ DEP_NETWORK = "NETWORK"
|
|||||||
|
|
||||||
import UserDataHandler as ud
|
import UserDataHandler as ud
|
||||||
import cloudinit.util as util
|
import cloudinit.util as util
|
||||||
|
import platform
|
||||||
|
|
||||||
class DataSource:
|
class DataSource:
|
||||||
userdata = None
|
userdata = None
|
||||||
@ -96,20 +97,33 @@ class DataSource:
|
|||||||
return "ubuntuhost"
|
return "ubuntuhost"
|
||||||
return(self.metadata['instance-id'])
|
return(self.metadata['instance-id'])
|
||||||
|
|
||||||
def get_hostname(self):
|
def get_hostname(self, fqdn=False):
|
||||||
|
domain = "localdomain"
|
||||||
if not 'local-hostname' in self.metadata:
|
if not 'local-hostname' in self.metadata:
|
||||||
return None
|
toks = [ platform.node(), domain ]
|
||||||
|
else:
|
||||||
toks = self.metadata['local-hostname'].split('.')
|
toks = self.metadata['local-hostname'].split('.')
|
||||||
|
|
||||||
# if there is an ipv4 address in 'local-hostname', then
|
# if there is an ipv4 address in 'local-hostname', then
|
||||||
# make up a hostname (LP: #475354)
|
# make up a hostname (LP: #475354)
|
||||||
if len(toks) == 4:
|
if len(toks) == 4:
|
||||||
try:
|
try:
|
||||||
r = filter(lambda x: int(x) < 256 and x > 0, toks)
|
r = filter(lambda x: int(x) < 256 and x > 0, toks)
|
||||||
if len(r) == 4:
|
if len(r) == 4:
|
||||||
return("ip-%s" % '-'.join(r))
|
toks = [ "ip-%s" % '-'.join(r) ]
|
||||||
except: pass
|
except:
|
||||||
return toks[0]
|
pass
|
||||||
|
|
||||||
|
if len(toks) > 1:
|
||||||
|
hostname = toks[0]
|
||||||
|
domain = '.'.join(toks[1:])
|
||||||
|
else:
|
||||||
|
hostname = toks[0]
|
||||||
|
|
||||||
|
if fqdn:
|
||||||
|
return "%s.%s" % (hostname,domain)
|
||||||
|
else:
|
||||||
|
return hostname
|
||||||
|
|
||||||
# return a list of classes that have the same depends as 'depends'
|
# return a list of classes that have the same depends as 'depends'
|
||||||
# iterate through cfg_list, loading "DataSourceCollections" modules
|
# iterate through cfg_list, loading "DataSourceCollections" modules
|
||||||
|
@ -452,8 +452,8 @@ class CloudInit:
|
|||||||
def get_mirror(self):
|
def get_mirror(self):
|
||||||
return(self.datasource.get_local_mirror())
|
return(self.datasource.get_local_mirror())
|
||||||
|
|
||||||
def get_hostname(self):
|
def get_hostname(self, fqdn=False):
|
||||||
return(self.datasource.get_hostname())
|
return(self.datasource.get_hostname(fqdn=fqdn))
|
||||||
|
|
||||||
def device_name_to_device(self,name):
|
def device_name_to_device(self,name):
|
||||||
return(self.datasource.device_name_to_device(name))
|
return(self.datasource.device_name_to_device(name))
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
# /etc/cloud/cloud.cfg or cloud-config from user-data
|
# /etc/cloud/cloud.cfg or cloud-config from user-data
|
||||||
#
|
#
|
||||||
## The value '$hostname' will be replaced with the local-hostname
|
## The value '$hostname' will be replaced with the local-hostname
|
||||||
127.0.1.1 $hostname
|
127.0.1.1 $fqdn $hostname
|
||||||
127.0.0.1 localhost
|
127.0.0.1 localhost
|
||||||
|
|
||||||
# The following lines are desirable for IPv6 capable hosts
|
# The following lines are desirable for IPv6 capable hosts
|
||||||
|
Loading…
x
Reference in New Issue
Block a user