Skip to content

Commit

Permalink
Merge pull request #2254 from Caustic/fix-hostname-debian
Browse files Browse the repository at this point in the history
guests/debian,ubuntu: Fixed fqdn handling
  • Loading branch information
mitchellh committed Sep 25, 2013
2 parents e77ca40 + 7d53047 commit d970c4e
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 5 deletions.
23 changes: 21 additions & 2 deletions plugins/guests/debian/cap/change_host_name.rb
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,28 @@ module Cap
class ChangeHostName
def self.change_host_name(machine, name)
machine.communicate.tap do |comm|
if !comm.test("hostname --fqdn | grep '^#{name}$' || hostname --short | grep '^#{name}$'")
comm.sudo("sed -r -i 's/^(127[.]0[.]1[.]1[[:space:]]+).*$/\\1#{name} #{name.split('.')[0]}/' /etc/hosts")

# Get the current hostname
# if existing fqdn setup improperly, this returns just hostname
old = ''
comm.sudo "hostname -f" do |type, data|
if type == :stdout
old = data.chomp
end
end

# this works even if they're not both fqdn
if old.split('.')[0] != name.split('.')[0]

comm.sudo("sed -i 's/.*$/#{name.split('.')[0]}/' /etc/hostname")

# hosts should resemble:
# 127.0.1.1 host.fqdn.com host
# First to set fqdn
comm.sudo("sed -i 's@#{old}@#{name}@' /etc/hosts")
# Second to set hostname
comm.sudo("sed -i 's@#{old.split('.')[0]}@#{name.split('.')[0]}@' /etc/hosts")

comm.sudo("hostname -F /etc/hostname")
comm.sudo("hostname --fqdn > /etc/mailname")
comm.sudo("ifdown -a; ifup -a; ifup eth0")
Expand Down
25 changes: 22 additions & 3 deletions plugins/guests/ubuntu/cap/change_host_name.rb
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,28 @@ module Cap
class ChangeHostName
def self.change_host_name(machine, name)
machine.communicate.tap do |comm|
if !comm.test("sudo hostname | grep '^#{name}$'")
comm.sudo("sed -i 's/.*$/#{name}/' /etc/hostname")
comm.sudo("sed -i 's@^\\(127[.]0[.]1[.]1[[:space:]]\\+\\)@\\1#{name} #{name.split('.')[0]} @' /etc/hosts")

# Get the current hostname
# if existing fqdn setup improperly, this returns just hostname
old = ''
comm.sudo "hostname -f" do |type, data|
if type == :stdout
old = data.chomp
end
end

# this works even if they're not both fqdn
if old.split('.')[0] != name.split('.')[0]

comm.sudo("sed -i 's/.*$/#{name.split('.')[0]}/' /etc/hostname")

# hosts should resemble:
# 127.0.1.1 host.fqdn.com host
# First to set fqdn
comm.sudo("sed -i 's@#{old}@#{name}@' /etc/hosts")
# Second to set hostname
comm.sudo("sed -i 's@#{old.split('.')[0]}@#{name.split('.')[0]}@' /etc/hosts")

if comm.test("[ `lsb_release -c -s` = hardy ]")
# hostname.sh returns 1, so I grep for the right name in /etc/hostname just to have a 0 exitcode
comm.sudo("/etc/init.d/hostname.sh start; grep '#{name}' /etc/hostname")
Expand Down

0 comments on commit d970c4e

Please sign in to comment.