天天看點

深入了解Linux修改hostname(原文作者:潇湘隐者)

當我覺得對Linux系統下修改hostname已經非常熟悉的時候,今天碰到了幾個個問題,這幾個問題給我好好上了一課,很多知識點,當你覺得你已經掌握的時候,其實你了解的還隻是皮毛。技術活,切勿淺嘗則止!

實驗環境:Red Hat Enterprise Linux Server release 5.7 (Tikanga) ,其它版本Linux可能有所不同。請以實際環境為準。

其實我多次修改過hostname,一般隻需要修改 /etc/hosts 和 /etc/sysconfig/network 兩個檔案下相關配置即可。但是,今天我遇到了兩個問題:

   問題1: 為什麼/etc/sysconfig/network配置檔案中HOSTNAME為localhost.localdomain,但是顯示的hostname為po132345806-a,那到底hostname的配置值放在哪裡?

1: [[email protected] ~]# 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: [[email protected] ~]# more /etc/sysconfig/network 7: NETWORKING=yes 8: NETWORKING_IPV6=yes 9: HOSTNAME=localhost.localdomain
           

有圖有真相,免得大家不相信這個現象,當我第一次碰到這種特殊情況時,我也非常納悶。Google了一些資料加上自己的實踐才弄明白

深入了解Linux修改hostname(原文作者:潇湘隐者)

問題2: 修改了hostname後,如何使其立即生效而不用重新開機作業系統。

    問題3: 修改hostname有幾種方式?

    問題4: hostname跟/etc/hosts 下配置有關系嗎?

    問題5: 如何檢視hostname的值,以那個為準?

問題1解答:我一直以為hostname的值配置在/etc/sysconfig/network中,這個檔案裡面HOSTNAME配置為啥,hostname值就是啥。但是為什麼出現上面那種情況呢?難道/etc/sysconfig/network

   不是hostname的配置檔案,難道還另有其它配置檔案?于是我當時實驗了一下修改了/etc/sysconfig/network檔案中HOSTNAME為DB-Server,發現

hostname的值依然沒有變化,于是重新開機了計算機

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
           
深入了解Linux修改hostname(原文作者:潇湘隐者)

重新開機過後發現居然hostname變為DB-Server了,也就是說修改配置檔案/etc/sysconfig/network下的HOSTNAME生效了。那麼也就是說應該是有人修改過 kernel.hostname,請看下面實驗

1: [[email protected] ~]# more /etc/sysconfig/network

   2:  

   3: NETWORKING=yes

   4:  

   5: NETWORKING_IPV6=yes

   6:  

   7: HOSTNAME=DB-Server.localdomain

   8:  

   9: [[email protected] ~]# echo Test > /proc/sys/kernel/hostname

  10:  

  11: [[email protected] ~]# more /etc/proc/sys/kernel/hostname

  12:  

  13: /etc/proc/sys/kernel/hostname: No such file or directory

  14:  

  15: [[email protected] ~]# more /proc/sys/kernel/hostname

  16:  

  17: Test

  18:  

  19: [[email protected] ~]# /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: [[email protected] ~]# hostname

  34:  

  35: Test

  36:  

  37: [[email protected] ~]# 

  38:  
           

注意:其實 /etc/init.d/network restart 沒有什麼用。隻是當時實驗時以為必須重新開機網絡服務。

深入了解Linux修改hostname(原文作者:潇湘隐者)

在SecureCRT建立克隆一個會話發現hostanme已經從DB-Server變為Test了,但是/etc/sysconfig/network的值還是DB-Server.localdomain,并沒有變為Test。

1: [[email protected] ~]# more /etc/sysconfig/network

   2:  

   3: NETWORKING=yes

   4:  

   5: NETWORKING_IPV6=yes

   6:  

   7: HOSTNAME=DB-Server.localdomain

   8:  

   9: [[email protected] ~]# hostname

  10:  

  11: Test

  12:  

  13: [[email protected] ~]# 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: [[email protected] ~]# more /proc/sys/kernel/hostname

  24:  

  25: Test

  26:  

  27: [[email protected] ~]# 

  28:  

clipboard[3]
           
深入了解Linux修改hostname(原文作者:潇湘隐者)

