• 【转】深入理解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的配置值放在哪里?

    [root@po132345806-a ~]# hostname
    po132345806-a.gfg1.esquel.com
    [root@po132345806-a ~]# more /etc/hosts
    # Do not remove the following line, or various programs 
    # that require network functionality will fail. 
    127.0.0.1 localhost.localdomain localhost 
    ::1 localhost6.localdomain6 localhost6 
    [root@po132345806-a ~]# more /etc/sysconfig/network 
    NETWORKING=yes 
    NETWORKING_IPV6=yes 
    HOSTNAME=localhost.localdomain

    有图有真相,免得大家不相信这个现象,当我第一次碰到这种特殊情况时,我也非常纳闷。Google了一些资料加上自己的实践才弄明白

    clipboard

        问题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 [root@po132345806-a ~]# hostname
    2 po132345806-a.gfg1.esquel.com
    3 [root@po132345806-a ~]# more /proc/sys/kernel/hostname
    4 po132345806-a.gfg1.esquel.com
    5 [root@po132345806-a ~]# sysctl kernel.hostname
    6 kernel.hostname = po132345806-a.gfg1.esquel.com
    7 [root@po132345806-a ~]#
    8 [root@po132345806-a ~]# reboot

      

    clipboard[1]

        重启过后发现居然hostname变为DB-Server了,也就是说修改配置文件/etc/sysconfig/network下的HOSTNAME生效了。那么也就是说应该是有人修改过 kernel.hostname,请看下面实验

     1 [root@DB-Server ~]# more /etc/sysconfig/network
     2 NETWORKING=yes
     3 NETWORKING_IPV6=yes
     4 HOSTNAME=DB-Server.localdomain 
     5 [root@DB-Server ~]# echo Test > /proc/sys/kernel/hostname
     6 [root@DB-Server ~]# more /etc/proc/sys/kernel/hostname 
     7 /etc/proc/sys/kernel/hostname: No such file or directory 
     8 [root@DB-Server ~]# more /proc/sys/kernel/hostname
     9 Test
    10 [root@DB-Server ~]# /etc/init.d/network restart
    11 Shutting down interface eth0: [ OK ]
    12 Shutting down loopback interface: [ OK ]
    13 Bringing up loopback interface: [ OK ] 
    14 Bringing up interface eth0: 
    15 Determining IP information for eth0... done. 
    16 [ OK ] 
    17 [root@DB-Server ~]# hostname 
    18 Test 
    19 [root@DB-Server ~]# 

    注意:其实 /etc/init.d/network restart 没有什么用。只是当时实验时以为必须重启网络服务。

    clipboard[2]

    在SecureCRT新建克隆一个会话发现hostanme已经从DB-Server变为Test了,但是/etc/sysconfig/network的值还是DB-Server.localdomain,并没有变为Test。

     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 ~]# 

    clipboard[3]

    但是如果重启系统后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,代码如下所示,至此,我们可以彻底明白了。

     1 HOSTNAME=`/bin/hostname`
     2  
     3 HOSTTYPE=`uname -m`
     4  
     5 unamer=`uname -r`
     6  
     7 set -m
     8  
     9 if [ -f /etc/sysconfig/network ]; then
    10  
    11 . /etc/sysconfig/network
    12  
    13 fi
    14  
    15 if [ -z "$HOSTNAME" -o "$HOSTNAME" = "(none)" ]; then
    16  
    17     HOSTNAME=localhost
    18  
    19 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。

             [root@DB-Server ~]# echo Test >/proc/sys/kernel/hostname

              注意当前会话还是不会变化,但是后续新建会话则会生效。

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

            [root@DB-Server ~]# sysctl kernel.hostname=Test2

            kernel.hostname = Test2

            注意当前会话还是不会变化,但是后续新建会话会生效。

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

            [root@Test ~]# 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文件,修改后的值如下所示:

     1 [root@localhost ~]# more /etc/hosts 
     2  
     3 # Do not remove the following line, or various programs 
     4  
     5 # that require network functionality will fail. 
     6  
     7 ::1 localhost.localdomain localhost 
     8  
     9 127.0.0.1 localhost.localdomain localhost 
    10  
    11 192.168.244.128 DB-Server.localdomain DB-Server 
    12  
    13 [root@localhost  ~]# more /etc/sysconfig/network 
    14  
    15 NETWORKING=yes 
    16  
    17 NETWORKING_IPV6=yes 
    18  
    19 HOSTNAME=localhost.localdomain

    重启系统后,我们再截图看看情况:

    clipboard[4]

        所以这也是有时候人们以为hostname的值跟hosts文件有关系的缘故。

    问题5: 如何查看hostname的值,以那个为准?

     1 [root@DB-Server ~]# hostname 
     2  
     3 DB-Server
     4  
     5 [root@DB-Server ~]# more /proc/sys/kernel/hostname 
     6  
     7 DB-Server 
     8  
     9 [root@DB-Server ~]# more /etc/sysconfig/network 
    10  
    11 NETWORKING=yes 
    12  
    13 NETWORKING_IPV6=yes 
    14  
    15 HOSTNAME=localhost.localdomain

       以那个为准呢,如果你理解了前面4个问题,那么理解这个问题就很简单了。

    参考资料:

    http://jblev​​ins.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

    作者:潇湘隐者

    如果你真心觉得文章写得不错,而且对你有所帮助,那就不妨小小打赏一下吧,如果囊中羞涩,不妨帮忙“推荐"一下,您的“推荐”和”打赏“将是我最大的写作动力!

    本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接.
  • 相关阅读:
    Android开发如何定制framework层服务
    Intellij IDEA通过SVN导入基于Springboot的maven项目以及对已有项目做更新
    intelliJ IDEA 怎么添加本地的idea web项目
    Android热修复之AndFix使用教程
    iOS友盟分享的使用总结
    iOS 传感器集锦
    IOS CALayer的属性和使用
    Swift使用Alamofire实现网络请求
    Android踩坑随笔Fragment中onActivityResult方法不被调用
    上周热点回顾(4.30-5.6)团队
  • 原文地址:https://www.cnblogs.com/lly001/p/11162418.html
Copyright © 2020-2023  润新知