分享几个常用的运维 shell 脚本

Posted edisonfish

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了分享几个常用的运维 shell 脚本相关的知识,希望对你有一定的参考价值。

今天咸鱼给大家分享几个不错的 Linux 运维脚本,这些脚本中大量使用了 Linux 的文本三剑客:

1. awk

2. grep

3. sed

 

建议大家这三个工具都要了解并最好能够较为熟练的使用

 

根据 PID 显示进程所有信息

 

 根据用户输入的 PID,过滤出该 PID 所有的信息

 

 

 

 

#! /bin/bash

read -p "请输入要查询的PID: " P

n=`ps -aux| awk \'$2~/^\'$P\'$/print $0\'|wc -l`

if [ $n -eq 0 ];then
 echo "该PID不存在!!"
 exit
fi
echo -e "\\e[32m--------------------------------\\e[0m"
echo "进程PID: $P"
echo "进程命令:$(ps -aux| awk \'$2~/^\'$P\'$/for (i=11;i<=NF;i++) printf("%s ",$i)\')"
echo "进程所属用户: $(ps -aux| awk \'$2~/^\'$P\'$/print $1\')"
echo "CPU占用率:$(ps -aux| awk \'$2~/^\'$P\'$/print $3\')%"
echo "内存占用率:$(ps -aux| awk \'$2~/^\'$P\'$/print $4\')%"
echo "进程开始运行的时间:$(ps -aux| awk \'$2~/^\'$P\'$/print $9\')"
echo "进程运行的时间:$(ps -aux| awk \'$2~/^\'$P\'$/print $10\')"
echo "进程状态:$(ps -aux| awk \'$2~/^\'$P\'$/print $8\')"
echo "进程虚拟内存:$(ps -aux| awk \'$2~/^\'$P\'$/print $5\')"
echo "进程共享内存:$(ps -aux| awk \'$2~/^\'$P\'$/print $6\')"
echo -e "\\e[32m--------------------------------\\e[0m"

 

 

 

 

根据进程名显示该进程所有信息

 

根据输入的程序的名字模糊过滤出所对应的 PID,并显示出详细信息,如果有多个PID,则全部显示

 

 

 

 

#! /bin/bash

read -p "请输入要查询的进程名:" NAME

N=`ps -aux | grep $NAME | grep -v grep | wc -l` ##统计进程总数

if [ $N -le 0 ];then
  echo "该进程名没有运行!"
fi
i=1
while [ $N -gt 0 ]
do
  echo -e "\\e[32m***************************************************************\\e[0m"
  echo "进程PID: $(ps -aux | grep $NAME | grep -v grep | awk \'NR==\'$i\'print $0\'| awk \'print $2\')"
  echo "进程命令:$(ps -aux | grep $NAME | grep -v grep | awk \'NR==\'$i\'print $0\'| awk \'for (j=11;j<=NF;j++) printf("%s ",$j)\')"
  echo "进程所属用户: $(ps -aux | grep $NAME | grep -v grep | awk \'NR==\'$i\'print $0\'| awk \'print $1\')"
  echo "CPU占用率:$(ps -aux | grep $NAME | grep -v grep | awk \'NR==\'$i\'print $0\'| awk \'print $3\')%"
  echo "内存占用率:$(ps -aux | grep $NAME | grep -v grep | awk \'NR==\'$i\'print $0\'| awk \'print $4\')%"
  echo "进程开始运行的时间:$(ps -aux | grep $NAME | grep -v grep | awk \'NR==\'$i\'print $0\'| awk \'print $9\')"
  echo "进程运行的时间:$(ps -aux | grep $NAME | grep -v grep | awk \'NR==\'$i\'print $0\'| awk \'print $10\')"
  echo "进程状态:$(ps -aux | grep $NAME | grep -v grep | awk \'NR==\'$i\'print $0\'| awk \'print $8\')"
  echo "进程虚拟内存:$(ps -aux | grep $NAME | grep -v grep | awk \'NR==\'$i\'print $0\'| awk \'print $5\')"
  echo "进程共享内存:$(ps -aux | grep $NAME | grep -v grep | awk \'NR==\'$i\'print $0\'| awk \'print $6\')"
  echo -e "\\e[32m***************************************************************\\e[0m"
  let N-- i++
done

 

 

 

 

根据用户名查看该用户的相关信息

 

 

 

#! /bin/bash

read -p "请输入要查询的用户名:" name

echo "------------------------------"

n=`cat /etc/passwd | awk -F: \'$1~/^\'$name\'$/print\' | wc -l`

