起因:公司網絡接口做了接口認證,虛擬機橋接至物理網卡無法完成認證進行網絡訪問,無奈之下只能講虛擬機網絡模式更改為NAT模式,更改完成之后進行ssh登錄,發現主機名發生了變化。
更改NAT模式之前
[root@localhost ~]#
[root@localhost ~]#
[root@localhost ~]#
更改為NAT模式之后
[root@bogon ~]#
[root@bogon ~]#
發現主機名變成了bogon,很氣,看着很不順眼,想辦法更改回來。
查看幾個相關文件
[root@localhost ~]# vi /etc/sysconfig/network
NETWORKING=yes
HOSTNAME=localhost.localdomain
[root@localhost ~]# vi /etc/hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
network和hosts中的主機名都正常,都是localhost
[root@bogon ~]# hostname
bogon
直接使用hostname發現還是返回了bogon,並不是文件中的localhost,查看dns文件
[root@localhost ~]# cat /etc/resolv.conf
; generated by /sbin/dhclient-script
search localdomain
nameserver 192.168.13.2
發現多了一行search localdomain,應該是這行配置導致的問題,resolv.conf中的配置是由vmware 8網卡自動下發的,所以更改此處配置無用,准備曲線救國
這塊的配置說明是要在加載配置文件后,對該主機的IP地址進行解析,返回的domain域名作為主機名回顯至命令行,嘗試解析本機IP
[root@localhost ~]# nslookup 192.168.13.128
Server: 192.168.13.2
Address: 192.168.13.2#53
Non-authoritative answer:
128.13.168.192.in-addr.arpa name = bogon.
Authoritative answers can be found from:
[root@localhost ~]#
果然本機的IP地址被解析為了bogon,那么說明一個問題就是,如果resolv.conf中配置了search localdomain,那么此處得到的主機名則優先於hosts和network文件中的配置
要解決這個問題,最簡單的方案就是讓其解析時不經過dns,使用hosts文件,直接將本機的IP地址解析為localhost即可
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.13.128 localhost
重啟服務器,登錄后查看主機名恢復正常。