60天shell脚本计划-2/12-渐入佳境

--作者:飞翔的小胖猪

--创建时间:2021年2月1日

--修改时间:2021年2月5日

说明

 每日上传更新一个shell脚本,周期为60天。如有需求的读者可根据自己实际情况选用合适的脚本,也可在评论区留言提出脚本需求,作者会尽快根据需求编写相关脚本对功能进行实现。

 每篇文章包含5个脚本。

总进度:2/12

上一篇脚本链接:https://www.cnblogs.com/Pigs-Will-Fly/p/14333284.html

下一篇脚本链接:https://www.cnblogs.com/Pigs-Will-Fly/p/14380780.html

主要内容

21年2月1日-系统监控脚本(简易)

 ************************************************************************************************************************************************************************************************************************************

脚本说明

脚本获取Linux操作系统中内存、cpu、根目录及message日志信息,展示当前的系统的资源使用情况。 判断当前系统中是否存在僵尸进程,/var/log/message文件最后100行是否存在错误日志。

文件说明

System_health_check.sh:脚本主体程序文件

脚本主体

[root@135 6_system_check]# cat System_health_check.sh 
#!/bin/bash #ip地址 ip_address=`ip a|grep -i -A2 'MULTICAST,UP,LOWER_UP' | grep -E -o "(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)" |grep -E -v "(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.255" |grep -E '^80|^10|^192' | head -1 ` Total_Swap=`cat /proc/meminfo |grep SwapTotal | awk '{printf ("%d\n",$2/1024)}'` #结果为一个数字,代表总的Swap值,单位为M Free_Swap=`cat /proc/meminfo |grep SwapFree | awk '{printf ("%d\n",$2/1024)}'` #结果为一个数字,代表空闲的Free值,单位为M #Mem_info=`free -m | awk 'NR==2{print $2,$3,$4,$5,$7}'` Mem_info=`free -m | awk 'BEGIN { OFS="|"};NR==2{print $2,$3,$4}'` #只要前面4个字段,total use free share Cpu_Num=`cat /proc/cpuinfo | grep -i process | wc -l` #获取逻辑CPU的个数 Avage_five_cpu=`uptime | sed 's/.*load average: //g' | sed 's#\,##g'|awk '{print $2}'` #采集5分钟CPU负载情况 System_start_time=`uptime | awk '{print $1}'` #得开机时间 System_uptime=`uptime |awk -F ',' '{print $1}' |sed 's#.*up##g'` #得到运行时常 #查看确认近100行日志是否有告警。 tail -100 /var/log/messages | grep -i -E 'warning|warn|error|crit|alert|emerg|err' &> /dev/null #cat /var/log/messages | grep -i -E 'warning|warn|error|crit|alert|emerg|err' &> /dev/null log_check=`echo $?` if [[ $log_check -eq 0 ]];then log_notice=waring else log_notice=no_waring fi echo "hostname | ip_address | Total_Swap | Free_Swap | total_mem| use_mem | free_mem| Cpu_Num | Avage_five_cpu | zombie | log_notice| System_start_time | System_uptime " | awk -F'|' 'BEGIN { OFS="\t"} ;{ $1=$1 ; print $0} ' > result.xls if [[ `ps -A -o stat,ppid,pid,cmd | grep -e '^[Zz]'` ]];then echo "`hostname` | $ip_address | $Total_Swap | $Free_Swap | $Mem_info | $Cpu_Num | $Avage_five_cpu | yes | $log_notice| $System_start_time | $System_uptime " | awk -F'|' 'BEGIN { OFS="\t"} ;{ $1=$1 ; print $0} ' >> result.xls else echo "`hostname` | $ip_address | $Total_Swap | $Free_Swap | $Mem_info | $Cpu_Num | $Avage_five_cpu | no | $log_notice | $System_start_time | $System_uptime " | awk -F'|' 'BEGIN { OFS="\t"} ;{ $1=$1 ; print $0} ' >> result.xls fi

结果

执行命令结果:

 生成execl文件格式:

**************************************************************************************************************2021年2月1日脚本结束*****************************************************************************************************************

 

21年2月2日-一键修改ip地址

 ************************************************************************************************************************************************************************************************************************************

脚本说明

通过脚本获取当前主机的网口名和网口ip地址,再根据脚本中定义的字典获取到将要修改的新的ip地址,最后调用sed命令对网络配置文件进行修改。

