B003 hostname與hosts的關係

很過人一提到更改hostname首先就想到修改/etc/hosts文件,認爲hostname的配置文件就是/etc/hosts。其實不是的。

hosts文件的作用相當如DNS,提供IP地址到hostname的對應。早期的互聯網計算機少,單機hosts文件裏足夠存放所有聯網計算機。不過隨着互聯網的發展,這就遠遠不夠了。於是就出現了分佈式的DNS系統。由DNS服務器來提供類似的IP地址到域名的對應。具體可以man hosts。

Linux系統在向DNS服務器發出域名解析請求之前會查詢/etc/hosts文件,如果裏面有相應的記錄,就會使用hosts裏面的記錄。/etc/hosts文件通常裏面包含這一條記錄

127.0.0.1 localhost.localdomain localhost

hosts文件格式是一行一條記錄,分別是IP地址 hostname aliases,三者用空白字符分隔,aliases可選。

127.0.0.1到localhost這一條建議不要修改,因爲很多應用程序會用到這個,比如sendmail,修改之後這些程序可能就無法正常運行。

修改hostname後,如果想要在本機上用newhostname來訪問,就必須在/etc/hosts文件裏添加一條newhostname的記錄。比如我的eth0的IP是192.168.1.61,我將hosts文件修改如下:

#hostname blog.infernor.net

# cat /etc/hosts

127.0.0.1 localhost.localdomain localhost

192.168.1.61 blog.infernor.net blog

這樣,我就可以通過blog或者blog.infernor.net來訪問本機。

從上面這些來看,/etc/hosts於設置hostname是沒直接關係的,僅僅當你要在本機上用新的hostname來訪問自己的時候纔會用到/etc/hosts文件。兩者沒有必然的聯繫。

 

RHEL還有個問題。

只修改/etc/hosts,裏面添加 192.168.1.61 blog.infernor.net blog,而/etc/sysconfig/network維持原狀,也就是裏面的HOSTNAME=localhost.localdomain。我重啓系統後居然發現hostname給修改成了blog.infernor.net。這樣看的話,倒真覺得/etc/hosts是hostname的配置文件。後來終於在/etc/rc.d/rc.sysinit這個啓動腳本里發現了問題的所在。

 

rc.sysinit文件裏一開始就設置了hostname

if [ -f /etc/sysconfig/network ]; then

. /etc/sysconfig/network

fi

if [ -z "$HOSTNAME" -o "$HOSTNAME" = "(none)" ]; then

HOSTNAME=localhost

fi

確實使用了/etc/sysconfig/network裏的hostname值。不過後面還有一段關於設置hostname的

ipaddr=

if [ "$HOSTNAME" = "localhost" -o "$HOSTNAME" = "localhost.localdomain" ]

; then

ipaddr=$(ip addr show to 0/0 scope global | awk '/[[:space:]]inet

/ { print gensub("/.*","","g",$2) }')

if [ -n "$ipaddr" ]; then

eval $(ipcalc -h $ipaddr 2>/dev/null)

hostname ${HOSTNAME}

fi

fi

腳本判斷hostname是否爲localhost或者localhost.localdomain,如果是的話,將會使用接口IP地址對應的 hostname來重新設置系統的hostname。問題就出在這裏,我的/etc/sysconfig/network默認的hostname是 localhost.localdomain,eth0的IP是192.168.1.61,而/etc/hosts裏有192.168.1.61的記錄。於是就用192.168.1.61這條記錄來替換了hostname。

估計這也是很多人將/etc/hosts誤以爲是hostname的配置文件的原因。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章