linux常用脚本示例

linux常用脚本示例

Posted by Azukin on July 20, 2023

检测两台服务器指定目录下的文件一致性

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
#!/bin/bash  
######################################  
检测两台服务器指定目录下的文件一致性  
#####################################  
#通过对比两台服务器上文件的md5值,达到检测一致性的目的  
dir=/data/web  
b_ip=192.168.88.10  
#将指定目录下的文件全部遍历出来并作为md5sum命令的参数,进而得到所有文件的md5值,并写入到指定文件中  
find $dir -type f|xargs md5sum > /tmp/md5_a.txt  
ssh $b_ip "find $dir -type f|xargs md5sum > /tmp/md5_b.txt"  
scp $b_ip:/tmp/md5_b.txt /tmp  
#将文件名作为遍历对象进行一一比对  
for f in `awk '{print 2} /tmp/md5_a.txt'`do  
#以a机器为标准,当b机器不存在遍历对象中的文件时直接输出不存在的结果  
if grep -qw "$f" /tmp/md5_b.txt  
then  
md5_a=`grep -w "$f" /tmp/md5_a.txt|awk '{print 1}'`  
md5_b=`grep -w "$f" /tmp/md5_b.txt|awk '{print 1}'`  
#当文件存在时,如果md5值不一致则输出文件改变的结果  
if [ $md5_a != $md5_b ]then  
echo "$f changed."  
fi  
else  
echo "$f deleted."  
fi  
done  

定时清空文件内容,定时记录文件大小

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#!/bin/bash  
#################################################################  
每小时执行一次脚本(任务计划),当时间为0点或12点时,将目标目录下的所有文件内#容清空,但不删除文件,其他时间则只统计各个文件的大小,一个文件一行,输出到以时#间和日期命名的文件中,需要考虑目标目录下二级、三级等子目录的文件  
################################################################  
logfile=/tmp/`date +%H-%F`.log  
n=`date +%H`  
if [ $n -eq 00 ] || [ $n -eq 12 ]  
then  
#通过for循环,以find命令作为遍历条件,将目标目录下的所有文件进行遍历并做相应操作  
for i in `find /data/log/ -type f`  
do  
true > $i  
done  
else  
for i in `find /data/log/ -type f`  
do  
du -sh $i >> $logfile  
done  
fi 

从 FTP 服务器下载文件

1
2
3
4
5
6
7
8
9
10
11
12
13
#!/bin/bash  
if [ $# -ne 1 ]; then  
    echo "Usage: $0 filename"  
fi  
dir=$(dirname $1)  
file=$(basename $1)  
ftp -n -v << EOF   # -n 自动登录  
open 192.168.1.10  # ftp服务器  
user admin password  
binary   # 设置ftp传输模式为二进制,避免MD5值不同或.tar.gz压缩包格式错误  
cd $dir  
get "$file"  
EOF  

监测 Nginx 访问日志 502 情况,并做相应动作

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#场景:  
#1.访问日志文件的路径:/data/log/access.log  
#2.脚本死循环,每10秒检测一次,10秒的日志条数为300条,出现502的比例不低于10%(30条)则需要重启php-fpm服务  
#3.重启命令为:/etc/init.d/php-fpm restart  
#!/bin/bash  
###########################################################  
#监测Nginx访问日志502情况,并做相应动作  
###########################################################  
log=/data/log/access.log  
N=30 #设定阈值  
while :do  
 #查看访问日志的最新300条,并统计502的次数  
    err=`tail -n 300 $log |grep -c '502" '`   
if [ $err -ge $N ]   
then  
/etc/init.d/php-fpm restart 2> /dev/null   
#设定60s延迟防止脚本bug导致无限重启php-fpm服务  
     sleep 60  
 fi  
 sleep 10  
 done  

将位置参数192.168.1.1{1,2}拆分为到每个变量

1
2
3
4
5
6
7
8
9
10
11
12
13
num=0  
for i in $(eval echo $*);do   #eval将{1,2}分解为1 2  
   let num+=1  
   eval node${num}="$i"  
done  
echo $node1 $node2 $node3  
# bash a.sh 192.168.1.1{1,2}  
192.168.1.11 192.168.1.12  
  
方法3:arr=(4 5 6)  
INDEX1=$(echo ${arr[0]})  
INDEX2=$(echo ${arr[1]})  
INDEX3=$(echo ${arr[2]})

扫描主机端口状态

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
#!/bin/bash  
HOST=$1  
PORT="22 25 80 8080"  
for PORT in $PORT; do  
    if echo &>/dev/null > /dev/tcp/$HOST/$PORT; then  
        echo "$PORT open"  
    else  
        echo "$PORT close"  
    fi  
done  
用 shell 打印示例语句中字母数小于6的单词  
  
#示例语句:  
#Bash also interprets a number of multi-character options.  
#!/bin/bash  
##############################################################  
#shell打印示例语句中字母数小于6的单词  
##############################################################  
for s in Bash also interprets a number of multi-character options.  
do  
 n=`echo $s|wc -c`   
 if [ $n -lt 6 ]   
 then  
 echo $s  
 fi  
done  

输入数字运行相应命令

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#!/bin/bash  
##############################################################  
#输入数字运行相应命令  
##############################################################  
echo "*cmd menu* 1-date 2-ls 3-who 4-pwd 0-exit "  
while :  
do  
#捕获用户键入值  
 read -p "please input number :" n  
 n1=`echo $n|sed s'/[0-9]//'g`  
#空输入检测   
 if [ -z "$n" ]  
 then  
 continue  
 fi  
#非数字输入检测   
 if [ -n "$n1" ]  
 then  
 exit 0  
 fi  
 break  
done  
case $n in  
 1)  
 date  
 ;;  
 2)  
 ls  
 ;;  
 3)  
 who  
 ;;  
 4)  
 pwd  
 ;;  
 0)  
 break  
 ;;  
    #输入数字非1-4的提示  
 *)  
 echo "please input number is [1-4]"  
