深入理解Linux下修改hostname的幾個(gè)問題
當(dāng)我覺得對(duì)Linux系統(tǒng)下修改hostname已經(jīng)非常熟悉的時(shí)候,今天碰到了幾個(gè)問題,這幾個(gè)問題給我好好上了一課,很多知識(shí)點(diǎn),當(dāng)你覺得你已經(jīng)掌握的時(shí)候,其實(shí)你了解的還只是皮毛。技術(shù)活,切勿淺嘗則止!
實(shí)驗(yàn)環(huán)境:Red Hat Enterprise Linux Server release 5.7 (Tikanga) ,其它版本Linux可能有所不同。請(qǐng)以實(shí)際環(huán)境為準(zhǔn)。
其實(shí)我多次修改過(guò)hostname,一般只需要修改 /etc/hosts 和 /etc/sysconfig/network 兩個(gè)文件下相關(guān)配置即可。但是,今天我遇到了兩個(gè)問題:
問題1:為什么/etc/sysconfig/network配置文件中HOSTNAME為localhost.localdomain,但是顯示的hostname為po132345806-a,那到底hostname的配置值放在哪里?
- 11: [root@po132345806-a ~]# more /etc/hosts
- 2: # Do not remove the following line, or various programs
- 3: # that require network functionality will fail.
- 4: 127.0.0.1 localhost.localdomain localhost
- 5: ::1 localhost6.localdomain6 localhost6
- 6: [root@po132345806-a ~]# more /etc/sysconfig/network
- 7: NETWORKING=yes
- 8: NETWORKING_IPV6=yes
- 9: HOSTNAME=localhost.localdomain
有圖有真相,免得大家不相信這個(gè)現(xiàn)象,當(dāng)我第一次碰到這種特殊情況時(shí),我也非常納悶。Google了一些資料加上自己的實(shí)踐才弄明白?! ?/p>
問題2: 修改了hostname后,如何使其立即生效而不用重啟操作系統(tǒng)。
問題3: 修改hostname有幾種方式?
問題4: hostname跟/etc/hosts 下配置有關(guān)系嗎?
問題5: 如何查看hostname的值,以那個(gè)為準(zhǔn)?
問題1解答:我一直以為hostname的值配置在/etc/sysconfig/network中,這個(gè)文件里面HOSTNAME配置為啥,hostname值就是啥。但是為什么出現(xiàn)上面那種情況呢?
難道/etc/sysconfig/network不是hostname的配置文件,難道還另有其它配置文件?于是我當(dāng)時(shí)實(shí)驗(yàn)了一下修改了/etc/sysconfig/network文件中HOSTNAME為DB-Server,發(fā)現(xiàn)hostname的值依然沒有變化,于是重啟了計(jì)算機(jī)。
- 1: "/etc/sysconfig/network" 3L, 66C written
- 2: 132345806-a ~]# hostname
- 3: 806-a.gfg1.esquel.com
- 4: 132345806-a ~]# more /proc/sys/kernel/hostname
- 5: 806-a.gfg1.esquel.com
- 6: 132345806-a ~]# sysctl kernel.hostname
- 7: ostname = po132345806-a.gfg1.esquel.com
- 8: 132345806-a ~]#
- 9: 132345806-a ~]# reboot
重啟過(guò)后發(fā)現(xiàn)居然hostname變?yōu)镈B-Server了,也就是說(shuō)修改配置文件/etc/sysconfig/network下的HOSTNAME生效了。那么也就是說(shuō)應(yīng)該是有人修改過(guò) kernel.hostname,請(qǐng)看下面實(shí)驗(yàn)。
- 1: [root@DB-Server ~]# more /etc/sysconfig/network
- 2:
- 3: NETWORKING=yes
- 4:
- 5: NETWORKING_IPV6=yes
- 6:
- 7: HOSTNAME=DB-Server.localdomain
- 8:
- 9: [root@DB-Server ~]# echo Test > /proc/sys/kernel/hostname
- 10:
- 11: [root@DB-Server ~]# more /etc/proc/sys/kernel/hostname
- 12:
- 13: /etc/proc/sys/kernel/hostname: No such file or directory
- 14:
- 15: [root@DB-Server ~]# more /proc/sys/kernel/hostname
- 16:
- 17: Test
- 18:
- 19: [root@DB-Server ~]# /etc/init.d/network restart
- 20:
- 21: Shutting down interface eth0: [ OK ]
- 22:
- 23: Shutting down loopback interface: [ OK ]
- 24:
- 25: Bringing up loopback interface: [ OK ]
- 26:
- 27: Bringing up interface eth0:
- 28:
- 29: Determining IP information for eth0... done.
- 30:
- 31: [ OK ]
- 32:
- 33: [root@DB-Server ~]# hostname
- 34:
- 35: Test
- 36:
- 37: [root@DB-Server ~]#
- 38:
注意:其實(shí) /etc/init.d/network restart 沒有什么用。只是當(dāng)時(shí)實(shí)驗(yàn)時(shí)以為必須重啟網(wǎng)絡(luò)服務(wù)?! ?/p>
在SecureCRT新建克隆一個(gè)會(huì)話發(fā)現(xiàn)hostanme已經(jīng)從DB-Server變?yōu)門est了,但是/etc/sysconfig/network的值還是DB-Server.localdomain,并沒有變?yōu)門est。
- 1: [root@ Test ~]# more /etc/sysconfig/network
- 2:
- 3: NETWORKING=yes
- 4:
- 5: NETWORKING_IPV6=yes
- 6:
- 7: HOSTNAME=DB-Server.localdomain
- 8:
- 9: [root@ Test ~]# hostname
- 10:
- 11: Test
- 12:
- 13: [root@ Test ~]# more /etc/hosts
- 14:
- 15: # Do not remove the following line, or various programs
- 16:
- 17: # that require network functionality will fail.
- 18:
- 19: 127.0.0.1 localhost.localdomain localhost
- 20:
- 21: ::1 localhost6.localdomain6 localhost6
- 22:
- 23: [root@ Test ~]# more /proc/sys/kernel/hostname
- 24:
- 25: Test
- 26:
- 27: [root@ Test ~]#
- 28:
但是如果重啟系統(tǒng)后hostname會(huì)變?yōu)镈B-Server,Google了一些英文文檔資料才知道,hostname是Linux系統(tǒng)下的一個(gè)內(nèi)核參數(shù),它保存在/proc/sys/kernel/hostname下,但是它的值是Linux啟動(dòng)時(shí)從rc.sysinit讀取的。
hostname is a kernel parameter which stores hostname of the system. Its location is”/proc/sys/kernel/hostname”
The value for this parameter is loaded to kernel by rc.sysinit file during the boot process.
#p#
而/etc/rc.d/rc.sysinit中HOSTNAME的取值來(lái)自與/etc/sysconfig/network下的HOSTNAME,代碼如下所示,至此,我們可以徹底明白了。
- HOSTNAME=`/bin/hostname`
- HOSTTYPE=`uname -m`
- unamer=`uname -r`
- set -m
- if [ -f /etc/sysconfig/network ]; then
- . /etc/sysconfig/network
- fi
- if [ -z "$HOSTNAME" -o "$HOSTNAME" = "(none)" ]; then
- HOSTNAME=localhost
- fi
結(jié)論:/etc/sysconfig/network 確實(shí)是hostname的配置文件,hostname的值跟該配置文件中的HOSTNAME有一定的關(guān)聯(lián)關(guān)系,但是沒有必然關(guān)系,hostname的值來(lái)自內(nèi)核參數(shù)/proc/sys/kernel/hostname,如果我通過(guò)命令sysctl kernel.hostname=Test修改了內(nèi)核參數(shù),那么hostname就變?yōu)榱薚est了。
問題2: 修改了hostname后,如何使其立即生效而不用重啟操作系統(tǒng)。
方法1:修改了/etc/sysconfig/network下的HOSTNAME后,然后使用echo servername > /proc/sys/kernel/hostname。
[root@DB-Server ~]# echo Test >/proc/sys/kernel/hostname
注意當(dāng)前會(huì)話還是不會(huì)變化,但是后續(xù)新建會(huì)話則會(huì)生效。
方法2:修改了/etc/sysconfig/network下的HOSTNAME后,然后使用sysctl kernel.hostname命令使其立即生效
[root@DB-Server ~]# sysctl kernel.hostname=Test2
kernel.hostname = Test2
注意當(dāng)前會(huì)話還是不會(huì)變化,但是后續(xù)新建會(huì)話會(huì)生效。
方法3:修改了/etc/sysconfig/network下的HOSTNAME后,然后使用hostname命令使其生效
[root@ Test ~]# hostname DB-Server
注意當(dāng)前會(huì)話還是不會(huì)變化,但是后續(xù)新建會(huì)話會(huì)生效。
其實(shí)呢,這幾種方式只是結(jié)合永久性修改和臨時(shí)性修改hostname,使其不必重啟Linux服務(wù)器,哈哈,不知道你明白沒。
問題3: 修改hostname有幾種方式?
1: hostname DB-Server –運(yùn)行后立即生效(新會(huì)話生效),但是在系統(tǒng)重啟后會(huì)丟失所做的修改;
2: echo DB-Server > /proc/sys/kernel/hostname –運(yùn)行后立即生效(新會(huì)話生效),但是在系統(tǒng)重啟后會(huì)丟失所做的修改;
3: sysctl kernel.hostname=DB-Server –運(yùn)行后立即生效(新會(huì)話生效),但是在系統(tǒng)重啟后會(huì)丟失所做的修改;
4: 修改/etc/sysconfig/network下的HOSTNAME變量 –需要重啟生效,永久性修改。
問題4: hostname跟/etc/hosts 下配置有關(guān)系嗎?
如果從我上面的實(shí)驗(yàn)來(lái)看,其實(shí)hostname跟/etc/hosts下的配置是沒有關(guān)系的。hostname的修改、變更完全不依賴hosts文件。 其實(shí)hosts文件的作用相當(dāng)如DNS,提供IP地址到hostname的對(duì)應(yīng)。早期的互聯(lián)網(wǎng)計(jì)算機(jī)數(shù)量少,單機(jī)hosts文件里足夠存放所有聯(lián)網(wǎng)計(jì)算機(jī)。不過(guò),隨著互聯(lián)網(wǎng)的發(fā)展,這就遠(yuǎn)遠(yuǎn)不夠了。于是就出現(xiàn)了分布式的DNS系統(tǒng)。由DNS服務(wù)器來(lái)提供類似的IP地址到域名的對(duì)應(yīng)。具體可以man hosts查看相關(guān)信息。
Linux系統(tǒng)在向DNS服務(wù)器發(fā)出域名解析請(qǐng)求之前會(huì)查詢/etc/hosts文件,如果里面有相應(yīng)的記錄,就會(huì)使用hosts里面的記錄。/etc/hosts文件通常里面包含這一條記錄
127.0.0.1 localhost.localdomain localhost
hosts文件格式是一行一條記錄,分別是IP地址 、hostname、 aliases,三者用空白字符分隔,aliases可選。
127.0.0.1到localhost這一條建議不要修改,因?yàn)楹芏鄳?yīng)用程序會(huì)用到這個(gè),比如sendmail,修改之后這些程序可能就無(wú)法正常運(yùn)行。
但是呢,其實(shí)hostname也不是說(shuō)跟/etc/hosts一點(diǎn)關(guān)系都沒有。在/etc/rc.d/rc.sysinit中,有如下邏輯判斷,當(dāng) hostname為localhost后localhost.localdomain時(shí),將會(huì)使用接口IP地址對(duì)應(yīng)的hostname來(lái)重新設(shè)置系統(tǒng)的 hostname。
- HOSTNAME=`/bin/hostname`
- HOSTTYPE=`uname -m`
- unamer=`uname -r`
- set -m
- if [ -f /etc/sysconfig/network ]; then
- . /etc/sysconfig/network
- fi
- if [ -z "$HOSTNAME" -o "$HOSTNAME" = "(none)" ]; then
- HOSTNAME=localhost
- fi
我們來(lái)實(shí)驗(yàn)一下吧!修改hosts、network文件,修改后的值如下所示:
- [root@ localhost~]# more /etc/hosts
- # Do not remove the following line, or various programs
- # that require network functionality will fail.
- ::1 localhost.localdomain localhost
- 127.0.0.1 localhost.localdomain localhost
- 192.168.244.128 DB-Server.localdomain DB-Server
- [root@ localhost ~]# more /etc/sysconfig/network
- NETWORKING=yes
- NETWORKING_IPV6=yes
- HOSTNAME=localhost.localdomain
重啟系統(tǒng)后,我們?cè)俳貓D看看情況:
所以,這也是有時(shí)候人們以為hostname的值跟hosts文件有關(guān)系的緣故。
問題5: 如何查看hostname的值,以那個(gè)為準(zhǔn)?
- [root@DB-Server ~]# hostname
- DB-Server
- [root@DB-Server ~]# more /proc/sys/kernel/hostname
- DB-Server
- [root@DB-Server ~]# more /etc/sysconfig/network
- NETWORKING=yes
- NETWORKING_IPV6=yes
- HOSTNAME=localhost.localdomain
以那個(gè)為準(zhǔn)呢,如果你理解了前面4個(gè)問題,那么理解這個(gè)問題就很簡(jiǎn)單了。
參考資料:
http://jblevins.org/log/hostname
http://www.ducea.com/2006/08/07/how-to-change-the-hostname-of-a-linux-system/