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日脚本结束*****************************************************************************************************************
60天shell脚本计划-2/12-渐入佳境的更多相关文章
- 60天shell脚本计划-12/12-渐入佳境
--作者:飞翔的小胖猪 --创建时间:2021年3月23日 --修改时间:2021年3月27日 说明 每日上传更新一个shell脚本,周期为60天.如有需求的读者可根据自己实际情况选用合适的脚本,也可 ...
- 60天shell脚本计划-8/12-渐入佳境
--作者:飞翔的小胖猪 --创建时间:2021年3月3日 --修改时间:2021年3月7日 说明 每日上传更新一个shell脚本,周期为60天.如有需求的读者可根据自己实际情况选用合适的脚本,也可在评 ...
- 60天shell脚本计划-11/12-渐入佳境
--作者:飞翔的小胖猪 --创建时间:2021年3月18日 --修改时间:2021年3月22日 说明 每日上传更新一个shell脚本,周期为60天.如有需求的读者可根据自己实际情况选用合适的脚本,也可 ...
- 60天shell脚本计划-10/12-渐入佳境
--作者:飞翔的小胖猪 --创建时间:2021年3月13日 --修改时间:2021年3月17日 说明 每日上传更新一个shell脚本,周期为60天.如有需求的读者可根据自己实际情况选用合适的脚本,也可 ...
- 60天shell脚本计划-9/12-渐入佳境
--作者:飞翔的小胖猪 --创建时间:2021年3月8日 --修改时间:2021年3月12日 说明 每日上传更新一个shell脚本,周期为60天.如有需求的读者可根据自己实际情况选用合适的脚本,也可在 ...
- 60天shell脚本计划-7/12-渐入佳境
--作者:飞翔的小胖猪 --创建时间:2021年2月26日 --修改时间:2021年3月2日 说明 每日上传更新一个shell脚本,周期为60天.如有需求的读者可根据自己实际情况选用合适的脚本,也可在 ...
- 60天shell脚本计划-6/12-渐入佳境
--作者:飞翔的小胖猪 --创建时间:2021年2月21日 --修改时间:2021年2月25日 说明 每日上传更新一个shell脚本,周期为60天.如有需求的读者可根据自己实际情况选用合适的脚本,也可 ...
- 60天shell脚本计划-5/12-渐入佳境
--作者:飞翔的小胖猪 --创建时间:2021年2月16日 --修改时间:2021年2月20日 说明 每日上传更新一个shell脚本,周期为60天.如有需求的读者可根据自己实际情况选用合适的脚本,也可 ...
- 60天shell脚本计划-4/12-渐入佳境
--作者:飞翔的小胖猪 --创建时间:2021年2月11日 --修改时间:2021年2月15日 说明 每日上传更新一个shell脚本,周期为60天.如有需求的读者可根据自己实际情况选用合适的脚本,也可 ...
- 60天shell脚本计划-3/12-渐入佳境
--作者:飞翔的小胖猪 --创建时间:2021年2月6日 --修改时间:2021年2月10日 说明 每日上传更新一个shell脚本,周期为60天.如有需求的读者可根据自己实际情况选用合适的脚本,也可在 ...
随机推荐
- 经典面试题:分布式缓存热点KEY问题如何解决--有赞方案
有赞透明多级缓存解决方案(TMC) 一.引子 1-1. TMC 是什么 TMC ,即"透明多级缓存( Transparent Multilevel Cache )",是有赞 Paa ...
- Java方法内联
一.概念 方法内联就是把调用方函数代码"复制"到调用方函数中,减少因函数调用开销的技术 函数调用过程 1.首先会有个执行栈,存储它们的局部变量.方法名.动态连接 2.当一个方法 ...
- java 多线程 start方法 run方法 简单介绍。
一 start开启一个多线程, run 只是一个内部的方法. package com.aaa.threaddemo; /* * start方法的作用? * 在 Java中启动多线程调用的是start方 ...
- APschedule定时任务
APScheduler是Python的一个定时任务框架,可以很方便的满足用户定时执行或者周期执行任务的需求, 它提供了基于日期date.固定时间间隔interval .以及类似于Linux上的定时任务 ...
- mybatis 原生写法创建项目
一.创建全局文件 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuratio ...
- Nacos服务注册与发现的2种实现方法!
Spring Cloud Alibaba 技术体系中的 Nacos,提供了两个重要的功能:注册中心(服务注册与发现)功能和配置中心功能. 其中注册中心解决了微服务调用中,服务提供者和服务调用者的解耦, ...
- 入门- k8s发布应用服务 (五)
目标 了解 Kubernetes 的 Service(服务) 了解 Labels(标签)和 LabelSelector(标签选择器)与 Service(服务)的关系 在 kubernetes 集群中, ...
- idea的jar文件,“java.lang.SecurityException: Invalid signature file digest for Manifest main attribute
感谢大佬:https://blog.csdn.net/mingyuli/article/details/84674483 命令行运行jar出现问题: 1.找不到主类.打开jar文件包,在MANIFES ...
- PMD的使用学习
是什么? 静态代码分析器 能找出什么问题? 可能的 bugs - 空的 try/catch/finally/switch 声明 死码 - 未使用的本地变量,参数和私有方法 次优代码 - 无用的 Str ...
- Ansible 自动化运维管理工具
Ansible 自动化运维管理工具 1.Ansible概述 2.Ansible部署 3.Ansible模块 1.Ansible概述: Ansible是一个基于Python开发的配置管理和应用部署工具, ...