使用脚本时注意由于该脚本为定制编写的在获取当前系统ip和网口名时需要更具自己环境指定。

单台设备修改IP地址时就不要采用该脚本了,单台修改时老老实实的手动修改配置文件嘛 。

文件说明

Batch_edit_add.sh:脚本主体程序文件

脚本主体

[root@135 7_edit_address]# cat Batch_edit_add.sh
#!/bin/bash
#修改静态路由函数
#该脚本仅仅适用于network的网络,NetworkManager不用这么麻烦。
edit_yw_ip(){
  #获取主机当前接口和ip地址。
  net_ip=`ifconfig | grep 192.168.111. | awk '{print $2}'`
  net_name=`ifconfig | egrep  -B1  '192.168.111.'| grep -i ens | awk -F':' '{print $1}'`

  #define old_ip and new_ip dict
  declare -A dict_ip_b
  dict_ip_b=([192.168.111.4]="192.168.20.4"  \
  [192.168.111.1]="192.168.20.1"  \
  [192.168.111.2]="192.168.20.2"  \
  [192.168.111.135]="192.168.20.135"  \
  [192.168.111.3]="192.168.20.3"  )

  new_ip=${dict_ip_b[$net_ip]}
  echo "This Machine new ip and old ip info:"
  echo "New addres ${new_ip} , old address: $net_ip"

  #开始修改网络配置文件,测试时sed 不要加i参数
  if [ -f /etc/sysconfig/network-scripts/ifcfg-${net_name}.bak ]; then
    cp -p /etc/sysconfig/network-scripts/ifcfg-${net_name} /etc/sysconfig/network-scripts/ifcfg-${net_name}.bak2
  else
    cp -p /etc/sysconfig/network-scripts/ifcfg-${net_name} /etc/sysconfig/network-scripts/ifcfg-${net_name}.bak
  fi

  if [ -f /etc/sysconfig/network-scripts/ifcfg-${net_name}.bak ] ||  [ -f /etc/sysconfig/network-scripts/ifcfg-${net_name}.bak2 ]; then
    sed -i "s/${net_ip}/${new_ip}/" /etc/sysconfig/network-scripts/ifcfg-${net_name}
    sed -i "s/GATEWAY\=192.168.111.2/GATEWAY\=192.168.20.2/" /etc/sysconfig/network-scripts/ifcfg-${net_name}
    if [ $? -eq 0 ];then
      echo "重启网络服务,并修改相关静态路由,测试状态下注释掉了"
      #systemctl restart network
    else
      echo "network config file edit failed,not restart network progroam."
    fi
  else
    echo "文件备份不存在,not change network config file........."
  fi

}

#申明主函数
main(){
  read -p 'Make sure you want to make network configuration changes。Please input YES(y) or NO(n):  ' answer
  if [ $answer == y ] || [ $answer == YES  ];then
    edit_yw_ip
  elif [ $answer == n ] || [ $answer == NO  ];then
    echo "input NO or n,program will exited..................."
    exit 1
  fi
}
#调用主函数
main

结果

执行前展示

执行命令展示

 结果文件

**************************************************************************************************************2021年2月2日脚本结束*****************************************************************************************************************

 

21年2月3日-获取远程主机磁盘信息

 ************************************************************************************************************************************************************************************************************************************

脚本说明

获取既定主机磁盘根分区使用情况。

文件说明

System_root_mount_check.sh:脚本主体程序文件

配置文件

[root@135 8_get_remote_df]# cat machine_list.txt 
192.168.111.11  root   yinwan
192.168.111.12  root   yinwan
192.168.111.124 root   yinwan

脚本主体

[root@135 8_get_remote_df]# cat Get_remote_mount.sh 
#!/bin/bash
generate_rsa(){
  #判断是否有密钥对文件没有的化自动生成密钥对。
  if [ ! -f /root/.ssh/id_rsa  ];then
    ssh-keygen -N "" -b 4096 -t rsa -C "`hostname`" -f /root/.ssh/id_rsa &>/dev/null
  else
    echo 'rsa config file exits !! ' >> /var/log/message
  fi
}

send_file_rsa(){
  #发送rsa到远程主机中,如果已经存在则可以忽略,不用执行该函数
  cat machine_list.txt | while read ipaddr  user  passwd
  do
    echo "exec send rsa file to $ipaddr  "  &>/dev/null
    timeout 2 sshpass -p $passwd /usr/bin/ssh-copy-id -i /root/.ssh/id_rsa $user@$ipaddr  &>/dev/null
  done
}