esac  

Expect 实现 SSH 免交互执行命令

Expect是一个自动交互式应用程序的工具,如telnet,ftp,passwd等。 需先安装expect软件包。

1
2
3
4
5
6
7
8
9
10
11
#!/bin/bash  
USER=root  
PASS=123.com  
IP=192.168.1.120  
expect -c "  
    spawn ssh $USER@$IP  
    expect {  
        \"(yes/no)\" {send \"yes\r\"; exp_continue}  
        \"password:\" {send \"$PASS\r\"; exp_continue}  
        \"$USER@*\" {send \"df -h\r exit\r\"; exp_continue}  
    }"  
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
// wbl buy
var n = 0
// var buy3 = function () {
//     // 获取 geetest_square_mark 元素
//     var geetestSquareMarks = document.querySelectorAll('.geetest_square_mark');
//     // 检查 geetest_square_mark 元素的数量是否等于三个
//     if (geetestSquareMarks.length === 3) {
//         // 获取 geetest_submit 元素
//         var geetestSubmit = document.querySelector('.geetest_submit');

//         // 模拟点击 geetest_submit 元素
//         if (geetestSubmit) {
//             geetestSubmit.click();
//         } else {
//             console.log("找不到 geetest_submit 元素");
//         }
//     } else {
//         setTimeout('buy3()', 0)
//     }

//     var tcMarks = document.querySelectorAll('.tc-click-mark');
//     if (tcMarks.length === 3) {
//         var tcSubmit = document.querySelector('.tc-action .verify-btn');

//         if (tcSubmit) {
//             tcSubmit.click();
//         } else {
//             console.log("找不到 tcSubmit 元素");
//         }
//     } else {
//         setTimeout('buy3()', 0)
//     }

// }

var buy2 = function () {
    if (document.getElementsByClassName('app-web-components-button-index-m__button--5EITv app-web-components-modal-kit-components-styles-components-m__modalButton--2dlLP app-web-components-modal-kit-components-styles-components-m__okType--tjylq')[0] != undefined) {
        document.getElementsByClassName('app-web-components-button-index-m__button--5EITv app-web-components-modal-kit-components-styles-components-m__modalButton--2dlLP app-web-components-modal-kit-components-styles-components-m__okType--tjylq')[0].click();
        buy3();
    } else {
        setTimeout('buy2()', 0)
    }
}

var buy = function () {
    n = n + 1
    if (document.getElementsByClassName('app-web-components-button-index-m__button--5EITv app-web-components-modal-components-role-detail-styles-price-m__button--IKLC-')[0] != undefined) {
        document.getElementsByClassName('app-web-components-button-index-m__button--5EITv app-web-components-modal-components-role-detail-styles-price-m__button--IKLC-')[0].click();
        buy2();
    } else {
        console.log(n)
        if (n < 6000) setTimeout('buy()', 0)
    }
}