工作中实用的Shell脚本实例

转自工作中实用的Shell脚本实例 - 简书

1. 内存监控脚本

#!/bin/bash#memory usemem_war_file=/tmp/mem_war.txtmem_use=`free -m | grep Mem | awk '{print $3}'`mem_total=`free -m | grep Mem | awk '{print $2}'`mem_percent=$((mem_use*100/mem_total))# echo "$mem_percent"%if (($mem_percent > 80));then  echo "`date +%F-%H-%M` mem: ${mem_percent}%" >$mem_war_file  echo "`date +%F-%H-%M` mem: ${mem_percent}%" | mail -s "mem warning" root fi

2. 检测网卡流量,并按规定格式记录在日志中

#!/bin/bash########################################################检测网卡流量,并按规定格式记录在日志中#规定一分钟记录一次#日志格式如下所示:#2021-07-08 18:55#eth0 input: 1234bps#eth0 output: 1235bps######################################################3while :do#设置语言为英文,保障输出结果是英文,否则会出现bugLANG=enlogfile=/tmp/`date +%d`.log#将下面执行的命令结果输出重定向到logfile日志中exec >> $logfiledate +"%F %H:%M"#sar命令统计的流量单位为kb/s,日志格式为bps,因此要*1000*8sar -n DEV 1 59|grep Average|grep eth0|awk '{print $2,"\t","input:","\t",$5*1000*8,"bps","\n",$2,"\t","output:","\t",$6*1000*8,"bps"}'echo "####################"#因为执行sar命令需要59秒,因此不需要sleepdone

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

假设服务器为lnmp环境,近期访问经常出现502现象,且502错误在重启php-fpm服务后消失,因此编写监控脚本,一旦出现502,则自动重启php-fpm服务。

#场景:#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.logN=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 10done

4. 扫描主机端口状态

#!/bin/bashHOST=$1PORT="22 80 8080 3306"for PORT in $PORT; do    if echo &>/dev/null > /dev/tcp/$HOST/$PORT; then        echo "$PORT open"    else        echo "$PORT close"    fidone

5. 检测两台服务器某个目录下的文件一致性

#!/bin/bash######################################检测两台服务器指定目录下的文件一致性######################################通过对比两台服务器上文件的md5值,达到检测一致性的目的dir=/data/webb_ip=192.168.88.10#将指定目录下的文件全部遍历出来并作为md5sum命令的参数,进而得到所有文件的md5值,并写入到指定文件中find $dir -type f|xargs md5sum > /tmp/md5_a.txtssh $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.txtthenmd5_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 ]thenecho "$f changed."fielseecho "$f deleted."fidone

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

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

7. 查看局域网内主机是否存活

#!/usr/bin/bash# check host statusfor i in {1..254}do        {    ip=192.168.8.$i    ping -c 2 -W 1 $ip &>/dev/null    if [ $? -eq 0 ];then        echo "$ip is online" | tee -a /tmp/host_online.txt    else      # echo "$ip is offline" | tee -a /tmp/host_offline.txt      echo "$ip is offline" &>/dev/null    fi        }&donewait

8. 自动应答分发免密登录

#!/usr/bin/bash# ssh keygen>ip_ok.txt>ip_false.txtuser=rootpasswd=123456rpm -qa | grep expect &>/dev/nullif [ $? -ne 0 ];then  echo "expect is not install"  yum -y install expectfiif [ ! -f ~/.ssh/id_rsa ];then  ssh-keygen -P "" -f ~/.ssh/id_rsafifor i in {15..30}do  {  ip=192.168.1."$i"  ping -c 1 -W1 "$ip"  if [ $? -eq 0 ];then    echo "$ip" >> ip_ok.txt    /usr/bin/expect <<-EOF    spawn ssh-copy-id $user@$ip    expect {        "yes/no" { send "yes\r"; exp_continue }        "password:" { send "$passwd\r" };    }    expect eof        EOF  else    echo "$ip" >>ip_false.txt  fi  }&donewaitecho "finish"

9. 代码上线脚本

