亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

工作中如何使用Shell實用腳本

發布時間:2021-07-27 13:40:35 來源:億速云 閱讀:152 作者:小新 欄目:開發技術

這篇文章主要介紹工作中如何使用Shell實用腳本,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

1. 內存監控腳本

#!/bin/bash
#memory use
mem_war_file=/tmp/mem_war.txt
mem_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
######################################################3
while :
do
#設置語言為英文,保障輸出結果是英文,否則會出現bug
LANG=en
logfile=/tmp/`date +%d`.log
#將下面執行的命令結果輸出重定向到logfile日志中
exec >> $logfile
date +"%F %H:%M"
#sar命令統計的流量單位為kb/s,日志格式為bps,因此要*1000*8
sar -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秒,因此不需要sleep
done

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.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

4. 掃描主機端口狀態

#!/bin/bash
HOST=$1
PORT="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"
    fi
done

5. 檢測兩臺服務器某個目錄下的文件一致性

#!/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

6. 定時清空文件內容,定時記錄文件大小

#!/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

7. 查看局域網內主機是否存活

#!/usr/bin/bash
# check host status
for 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
        }&
done
wait

8. 自動應答分發免密登錄

#!/usr/bin/bash
# ssh keygen

>ip_ok.txt
>ip_false.txt
user=root
passwd=123456

rpm -qa | grep expect &>/dev/null
if [ $? -ne 0 ];then
  echo "expect is not install"
  yum -y install expect
fi

if [ ! -f ~/.ssh/id_rsa ];then
  ssh-keygen -P "" -f ~/.ssh/id_rsa
fi

for 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
  }&
done
wait
echo "finish"

9. 代碼上線腳本

#!/bin/bash
# code online
# author: ren
PROJT_DIR=/usr/local/nginx/html
OLD_DIR=/usr/local/nginx/html/web1
PROJT=web1
BACKUP_DIR=/data/backup
DATA_CHMOD=www
DATE=`date +%F`
NEW_DIR=/data/web1
# 關閉nginx
function 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_nginx
backup_data
new_code
chmod_news
start_nginx

10. 檢測MySQL主從復制是否異常

#!/bin/bash
user="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 true
do chkdb
   sleep 3
done
}
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}'

以上是“工作中如何使用Shell實用腳本”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

郑州市| 塘沽区| 金昌市| 通海县| 平顺县| 巩义市| 惠安县| 宁阳县| 长泰县| 乌拉特后旗| 永定县| 陈巴尔虎旗| 永和县| 婺源县| 行唐县| 沅陵县| 门源| 毕节市| 吉林省| 日喀则市| 福州市| 梓潼县| 门源| 濮阳市| 天全县| 拉萨市| 彰武县| 马鞍山市| 尼玛县| 玛曲县| 荔浦县| 荔波县| 桂东县| 屏南县| 磴口县| 英吉沙县| 台江县| 云和县| 盐津县| 晋江市| 宾阳县|