if [ $n -eq 0 ];then
echo -e "\\e[31m该用户不存在!\\e[0m"
echo "------------------------------"
else
  echo "该用户的用户名:$name"
  echo "该用户的UID:$(cat /etc/passwd | awk -F: \'$1~/^\'$name\'$/print\'|awk -F: \'print $3\')"
  echo "该用户的组为:$(id $name | awk \'print $3\')"
  echo "该用户的GID为:$(cat /etc/passwd | awk -F: \'$1~/^\'$name\'$/print\'|awk -F: \'print $4\')"
  echo "该用户的家目录为:$(cat /etc/passwd | awk -F: \'$1~/^\'$name\'$/print\'|awk -F: \'print $6\')"
  Login=$(cat /etc/passwd | awk -F: \'$1~/^\'$name\'$/print\'|awk -F: \'print $7\')
  if [ $Login == "/bin/bash" ];then
  echo -e "\\e[32m该用户有登录系统的权限\\e[0m"
  echo "------------------------------"
  elif [ $Login == "/sbin/nologin" ];then
  echo -e "\\e[31m该用户没有登录系统的权限!\\e[0m"
  echo "------------------------------"
  fi
fi

 

查看 tcp 的连接状态

 

 

 

#! /bin/bash

#统计不同状态 tcp 连接(除了 LISTEN )
all_status_tcp=$(netstat -nt | awk \'NR>2 print $6\' | sort | uniq -c)

#打印各状态 tcp 连接以及连接数
all_tcp=$(netstat -na | awk \'/^tcp/ ++S[$NF];END for(a in S) print a, S[a]\')


#统计有哪些 IP 地址连接到了本地 80 端口(ipv4)
connect_80_ip=$(netstat -ant| grep -v \'tcp6\' | awk \'/:80/split($5,ip,":");++S[ip[1]]ENDfor (a in S) print S[a],a\' |sort -n)


#输出前十个连接到了本地 80 端口的 IP 地址(ipv4)
top10_connect_80_ip=$(netstat -ant| grep -v \'tcp6\' | awk \'/:80/split($5,ip,":");++S[ip[1]]ENDfor (a in S) print S[a],a\' |sort -rn|head -n 10)


echo -e "\\e[31m不同状态(除了LISTEN) tcp 连接及连接数为:\\e[0m\\n$all_status_tcp"
echo -e "\\e[31m各个状态 tcp 连接以及连接数为:\\e[0m\\n$all_tcp"
echo -e "\\e[31m连接到本地80端口的 IP 地址及连接数为:\\e[0m\\n$connect_80_ip"
echo -e "\\e[31m前十个连接到本地80端口的 IP 地址及连接数为:\\e[0m\\n$top10_connect_80_ip"

 

PS:下面例子里我检测的是 22 端口

 

 

显示系统性能

 

 

 

 

#!/bin/bash

#物理内存使用量
mem_used=$(free -m | grep Mem | awk \'print$3\')

#物理内存总量
mem_total=$(free -m | grep Mem | awk \'print$2\')

#cpu核数
cpu_num=$(lscpu  | grep \'CPU(s)\' | awk \'NR==1 print$2\')

#平均负载
load_average=$(uptime  | awk -F : \'print$5\')

#用户态的CPU使用率
cpu_us=$(top -d 1 -n 1 | grep Cpu | awk -F\',\' \'print $1\' | awk \'print $(NF-1)\')

#内核态的CPU使用率
cpu_sys=$(top -d 1 -n 1 | grep Cpu | awk -F\',\' \'print $2\' | awk \'print $(NF-1)\')

#等待I/O的CPU使用率
cpu_wa=$(top -d 1 -n 1 | grep Cpu | awk -F\',\' \'print $5\' | awk \'print $(NF-1)\')

#处理硬中断的CPU使用率
cpu_hi=$(top -d 1 -n 1 | grep Cpu | awk -F\',\' \'print $6\' | awk \'print $(NF-1)\')

#处理软中断的CPU使用率
cpu_si=$(top -d 1 -n 1 | grep Cpu | awk -F\',\' \'print $7\'| awk \'print $(NF-1)\')

echo -e "物理内存使用量(M)为:$mem_used"
echo -e "物理内存总量(M)为:$mem_total"
echo -e "cpu核数为:$cpu_num"
echo -e "平均负载为:$load_average"
echo -e "用户态的CPU使用率为:$cpu_us"
echo -e "内核态的CPU使用率为:$cpu_sys"
echo -e "等待I/O的CPU使用率为:$cpu_wa"
echo -e "处理硬中断的CPU使用率为:$cpu_hi"
echo -e "处理软中断的CPU使用率为:$cpu_si"

 

 

 

文件不安全的权限检查

 

 

 

#查找系统中任何用户都有写权限的文件(目录),并存放到/tmp/anynone_write.txt
find / -type f -perm -2 -o -perm -20 -exec echo  >> /tmp/anynone_write.txt   \\;

#查找系统中所有含 \'s\' 位权限的程序,并存放到/tmp/s_permission.txt
find / -type f -perm -4000 -o -perm -2000 -print -exec echo  >> /tmp/s_permission.txt  \\;

#查找系统中没有属主以及属组的文件,并存放到/tmp/none.txt
find / -nouser -o -nogroup -exec echo  >> /tmp/none.txt  \\;

 

 


感谢阅读,喜欢作者就动动小手[一键三连],这是我写作最大的动力

 

以上是关于分享几个常用的运维 shell 脚本的主要内容,如果未能解决你的问题,请参考以下文章

Linux常用Shell脚本

Linux常用shell脚本

Linux常用Shell脚本,值得学习及收藏

数据库的运维策略脚本篇(内附脚本,无私分享)

学习不迷茫:Ansible要如何学至精通

免费领 | 《Shell脚本 100例》电子书免费拿,运维必备干货~