Shell脚本之为集群机器添加DNS

一.环境

1.本次实验的主要配置环境如下,


  • 物理机:windows 10
  • 虚拟机:VMware pro 12,用其分别创建了三个虚拟机,其ip地址分别为​​192.168.211.3​​​,​​192.168.211.4​​​,​​192.168.211.5​​​。其中​​192.168.211.3​​​这台机器的主机名已经配置为​​littlelawson​​。

二.需求

现在想将​​192.168.211.4​​​,​​192.168.211.5​​​这两台机器的主机名dns 做一下修改**【修改dns的目的是,可以直接让集群间的机器使用主机名而不是ip进行定位】**,修改成​​server1​​​,​​server2​

三.实现

实现修改主机名 有两种方式:


  • 1.一种是单独修改 ​​/etc/hosts​​文件中的内容,在其后追加​​[ipAddress] [hostname]​​。但是如果我们有很多台服务器,再使用这种方式,就会变得十分低效。所以这里采用第二种方式:
  • 2.使用shell脚本,编写修改主机名的程序,然后运行即可。不过这样的前提是,运行脚本的主机A能够远程连接到其它服务器B、C…X等。【如果想更方便的话,可以实现ssh免密登录,可以看我之前的博客了解ssh】
    这里提供如下shell脚本,并做一些解释:

#!/bin/bash
for HOST in `cat hosts`;do
OLDNAME=`ssh laowang@$HOST "hostname"`
NEWNAME=`cat ip_dns.map | grep $HOST | awk '{print $2}' | head -1`
ssh -t laowang@$HOST "sudo sed -i 's/HOSTNAME=${OLDNAME}/HOSTNAME=${NEWNAME}/g' /etc/sysconfig/network"
ssh -t laowang@$HOST "sudo hostname $NEWNAME"
echo "$HOST"
ssh -t laowang@$HOST "sudo cat /etc/sysconfig/network | grep HOSTNAME"
ssh -t laowang@$HOST hostname
done

  • ​#!/bin/bash​​:说明这是一个可执行的shell脚本程序
  • ​for HOST in `cat hosts`; do​​:这是一个shell脚本中的for循环,这里的HOST是一个变量,其中的值是执行文件​​cat hosts​​所得到的每一行内容。【这也就间接说明,如果要执行这个文件,就需要在当前目录下有hosts这个文件 】。需要注意的是,for语句中的HOST没有添加$符号。
  • ​OLDNAME = `ssh laowang@$HOST "hostname"`​​:这是一个赋值语句。分为以下几个步骤:
    (1)​​ssh laowang@$HOST​​以laowang这个身份登录到HOST变量值所表示的那台机器上,
    (2)然后执行​​hostname​​命令
    (3)最后将命令显示出来的值赋给​​OLDNAME​
  • ​NEWNAME=`cat ip_dns.map | grep $HOST |awk '{print $2}' | head -1`​​:这个命令稍微复杂,分为如下几步执行:
    (1)​​cat ip_dns.map​​这个是查看ip_dns.map文件中的内容。【所以能够看出来ip_dns.map是一个ip到dns的映射,这个需要自己创建】
    (2)​​| grep $HOST​​这个就是将步骤(1)输出中的内容中查找包含$HOST的字符串,
    (3)​​| awk '{print $2}'​​这个就是将步骤(2)过滤得到的内容中的第二列打印出来
    (4)​​| head -1​​:就是取步骤(3)中首先出现的第二列【第一行,第二列的那个值】
  • ​ssh -t laowang@$HOST "sudo sed -i 's/HOSTNAME=${OLDNAME}/HOSTNAME=${NEWNAME}/g' /etc/sysconfig/network"​​中的​​sed -i 's/HOSTNAME=${OLDNAME}/HOSTNAME=${NEWNAME}/g' /etc/sysconfig/network​​是一个查找替换命令。
    具体的意思是:查找/etc/sysconfig/network这个文件中的HOSTNAME=OLDNAME这个内容,并将其替换成HOSTNAME=NEWNAME。其中OLDNAME和NEWNAME都是变量。
  • 后面的就是比较雷同的内容了,不再啰嗦。
    ####四.执行结果
  • 1.hosts文件