但是如果重新開機系統後hostname會變為DB-Server,Google了一些英文文檔資料才知道,hostname是Linux系統下的一個核心參數,它儲存在/proc/sys/kernel/hostname下,但是它的值是Linux啟動時從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.

而/etc/rc.d/rc.sysinit中HOSTNAME的取值來自與/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

結論:/etc/sysconfig/network 确實是hostname的配置檔案,hostname的值跟該配置檔案中的HOSTNAME有一定的關聯關系,但是沒有必然關系,hostname的值來自核心參數/proc/sys/kernel/hostname,如果我通過指令sysctl kernel.hostname=Test修改了核心參數,那麼hostname就變為了Test了。

問題2: 修改了hostname後,如何使其立即生效而不用重新開機作業系統。

    方法1:修改了/etc/sysconfig/network下的HOSTNAME後,然後使用echo  servername > /proc/sys/kernel/hostname。

         [[email protected] ~]# echo Test >/proc/sys/kernel/hostname

          注意目前會話還是不會變化,但是後續建立會話則會生效。

    方法2:修改了/etc/sysconfig/network下的HOSTNAME後,然後使用sysctl kernel.hostname指令使其立即生效

        [[email protected] ~]# sysctl kernel.hostname=Test2

        kernel.hostname = Test2

注意目前會話還是不會變化,但是後續建立會話會生效。

    方法3:修改了/etc/sysconfig/network下的HOSTNAME後,然後使用hostname指令使其生效

        [[email protected] ~]# hostname DB-Server

        注意目前會話還是不會變化,但是後續建立會話會生效。

    其實呢,這幾種方式隻是結合永久性修改和臨時性修改hostname,使其不必重新開機Linux伺服器,哈哈,不知道你明白沒。

問題3: 修改hostname有幾種方式?

    1:  hostname DB-Server                                   --運作後立即生效(新會話生效),但是在系統重新開機後會丢失所做的修改

    2:  echo DB-Server  > /proc/sys/kernel/hostname          --運作後立即生效(新會話生效),但是在系統重新開機後會丢失所做的修改

    3: sysctl kernel.hostname=DB-Server                      --運作後立即生效(新會話生效),但是在系統重新開機後會丢失所做的修改

    4: 修改/etc/sysconfig/network下的HOSTNAME變量             --需要重新開機生效,永久性修改。

問題4: hostname跟/etc/hosts 下配置有關系嗎?

      如果從我上面的實驗來看,其實hostname跟/etc/hosts下的配置是沒有關系的。hostname的修改、變更完全不依賴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也不是說跟/etc/hosts一點關系都沒有。在/etc/rc.d/rc.sysinit中,有如下邏輯判斷,當hostname為localhost後localhost.localdomain時,将會使用接口IP位址對應的hostname來重新設定系統的hostname。

        # In theory there should be no more than one network interface active

        # this early in the boot process -- the one we're booting from.

        # Use the network address to set the hostname of the client. This

        # must be done even if we have local storage.

        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

我們來實驗一下吧,修改hosts、network檔案,修改後的值如下所示:

[[email protected] ~]# 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

[[email protected]  ~]# more /etc/sysconfig/network

NETWORKING=yes

NETWORKING_IPV6=yes

HOSTNAME=localhost.localdomain

重新開機系統後,我們再截圖看看情況:

深入了解Linux修改hostname(原文作者:潇湘隐者)

是以這也是有時候人們以為hostname的值跟hosts檔案有關系的緣故。

問題5: 如何檢視hostname的值,以那個為準?

[[email protected] ~]# hostname

DB-Server

[[email protected] ~]# more /proc/sys/kernel/hostname

DB-Server

[[email protected] ~]# more /etc/sysconfig/network

NETWORKING=yes

NETWORKING_IPV6=yes

HOSTNAME=localhost.localdomain

   以那個為準呢,如果你了解了前面4個問題,那麼了解這個問題就很簡單了。

參考資料:

http://jblevins.org/log/hostname

http://www.ducea.com/2006/08/07/how-to-change-the-hostname-of-a-linux-system/

https://www.kernel.org/doc/Documentation/sysctl/kernel.txt

http://soft.chinabyte.com/os/281/11563281.shtml

繼續閱讀