shell脚本-监控多台服务器磁盘利用率介绍

第一步:实现免密登录服务器 ,为后续脚本免密登录做好准备。

第二步:把要监控服务器的ip地址 root用户 端口port 写入host.info文件中以便后续脚本从这个文件读取服务器信息。

第三步:写shell脚本,先从host.info中拿到信息连接各个服务器,读取每个服务器的磁盘使用率,大于一定值(80%)则报警

第一步:免密登录

测试192.168.70.24 登录 192.168.70.25

在24机器上执行:

ssh-keygen

一路回车

在用户根目录下的.ssh目录下可以看到生成2个文件:id_rsa(私钥文件)、id_rsa.pub(公钥文件)我们需要的是公钥文件。

[root@zabbix-agent02 ~]# ls .ssh/id_rsa  id_rsa.pub  known_hosts

将本机(24机器)刚才生成的公钥copy到25机器 会提示输入25机器密码 输入密码即可

ssh-copy-id root@192.168.70.25

在25机器上 .ssh/authorized_keys 文件是否生成并含内容

[root@localhost ~]# cat .ssh/authorized_keysssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDGg+cD6QLZ3/fBxcRDbvEaMjhl+byslM+6o87dZh0AUiuRxqakTCYBEmhgzA/6giUcMKfymvqshncOWw0i0cS310pY+o2DK56o1oizxCOmmBHk81bl6MdbRnUk9WOj5IKPSXsnr3tmcguaUlA0Y7VVJmNy3fHQ41Oo29VxjBy9GPxc2N65I33LUzzPNEjJjp3gHMAAkxGRkuI49UybplyAXNkb7RHnGq/ZDBJtNIrhXPIMOsWURVAZePGrvQYa/RpxpxfmJx6QuE8YNU6EP7S8l6u90piPxsRyGr624NKXbiI/rxCvDrfGXcIwbIs2Cao+g6cJcRVFdU2SDwkwIQgf root@localhost

可以直接在24机器上使用命令登录25机器

[root@localhost ~]# ssh root@192.168.70.25Last login: Tue Jul 11 00:53:57 2023 from 192.168.70.1[root@localhost ~]#  ifconfigens33: flags=4163  mtu 1500     inet 192.168.70.25  netmask 255.255.255.0  broadcast 192.168.70.255

第二步:创建服务器信息文件

这里我host.info文件和shell脚本文件都创建再/opt/scripts/文件夹下,并加入22机器两台机器一起测试,22机器人也需要进行第一步,为免密登录做好准备,与上述第一步内容一致不再重复。

[root@localhost scripts]# vim host.info192.168.70.25 root 22192.168.70.22 root 22

第三步:创建shell脚本文件

[root@localhost scripts]# vim 7.sh         for USE_RATE in $USE_RATE_LIST;do                # %=* 解释: 以“=”为分隔符,去除右边所有                # #*= 解释: 以“=“为分隔符,去除左边所有                # RART_NAME=${$USE_RATE%=*}                part_name=${USE_RATE%=*}                use_rate=${USE_RATE#*=}                if [ $use_rate -gt 80 ];then                        echo ”Warning: $part_name = $use_rate Partition use_rate more then $use_rate %!“                else                        echo "$part_name = $use_rate"                fi        donedone
[root@localhost scripts]# bash  7.sh / = 14/boot = 14/ = 14/boot = 14