致 Linux 運(yùn)維:這些高頻命令,你真的需要熟記!
這些命令都是在系統(tǒng)運(yùn)維常敲的命令,幾天不敲,有些就記不全了,對(duì)于職業(yè)的運(yùn)維工程師來(lái)說(shuō)這些最好能熟記并能舉一反三。雖然什么都可以百度、谷歌,但是如果你能在工作中很流暢的敲出來(lái)并解決問(wèn)題,那么工作效率肯定會(huì)很高。
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、寫(xiě)一個(gè)腳本查找最后創(chuàng)建時(shí)間是 3 天前,后綴是 *.log 的文件并刪除。
find . -mtime +3 -name "*.log" | xargs rm -rf {};
5、寫(xiě)一個(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:/usr/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 訪問(wèn)日志 訪問(wèn)量排在前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 通過(guò)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ī)訪問(wèn)本機(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
責(zé)任編輯:龐桂玉
來(lái)源:
良許Linux