新聞中心
概述

創(chuàng)新互聯(lián)公司從2013年成立,公司以成都網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、系統(tǒng)開(kāi)發(fā)、網(wǎng)絡(luò)推廣、文化傳媒、企業(yè)宣傳、平面廣告設(shè)計(jì)等為主要業(yè)務(wù),適用行業(yè)近百種。服務(wù)企業(yè)客戶(hù)千余家,涉及國(guó)內(nèi)多個(gè)省份客戶(hù)。擁有多年網(wǎng)站建設(shè)開(kāi)發(fā)經(jīng)驗(yàn)。為企業(yè)提供專(zhuān)業(yè)的網(wǎng)站建設(shè)、創(chuàng)意設(shè)計(jì)、宣傳推廣等服務(wù)。 通過(guò)專(zhuān)業(yè)的設(shè)計(jì)、獨(dú)特的風(fēng)格,為不同客戶(hù)提供各種風(fēng)格的特色服務(wù)。
今天主要分享5個(gè)shell腳本實(shí)例,大家可以借鑒下里面的思路,看下有沒(méi)另外一種實(shí)現(xiàn)方式。
1、定時(shí)清空文件內(nèi)容,定時(shí)記錄文件大小
- #!/bin/bash
- ################################################################
- #每小時(shí)執(zhí)行一次腳本(任務(wù)計(jì)劃),當(dāng)時(shí)間為0點(diǎn)或12點(diǎn)時(shí),將目標(biāo)目錄下的所有文件內(nèi)
- #容清空,但不刪除文件,其他時(shí)間則只統(tǒng)計(jì)各個(gè)文件的打小,一個(gè)文件一行,輸出到以時(shí)#間和日期命名的文件中,需要考慮目標(biāo)目錄下二級(jí)、三級(jí)等子目錄的文件
- ################################################################
- logfile=/tmp/`date +%H-%F`.log
- n=`date +%H`
- if [ $n -eq 00 ] || [ $n -eq 12 ]
- then
- #通過(guò)for循環(huán),以find命令作為遍歷條件,將目標(biāo)目錄下的所有文件進(jìn)行遍歷并做相應(yīng)操作
- 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
2、計(jì)算文檔每行出現(xiàn)的數(shù)字個(gè)數(shù),并計(jì)算整個(gè)文檔的數(shù)字總數(shù)
- #!/bin/bash
- #########################################################
- #計(jì)算文檔每行出現(xiàn)的數(shù)字個(gè)數(shù),并計(jì)算整個(gè)文檔的數(shù)字總數(shù)
- ########################################################
- #使用awk只輸出文檔行數(shù)(截取第一段)
- n=`wc -l a.txt|awk '{print $1}'`
- sum=0
- #文檔中每一行可能存在空格,因此不能直接用文檔內(nèi)容進(jìn)行遍歷
- for i in `seq 1 $n`
- do
- #輸出的行用變量表示時(shí),需要用雙引號(hào)
- line=`sed -n "$i"p a.txt`
- #wc -L選項(xiàng),統(tǒng)計(jì)最長(zhǎng)行的長(zhǎng)度
- n_n=`echo $line|sed s'/[^0-9]//'g|wc -L`
- echo $n_n
- sum=$[$sum+$n_n]
- done
- echo "sum:$sum"
3、檢測(cè)兩臺(tái)服務(wù)器指定目錄下的文件一致性
- #!/bin/bash
- #####################################
- #檢測(cè)兩臺(tái)服務(wù)器指定目錄下的文件一致性
- #####################################
- #通過(guò)對(duì)比兩臺(tái)服務(wù)器上文件的md5值,達(dá)到檢測(cè)一致性的目的
- dir=/data/web
- b_ip=192.168.88.10
- #將指定目錄下的文件全部遍歷出來(lái)并作為md5sum命令的參數(shù),進(jìn)而得到所有文件的md5值,并寫(xiě)入到指定文件中
- 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
- #將文件名作為遍歷對(duì)象進(jìn)行一一比對(duì)
- for f in `awk '{print 2} /tmp/md5_a.txt'`
- do
- #以a機(jī)器為標(biāo)準(zhǔn),當(dāng)b機(jī)器不存在遍歷對(duì)象中的文件時(shí)直接輸出不存在的結(jié)果
- 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}'`
- #當(dāng)文件存在時(shí),如果md5值不一致則輸出文件改變的結(jié)果
- if [ $md5_a != $md5_b ]
- then
- echo "$f changed."
- fi
- else
- echo "$f deleted."
- fi
- done
4、檢測(cè)網(wǎng)卡流量,并按規(guī)定格式記錄在日志中
- #!/bin/bash
- #######################################################
- #檢測(cè)網(wǎng)卡流量,并按規(guī)定格式記錄在日志中
- #規(guī)定一分鐘記錄一次
- #日志格式如下所示:
- #2019-08-12 20:40
- #ens33 input: 1234bps
- #ens33 output: 1235bps
- ######################################################3
- while :
- do
- #設(shè)置語(yǔ)言為英文,保障輸出結(jié)果是英文,否則會(huì)出現(xiàn)bug
- LANG=en
- logfile=/tmp/`date +%d`.log
- #將下面執(zhí)行的命令結(jié)果輸出重定向到logfile日志中
- exec >> $logfile
- date +"%F %H:%M"
- #sar命令統(tǒng)計(jì)的流量單位為kb/s,日志格式為bps,因此要*1000*8
- sar -n DEV 1 59|grep Average|grep ens33|awk '{print $2,"\t","input:","\t",$5*1000*8,"bps","\n",$2,"\t","output:","\t",$6*1000*8,"bps"}'
- echo "####################"
- #因?yàn)閳?zhí)行sar命令需要59秒,因此不需要sleep
- done
輸出結(jié)果:
5、殺死所有腳本
- #!/bin/bash
- ################################################################
- #有一些腳本加入到了cron之中,存在腳本尚未運(yùn)行完畢又有新任務(wù)需要執(zhí)行的情況,
- #導(dǎo)致系統(tǒng)負(fù)載升高,因此可通過(guò)編寫(xiě)腳本,篩選出影響負(fù)載的進(jìn)程一次性全部殺死。
- ################################################################
- ps aux|grep 指定進(jìn)程名|grep -v grep|awk '{print $2}'|xargs kill -9
分享名稱(chēng):超詳細(xì)的5個(gè)Shell腳本實(shí)例分享,值得收藏
鏈接地址:http://m.fisionsoft.com.cn/article/cohhogp.html


咨詢(xún)
建站咨詢(xún)
