shell腳本補(bǔ)遺

Linux自動(dòng)批量增加公鑰
https://blog.csdn.net/heian_99/article/details/105197561
主機(jī)存活監(jiān)控
https://blog.csdn.net/heian_99/article/details/105165477
Redhat機(jī)器巡檢腳本
https://blog.csdn.net/heian_99/article/details/114080095
Shell幫你掌管上千臺(tái)服務(wù)(多線程)
https://blog.csdn.net/heian_99/article/details/117753840

1、查找目錄下所有以 .zip 結(jié)尾的文件移動(dòng)到指定目錄。

find . -name "*.zip" -exec mv {} ./backup/;

2、查找當(dāng)前目錄 30 天以前大于 100M 的 log 文件并刪除。

find . -name "*.log" –mtime +30 –typef –size +100M | xargs rm –rf {};

3、批量解壓當(dāng)前目錄下以 .zip 結(jié)尾的所有文件到指定目錄。

for i  in  `find . –name "*.zip" –type f`
do
  unzip –d $i /data/www/
done
注解:for i in (command);do … done 為 for 循環(huán)的一個(gè)常用格式,其中i為變量,可以自己指定。

4、寫一個(gè)腳本查找最后創(chuàng)建時(shí)間是 3 天前,后綴是 *.log 的文件并刪除。

find . -mtime +3  -name "*.log" | xargs rm -rf {};

5、寫一個(gè)腳本將某目錄下大于 100k 的文件移動(dòng)至 /tmp 下

find . -size +100k -exec mv {} /tmp;

6、如何判斷某個(gè)目錄是否存在,不存在則新建,存在則打印信息。

if [ ! –d /data/backup/ ];then
   mkdir –p /data/backup/
else
   echo  "目錄已存在"
fi
-d 代表目錄

7、替換文件中的目錄

sed 's:/user/local:/tmp:g' test.txt
或者
sed -i 's//usr/local//tmp/g' test.txt

8、sed 常用命令

如何去掉行首的.字符: sed -i 's/^.//g' test.txt

在行首添加一個(gè)a字符: sed 's/^/a/g'    test.txt

在行尾添加一個(gè)a字符: sed 's/$/a/'     tets.txt

在特定行后添加一個(gè)z字符:sed '/rumen/az' test.txt

在行前加入一個(gè)c字符: sed '/rumenz/ic' test.txt

9、sed 另外一個(gè)用法找到當(dāng)前行,然后在修改該行后面的參數(shù)

sed -i '/SELINUX/s/enforcing/disabled/' /etc/selinux/config
sed 冒號(hào)方式
sed -i 's:/tmp:/tmp/abc/:g' test.txt意思是將/tmp改成/tmp/abc/。

10、統(tǒng)計(jì) Nginx 訪問日志 訪問量排在前20的ip地址

cat access.log |awk '{print $1}'|sort|uniq -c |sort -nr |head -20
注解:sort 排序、uniq(檢查及刪除文本文件中重復(fù)出現(xiàn)的行列 )

11、修改文本中以ab 結(jié)尾的替換成 cd:

sed -e 's/ab$/cd/g' b.txt

12、網(wǎng)絡(luò)抓包:tcpdump

#抓取 56.7 通過80端口請(qǐng)求的數(shù)據(jù)包。
tcpdump -nn host 192.168.56.7 and port 80
#排除0.22 80端口
tcpdump -nn host 192.168.56.7 or ! host 192.168.0.22 and port 80

13、統(tǒng)計(jì) bash_history 最常用的 20 條命令

history | awk '{print $2}' | sort | uniq -c | sort -k1,1nr | head -10

14、配置防火墻腳本,只允許遠(yuǎn)程主機(jī)訪問本機(jī)的 80 端口

iptables -F
iptables -X
iptables -A INPUT -p tcp --dport 80 -j accept
iptables -A INPUT -p tcp -j REJECT
或者
iptables -A INPUT -m state --state NEW-m tcp -p tcp --dport 80 -j ACCEPT
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容