自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

分享7個(gè)shell腳本實(shí)例--shell腳本練習(xí)必備

系統(tǒng) Linux
看多shell腳本實(shí)例自然就會有shell腳本的編寫思路了,所以我一般比較推薦看腳本實(shí)例來練習(xí)shell腳本。下面分享幾個(gè)shell腳本實(shí)例。

概述

看多shell腳本實(shí)例自然就會有shell腳本的編寫思路了,所以我一般比較推薦看腳本實(shí)例來練習(xí)shell腳本。下面分享幾個(gè)shell腳本實(shí)例。

1、監(jiān)測Nginx訪問日志502情況,并做相應(yīng)動作

假設(shè)服務(wù)器環(huán)境為lnmp,近期訪問經(jīng)常出現(xiàn)502現(xiàn)象,且502錯(cuò)誤在重啟php-fpm服務(wù)后消失,因此需要編寫監(jiān)控腳本,一旦出現(xiàn)502,則自動重啟php-fpm服務(wù)。

  1. #場景: 
  2. #1.訪問日志文件的路徑:/data/log/access.log 
  3. #2.腳本死循環(huán),每10秒檢測一次,10秒的日志條數(shù)為300條,出現(xiàn)502的比例不低于10%(30條)則需要重啟php-fpm服務(wù) 
  4. #3.重啟命令為:/etc/init.d/php-fpm restart 
  5. #!/bin/bash 
  6. ########################################################### 
  7. #監(jiān)測Nginx訪問日志502情況,并做相應(yīng)動作 
  8. ########################################################### 
  9. log=/data/log/access.log 
  10. N=30 #設(shè)定閾值 
  11. while : 
  12. do 
  13.  #查看訪問日志的最新300條,并統(tǒng)計(jì)502的次數(shù) 
  14.     err=`tail -n 300 $log |grep -c '502" '
  15.  if [ $err -ge $N ] 
  16.  then 
  17.  /etc/init.d/php-fpm restart 2> /dev/null 
  18.  #設(shè)定60s延遲防止腳本bug導(dǎo)致無限重啟php-fpm服務(wù) 
  19.      sleep 60 
  20.  fi 
  21.  sleep 10 
  22. done 
分享7個(gè)shell腳本實(shí)例--shell腳本練習(xí)必備

2、把一個(gè)文檔前五行中包含字母的行刪掉,同時(shí)刪除6到10行包含的所有字母

1)準(zhǔn)備測試文件,文件名為2.txt

  1. 第1行1234567不包含字母 
  2. 第2行56789BBBBBB 
  3. 第3行67890CCCCCCCC 
  4. 第4行78asdfDDDDDDDDD 
  5. 第5行123456EEEEEEEE 
  6. 第6行1234567ASDF 
  7. 第7行56789ASDF 
  8. 第8行67890ASDF 
  9. 第9行78asdfADSF 
  10. 第10行123456AAAA 
  11. 第11行67890ASDF 
  12. 第12行78asdfADSF 
  13. 第13行123456AAAA 

2)腳本如下:

  1. #!/bin/bash 
  2. ############################################################## 
  3. #把一個(gè)文檔前五行中包含字母的行刪掉,同時(shí)刪除6到10行包含的所有字母 
  4. ############################################################## 
  5. sed -n '1,5'p 2.txt |sed '/[a-zA-Z]/'
  6. sed -n '6,10'p 2.txt |sed s'/[a-zA-Z]//'
  7. sed -n '11,$'p 2.txt 
  8. #最終結(jié)果只是在屏幕上打印結(jié)果,如果想直接更改文件,可將輸出結(jié)果寫入臨時(shí)文件中,再替換2.txt或者使用-i選項(xiàng) 

分享7個(gè)shell腳本實(shí)例--shell腳本練習(xí)必備3、用shell打印示例語句中字母數(shù)小于6的單詞

  1. #示例語句: 
  2. #Bash also interprets a number of multi-character options. 
  3. #!/bin/bash 
  4. ############################################################## 
  5. #shell打印示例語句中字母數(shù)小于6的單詞 
  6. ############################################################## 
  7. for s in Bash also interprets a number of multi-character options. 
  8. do 
  9.  n=`echo $s|wc -c` 
  10.  if [ $n -lt 6 ] 
  11.  then 
  12.  echo $s 
  13.  fi 
  14. done 
分享7個(gè)shell腳本實(shí)例--shell腳本練習(xí)必備

4、輸入數(shù)字運(yùn)行相應(yīng)命令

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

分享7個(gè)shell腳本實(shí)例--shell腳本練習(xí)必備

 

分享7個(gè)shell腳本實(shí)例--shell腳本練習(xí)必備

5、創(chuàng)建10個(gè)用戶,并分別設(shè)置密碼,密碼要求10位且包含大小寫字母以及數(shù)字,最后需要把每個(gè)用戶的密碼存在指定文件中

  1. #!/bin/bash 
  2. ############################################################## 
  3. #創(chuàng)建10個(gè)用戶,并分別設(shè)置密碼,密碼要求10位且包含大小寫字母以及數(shù)字 
  4. #最后需要把每個(gè)用戶的密碼存在指定文件中 
  5. #前提條件:安裝mkpasswd命令 
  6. ############################################################## 
  7. #生成10個(gè)用戶的序列(00-09) 
  8. for u in `seq -w 0 09` 
  9. do 
  10.  #創(chuàng)建用戶 
  11.  useradd user_$u 
  12.  #生成密碼 
  13.  p=`mkpasswd -s 0 -l 10` 
  14.  #從標(biāo)準(zhǔn)輸入中讀取密碼進(jìn)行修改(不安全) 
  15.  echo $p|passwd --stdin user_$u 
  16.  #常規(guī)修改密碼 
  17.  echo -e "$p\n$p"|passwd user_$u 
  18.  #將創(chuàng)建的用戶及對應(yīng)的密碼記錄到日志文件中 
  19.  echo "user_$u $p" >> /tmp/userpassword 
  20. done 

分享7個(gè)shell腳本實(shí)例--shell腳本練習(xí)必備

 

分享7個(gè)shell腳本實(shí)例--shell腳本練習(xí)必備

6、監(jiān)控httpd的進(jìn)程數(shù),根據(jù)監(jiān)控情況做相應(yīng)處理

  1. #!/bin/bash 
  2. ############################################################################################################################### 
  3. #需求: 
  4. #1.每隔10s監(jiān)控httpd的進(jìn)程數(shù),若進(jìn)程數(shù)大于等于500,則自動重啟Apache服務(wù),并檢測服務(wù)是否重啟成功 
  5. #2.若未成功則需要再次啟動,若重啟5次依舊沒有成功,則向管理員發(fā)送告警郵件,并退出檢測 
  6. #3.如果啟動成功,則等待1分鐘后再次檢測httpd進(jìn)程數(shù),若進(jìn)程數(shù)正常,則恢復(fù)正常檢測(10s一次),否則放棄重啟并向管理員發(fā)送告警郵件,并退出檢測 
  7. ############################################################################################################################### 
  8. #計(jì)數(shù)器函數(shù) 
  9. check_service() 
  10.  j=0 
  11.  for i in `seq 1 5`  
  12.  do 
  13.  #重啟Apache的命令 
  14.  /usr/local/apache2/bin/apachectl restart 2> /var/log/httpderr.log 
  15.     #判斷服務(wù)是否重啟成功 
  16.  if [ $? -eq 0 ] 
  17.  then 
  18.  break 
  19.  else 
  20.  j=$[$j+1] 
  21.  fi 
  22.     #判斷服務(wù)是否已嘗試重啟5次 
  23.  if [ $j -eq 5 ] 
  24.  then 
  25.  mail.py 
  26.  exit 
  27.  fi 
  28.  done  
  29. while : 
  30. do 
  31.  n=`pgrep -l httpd|wc -l` 
  32.  #判斷httpd服務(wù)進(jìn)程數(shù)是否超過500 
  33.  if [ $n -gt 500 ] 
  34.  then 
  35.  /usr/local/apache2/bin/apachectl restart 
  36.  if [ $? -ne 0 ] 
  37.  then 
  38.  check_service 
  39.  else 
  40.  sleep 60 
  41.  n2=`pgrep -l httpd|wc -l` 
  42.  #判斷重啟后是否依舊超過500 
  43.              if [ $n2 -gt 500 ] 
  44.  then  
  45.  mail.py 
  46.  exit 
  47.  fi 
  48.  fi 
  49.  fi 
  50.  #每隔10s檢測一次 
  51.  sleep 10 
  52. done 

分享7個(gè)shell腳本實(shí)例--shell腳本練習(xí)必備

 

分享7個(gè)shell腳本實(shí)例--shell腳本練習(xí)必備

7、根據(jù)web訪問日志,封禁請求量異常的IP,如IP在半小時(shí)后恢復(fù)正常,則解除封禁

  1. #!/bin/bash 
  2. #################################################################################### 
  3. #根據(jù)web訪問日志,封禁請求量異常的IP,如IP在半小時(shí)后恢復(fù)正常,則解除封禁 
  4. #################################################################################### 
  5. logfile=/data/log/access.log 
  6. #顯示一分鐘前的小時(shí)和分鐘 
  7. d1=`date -d "-1 minute" +%H%M` 
  8. d2=`date +%M` 
  9. ipt=/sbin/iptables 
  10. ips=/tmp/ips.txt 
  11. block() 
  12.  #將一分鐘前的日志全部過濾出來并提取IP以及統(tǒng)計(jì)訪問次數(shù) 
  13.  grep '$d1:' $logfile|awk '{print $1}'|sort -n|uniq -c|sort -n > $ips 
  14.  #利用for循環(huán)將次數(shù)超過100的IP依次遍歷出來并予以封禁 
  15.  for i in `awk '$1>100 {print $2}' $ips` 
  16.  do 
  17.  $ipt -I INPUT -p tcp --dport 80 -s $i -j REJECT 
  18.  echo "`date +%F-%T` $i" >> /tmp/badip.log 
  19.  done 
  20. unblock() 
  21.  #將封禁后所產(chǎn)生的pkts數(shù)量小于10的IP依次遍歷予以解封 
  22.  for a in `$ipt -nvL INPUT --line-numbers |grep '0.0.0.0/0'|awk '$2<10 {print $1}'|sort -nr` 
  23.  do  
  24.  $ipt -D INPUT $a 
  25.  done 
  26.  $ipt -Z 
  27. #當(dāng)時(shí)間在00分以及30分時(shí)執(zhí)行解封函數(shù) 
  28. if [ $d2 -eq "00" ] || [ $d2 -eq "30" ] 
  29.  then 
  30.  #要先解再封,因?yàn)閯倓偡饨麜r(shí)產(chǎn)生的pkts數(shù)量很少 
  31.  unblock 
  32.  block 
  33.  else 
  34.  block 
  35. fi 
分享7個(gè)shell腳本實(shí)例--shell腳本練習(xí)必備

 

責(zé)任編輯:龐桂玉 來源: 今日頭條
相關(guān)推薦

2019-08-12 07:45:44

Linux腳本shell

2019-10-31 08:22:39

shell腳本Linux

2019-08-13 11:53:01

腳本語言AWKBash

2021-04-15 11:21:26

Shell腳本Linux

2017-08-17 08:59:40

磁盤RAIDShell

2024-11-27 09:19:25

2020-02-24 22:50:15

Shell腳本MySQL

2021-05-11 07:50:31

BashShell腳本

2021-04-11 07:56:42

ShellLinux

2018-08-28 16:02:59

LinuxShellBash

2019-08-14 08:03:49

LinuxShell腳本web服務(wù)

2011-09-27 13:52:41

2020-06-17 10:42:54

shellshell腳本Linux

2021-05-31 10:55:23

shell腳本Linux

2020-11-02 08:23:36

shell腳本Linux

2023-07-31 08:45:10

Shell腳本

2009-11-18 13:52:30

PHP shell腳本

2012-04-26 14:02:58

ibmdw

2021-07-02 06:54:44

Shell腳本 Linux

2022-06-21 09:26:21

Shell腳本JavaScript
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號