get_remote_df(){
  #远程执行命令把结果置入到临时文件中。
  echo "Ipadress" >> result_ip.txt
  echo "Filesystem           Size  Used Avail Use% Mounted" >> result.txt 
  for ipaddr in 192.168.111.11 192.168.111.12 192.168.111.124
  do
    echo "$ipaddr" >> result_ip.txt
    ssh -T $ipaddr df -hP | grep -i /$ >> result.txt
  done
  paste  result_ip.txt  result.txt | awk 'BEGIN { OFS="\t"} ;{ $1=$1 ; print $0} ' > result.xls
  echo -e "Remote Machine / Info:\n`cat result.xls`  "
}


clear_env(){
  #清除执行过后的环境文件
  rm -rf result_ip.txt
  rm -rf result.txt
}


#定义主函数
main(){
  > result_ip.txt
  > result.txt
  generate_rsa
  send_file_rsa
  get_remote_df
  clear_env
}


#调用主函数
main

结果

**************************************************************************************************************2021年2月3日脚本结束*****************************************************************************************************************

 

21年2月4日-批量修改ipmi用户脚本

 ************************************************************************************************************************************************************************************************************************************

脚本说明

通过用户之前规划的ipmi密码,写入到指定的配置文件中。脚本循环读取配置文件中的ipmi地址及用户信息等参数实现批量修改ipmi密码,用户密码修改后再测试是否能够使用新的密码连接ipmi口,如果可以连接则把能够连接的结果置入到文件中。

该脚本只作为参考,由于各厂商的产品迭代比较厉害使用脚本前还请先确认每个品牌和型号的用户id号,再根据具体情况加以修改脚本。

文件说明

machine_list.txt:物理主机ipmi表

Batch_edit_ipmi_user.sh:脚本主体程序文件

配置文件

[root@135 9_edit_ipmi_password]# cat machine_list.txt 
#ip_addr          manufacturer    user             old_pass          new_pass     
192.168.111.3     dell            root             calvin            calvin123456
192.168.111.4     inspur          admin            admin             admin123456
192.168.111.5     hw              root             Huawei_123        Huawei_12345
192.168.111.6     ibm             USERID           PASSW0RD          PASSW0RD12345 
192.168.111.7     hp              administrator    hp123456          hp123456789
192.168.111.8     hw              root             Huawei_123        Huawei_12345
192.168.111.9     ibm             USERID           PASSW0RD          PASSW0RD12345 
192.168.111.10    hw              administrator    hp123456          hp123456789

脚本主体

[root@135 9_edit_ipmi_password]# cat edit_ipmi_password.sh 
#!/bin/bash
edit_pass(){
cat machine_list.txt |while read ip_addr type  user old_pass  new_pass
do
  echo $ip_addr | grep '\#' &>/dev/null
  if [ $? -eq 0 ];then
    echo "注释掉了" 
    continue
  fi  
  echo "Ip Address Info: $ip_addr"
  case $type in
    'dell')
     echo "this type dell"
     ipmitool -H ${ip_addr}  -I lanplus -U ${user} -P ${old_pass} user set password  1 ${new_pass}
     ;;

    'hw')
     echo "this type hw"
     ipmitool -H ${ip_addr}  -I lanplus -U ${user} -P ${old_pass} user set password  2 ${new_pass}
     ;;

    'inspur')
     echo "this type inspur"
     ipmitool -H ${ip_addr}  -I lanplus -U ${user} -P ${old_pass} user set password  1 ${new_pass}
     ;;

    'ibm')
     echo "this type ibm"
     ipmitool -H ${ip_addr}  -I lanplus -U ${user} -P ${old_pass} user set password  2 ${new_pass}
     ;;

    'hp')
     echo "this type hp"
     ipmitool -H ${ip_addr}  -I lanplus -U ${user} -P ${old_pass} user set password  1 ${new_pass}
     ;;
     *)
     echo "Sorry this Model not supported for program."
     ;;
  esac
done
}

check_new_pass_status(){
  > result_eidt_pass.txt
  cat machine_list.txt |while read ip_addr type  user old_pass  new_pass
  do
    timeout 2 ipmitool -H ${ip_addr}  -I lanplus -U ${user} -P ${new_pass} user list
    if [ $? -eq 0 ];then
      echo "${ip_addr} edit ${user} password succeed"  >> result_eidt_pass.txt
    else
      echo "${ip_addr} edit ${user} password failed"   >> result_eidt_pass.txt
    fi
  done
}