#!/bin/bash# code online# author: renPROJT_DIR=/usr/local/nginx/htmlOLD_DIR=/usr/local/nginx/html/web1PROJT=web1BACKUP_DIR=/data/backupDATA_CHMOD=wwwDATE=`date +%F`NEW_DIR=/data/web1# 关闭nginxfunction stop_nginx() {  /usr/bin/systemctl stop nginx  if [ $? -eq 0 ];then    echo "nginx is stopd"  else    echo "nginx is not stop please check..."    exit 1  fi}#2 备份原有数据function backup_data() {  if [ -d $BACKUP_DIR/$DATE'-'$PROJT ];then    echo "DIR $BACKUP_DIR/$DATE'-'$PROJT is exist"    exit 2  else    mv $OLD_DIR $BACKUP_DIR/$DATE'-'$PROJT  fi}# 3移动新的代码 项目目录  注:此代码目录需手动上传解压 function new_code() {  if [ -d $NEW_DIR ];then    mv $NEW_DIR $PROJT_DIR  else    echo "NEW_DIR is not exist"    exit 3  fi}# 4 修改权限function chmod_news() {  chown -R $DATA_CHMOD.$DATA_CHMOD $OLD_DIR}# 5 启动服务function start_nginx() {  /usr/bin/systemctl start nginx  if [ $? -eq 0 ];then    echo "nginx start ok"  else    echo "ngin is not start,please check..."  fi}stop_nginxbackup_datanew_codechmod_newsstart_nginx

10. 检测MySQL主从复制是否异常

#!/bin/bashuser="root"password="123456"mycmd="mysql -u$user -p$password -h 192.168.1.88"function chkdb() {list=($($mycmd -e "show slave status \G"|egrep "Running|Behind"|awk -F: '{print $2}'))if [ ${list[0]} = "Yes" -a ${list[1]} = "Yes" -a ${list[2]} -lt 120 ]then echo "Mysql slave is ok"else echo "Mysql slave replation is filed"fi}function main() {while truedo chkdb  sleep 3done}main

11. MySQL数据库备份脚本(mysqldump)

#!/bin/bash

#删除15天以前备份

source /etc/profile          #加载系统环境变量

source ~/.bash_profile    #加载用户环境变量

set -o nounset            #引用未初始化变量时退出

#set -o errexit            #执行shell命令遇到错误时退出

user="root"

password="123456"

host="localhost"

port="3306"

#需备份的数据库,数组

db=("test")

#备份时加锁方式,

#MyISAM为锁表--lock-all-tables,

#InnoDB为锁行--single-transaction

lock="--single-transaction"

mysql_path="/usr/local/mysql"

backup_path="${mysql_path}/backup"

date=$(date +%Y-%m-%d_%H-%M-%S)

day=15

backup_log="${mysql_path}/backup.log"

#建立备份目录

if [ ! -e $backup_path ];then

    mkdir -p $backup_path

fi

#删除以前备份

find $backup_path -type f -mtime +$day -exec rm -rf {} \; > /dev/null 2>&1

echo "开始备份数据库:${db[*]}"

#备份并压缩

backup_sql(){

    dbname=$1

    backup_name="${dbname}_${date}.sql"

    #-R备份存储过程,函数,触发器

    mysqldump -h $host -P $port -u $user -p$password $lock --default-character-set=utf8 --flush-logs -R $dbname > $backup_path/$backup_name   

    if [[ $? == 0 ]];then

        cd $backup_path

        tar zcpvf $backup_name.tar.gz $backup_name

        size=$(du $backup_name.tar.gz -sh | awk '{print $1}')

        rm -rf $backup_name

        echo "$date 备份 $dbname($size) 成功 "

    else

        cd $backup_path

        rm -rf $backup_name

        echo "$date 备份 $dbname 失败 "

    fi

}

#循环备份

length=${#db[@]}

for (( i = 0; i < $length; i++ )); do

        backup_sql ${db[$i]} >> $backup_log 2>&1

done

echo "备份结束,结果查看 $backup_log"

du $backup_path/*$date* -sh | awk '{print "文件:" $2 ",大小:" $1}'

作者:一个小运维

链接:https://www.jianshu.com/p/093d712c777d

来源:简书

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容