这些命令都是在系统运维常敲的命令,几天不敲,有些就记不全了,对于职业的运维工程师来说这些最好能熟记并能举一反三。虽然什么都可以百度,谷歌查但是如果你能在工作中很流畅的敲出来并解决问题,那么工作效率肯定会很高。
find . -name "*.zip" -exec mv {} ./backup/;
find . -name "*.log" –mtime +30 –typef –size +100M | xargs rm –rf {};
for i in `find . –name "*.zip" –type f`
do
unzip –d $i /data/www/
done
注解:
for i in (command);do … done
为 for 循环的一个常用格式,其中i为变量,可以自己指定。
*.log
的文件并删除。find . -mtime +3 -name "*.log" | xargs rm -rf {};
find . -size +100k -exec mv {} /tmp;
if [ ! –d /data/backup/ ];then
mkdir –p /data/backup/
else
echo "目录已存在"
fi
-d 代表目录。
sed 's:/user/local:/tmp:g' test.txt
或者
sed -i 's//usr/local//tmp/g' test.txt
如何去掉行首的.字符: sed -i 's/^.//g' test.txt
在行首添加一个a字符: sed 's/^/a/g' test.txt
在行尾添加一个a字符: sed 's/$/a/' tets.txt
在特定行后添加一个z字符:sed '/rumen/az' test.txt
在行前加入一个c字符: sed '/rumenz/ic' test.txt
sed -i '/SELINUX/s/enforcing/disabled/' /etc/selinux/config
sed 冒号方式
sed -i 's:/tmp:/tmp/abc/:g' test.txt意思是将/tmp改成/tmp/abc/。
cat access.log |awk '{print $1}'|sort|uniq -c |sort -nr |head -20
注解:
sort
排序、uniq
(检查及删除文本文件中重复出现的行列 )
sed -e 's/ab$/cd/g' b.txt
#抓取 56.7 通过80请求的数据包。
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
history | awk '{print $2}' | sort | uniq -c | sort -k1,1nr | head -10
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