result_file_info(){
  echo "######################ipmi地址修改结果统计######################"
  total_n=`cat result_eidt_pass.txt|wc -l`
  success_n=`cat result_eidt_pass.txt | grep  success$|wc -l`
  failed_n=`cat result_eidt_pass.txt | grep failed$|wc -l`
  echo -e "statistics:\n待修改主机数:${total_n}\n成功修改数:${success_n}\n失败修改数:${failed_n}"
  echo "######################ipmi地址修改结果统计结束######################"
}

mian(){
 edit_pass
 check_new_pass_status
 result_file_info
}


#IBM USERID账户id为 2
#ipmitool -H 192.168.111.1  -I lanplus -U root -P old_password user set password  2 new_password
#华为 root账户id为 2
#ipmitool -H 192.168.111.1  -I lanplus -U root -P old_password user set password  2 new_password
#浪潮 admin账户id为 1
#ipmitool -H 192.168.111.1  -I lanplus -U root -P old_password user set password  1 new_password
#dell root账户id为 1
#ipmitool -H 192.168.111.1  -I lanplus -U root -P old_password user set password  1 new_password
#hp   root账户id为 2     admin账户id为 1
#ipmitool -H 192.168.111.1  -I lanplus -U root -P old_password user set password  1 new_password
#查看用户id
#ipmitool -H 192.168.111.1  -I lanplus -U root -P password user list

**************************************************************************************************************2021年2月4日脚本结束*****************************************************************************************************************

 

21年2月5日-ping判断系统类型

 ************************************************************************************************************************************************************************************************************************************

脚本说明

脚本读取配置文件中的主机ip地址列表,使用ping命令截取返回ttl值根据已知的规则判断系统大致类型。

读者可以根据自己的了解在case中添加对应的行实现对更多系统的识别。

文件说明

machine.txt:配置文件

Dis_host_system.sh:脚本主体脚本

配置文件

[root@135 10_Dis_Host_Systems]# cat machine.txt 
192.168.111.1
192.168.111.2
192.168.111.11
192.168.111.12
192.168.111.135
192.168.111.200
192.168.300.12

脚本主体

[root@135 10_Dis_Host_Systems]# cat Dis_host_system.sh 
#!/bin/bash


Dis_host_system(){
  > tmp_result.txt
  for i in `cat machine.txt`
  do
    ttl_num=`timeout 1 ping -c 1 ${i} | grep 'ttl='  | awk -F'ttl=' '{print $2}'| awk  '{print $1}'`
    timeout 1 ping -c 1 ${i} &>/dev/null
    if [ $? -eq 0  ];then
      case ${ttl_num} in
        64)
         echo "This ${i} System os Linux" >> tmp_result.txt
         ;;
        128)
         echo "This ${i} System os Windows NT/2000/xp And later versions" >> tmp_result.txt
         ;;
        32)
         echo "This ${i} System os Windows 98" >> tmp_result.txt
         ;;
        255)
         echo "This ${i} System os UNIX/Linux" >> tmp_result.txt
         ;;
         *)
         echo "Sorry ${i} Unable to identify the operating system" >> tmp_result.txt
         ;;
      esac
    else
      echo "The ${i} address is unreachable or ICMP has been closed" >> tmp_result.txt
    fi
  done
}


statistics(){
  total_num=`cat tmp_result.txt|wc -l`
  Linux=`cat tmp_result.txt | grep Linux|wc -l`
  Win=`cat tmp_result.txt | grep Windows|wc -l`
  Unable=`cat tmp_result.txt | grep Unable|wc -l`
  not_ping=`cat tmp_result.txt | grep unreachable|wc -l`
  echo  -e "Statistics Info:\n  The total number of IP addresses to be detected: ${total_num}\n  Linux/Unix System num: ${Linux}\n  Win System num: ${Win}\n  Unable System num: ${Unable}" 
  echo "  Address unreachable or ICMP has been closed num: ${not_ping}"
  rm -rf tmp_result.txt
}

main(){
Dis_host_system
statistics
}

main

结果

**************************************************************************************************************2021年2月5日脚本结束*****************************************************************************************************************

posted @ 2021-02-01 15:08  飞翔的小胖猪  阅读(158)  评论(0编辑  收藏  举报