[root@littlelawson ~]# cat hosts
192.168.211.4
192.168.211.5
[root@littlelawson ~]# cat changeHostname.sh 
#!/bin/bash
for HOST in `cat hosts`;do
OLDNAME=`ssh root@$HOST "hostname"`
NEWNAME=`cat ip_dns.map | grep $HOST | awk '{print $2}' | head -1`
ssh -t root@$HOST "sudo sed -i 's/HOSTNAME=${OLDNAME}/HOSTNAME=${NEWNAME}/g' /etc/sysconfig/network"
ssh -t root@$HOST "sudo hostname $NEWNAME"
echo "$HOST"
ssh -t root@$HOST "sudo cat /etc/sysconfig/network | grep HOSTNAME"
ssh -t root@$HOST hostname
done
  • ip_dns.map文件【从ip到hostname的映射】
[root@littlelawson ~]# cat ip_dns.map 
192.168.211.4 server4
192.168.211.5 server5
  • 运行结果如下:
[root@littlelawson ~]# bash changeHostname.sh
Connection to 192.168.211.4 closed.
Connection to 192.168.211.4 closed.
192.168.211.4
Connection to 192.168.211.4 closed.
server4
Connection to 192.168.211.4 closed.
Connection to 192.168.211.5 closed.
Connection to 192.168.211.5 closed.
192.168.211.5
Connection to 192.168.211.5 closed.
server5
Connection to 192.168.211.5 closed.

五.总结


  • ​ssh root@192.168.211.5 "hostname"​
  • 1.表示使用ssh命令以root身份登录到192.168.211.5这台服务器上
  • 2.接着运行命令"hostname"
  • ​cat test.txt | grep 'little'​
  • 01.查询test.txt这个文件中包含’little’关键字的行,
  • 02.因为grep后面没有接文件,所以默认打印到屏幕缓冲区
  • 03.​​cat test.txt | grep 'little' > result.txt​​:将查询结果导出到(当前)目录下的result.txt中
  • 之前配置了一个​​192.168.5.101 -> 192.168.5.[102-108]​​​【单向】的免密。突然发现,今天登录不上了。使用​​ssh [user]@[ip1]​​​【第一次运行】命令之后,就会登录到指定ip1所在的机器上。但是如果在此基础之上再运行​​ssh [user]@[ip2]​​【第二次运行】,则会出现ssh命令需要密码的情况,这是因为在第二次运行时,指定ip2所在的机器并没有拿到ip2所在主机的pub_key,所以需要输入密码。相反,如果你先exit到原始的103主机,则不会再次输入密码。

[laowang@cdh201 ~]$ ssh laowang@192.168.5.106
Last login: Thu Jun 28 05:51:05 2018 from 192.168.5.106

[laowang@bitest02 ~]$ exit
logout
Connection to 192.168.5.106 closed.

[laowang@cdh201 ~]$ ssh laowang@192.168.5.107
Last login: Thu Jun 28 14:19:20 2018 from 192.168.5.101

[laowang@bitest03 ~]$ exit
logout
Connection to 192.168.5.107 closed.
  • 注意不同的linux系统,具体的shell脚本实现不大相同。比如说,centos系统的hosts文件在​​/etc/hosts​​目录下。
--------------------------------------------------------------------------------------------------------------------------------------------

六.补充

1.针对不同的主机ip添加主机名。该文件为​​/etc/sysconfig/network​

实现代码

[root@littlelawson ~]# cat chageHostName.sh 
#!/bin/bash
for HOST in `cat hosts`;do
NEWNAME=`cat ip_dns.map | grep $HOST | awk '{print $2}' | head -1`
ssh -t root@$HOST "echo $NEWNAME >> /etc/sysconfig/network"
done
  • 注:**​​ssh -t root@$HOST "echo $NEWNAME >> /etc/sysconfig/network"​​​**这里是由​​"​​号括起来的远程命令!一定要注意!
[root@littlelawson ~]# cat hosts
192.168.211.4
192.168.211.5
192.168.211.6
[root@littlelawson ~]# cat ip_dns.map 
192.168.211.4 server4
192.168.211.5 server5
192.168.211.6 server6
[root@littlelawson ~]#