Linux命令
序號
任務
命令組合
1
刪除0字節文件
find . -type f -size 0 -exec rm -rf {} \;
find . type f -size 0 -delete
2
查看進程,按內存從大到小排列
ps -e -o “%C : %p : %z : %a”|sort -k5 -nr
3
按cpu利用率從大到小排列
ps -e -o “%C : %p : %z : %a”|sort -nr
4
打印說cache裡的URL
grep -r -a jpg /data/cache/* | strings | grep “http:” | awk -F’http:’ ‘{print “http:”$2;}’
5
查看http的並發請求數及其TCP連接狀態
netstat -n | awk ‘/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}’
6
sed在這個文裡Root的一行,匹配Root一行,將no替換成yes。
sed -i ‘/Root/s/no/yes/’ /etc/ssh/sshd_config
7
如何殺掉mysql進程
ps aux |grep mysql |grep -v grep |awk ‘{print $2}’ |xargs kill -9
killall -TERM mysqld
kill -9 `cat /usr/local/apache2/logs/httpd.pid`
8
顯示運行3級別開啟的服務(從中了解到cut的用途,截取數據)
ls /etc/rc3.d/S* |cut -c 15-
9
如何在編寫SHELL顯示多個信息,用EOF
cat << EOF
+————————————————————–+
| === Welcome to Tunoff services === |
+————————————————————–+
EOF
10
for的用法(如給mysql建軟鏈接)
cd /usr/local/mysql/bin
for i in *
do ln /usr/local/mysql/bin/$i /usr/bin/$i
done
11
取IP地址
ifconfig eth0 |grep “inet addr:” |awk ‘{print $2}’|cut -c 6-
ifconfig | grep ‘inet addr:’| grep -v ’127.0.0.1′ |cut -d: -f2 | awk ‘{ print $1}’
12
內存的大小
free -m |grep “Mem” | awk ‘{print $2}’
13
查看80端口的連接,並排序
netstat -an -t | grep “:80″ | grep ESTABLISHED | awk ‘{printf “%s %s\n”,$5,$6}’ | sort
14
查看Apache的並發請求數及其TCP連接狀態
netstat -n | awk ‘/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}’
15
統計一下服務器下面所有的jpg的文件的大小
find / -name *.jpg -exec wc -c {} \;|awk ‘{print $1}’|awk ‘{a+=$1}END{print a}’
16
CPU的數量
cat /proc/cpuinfo |grep -c processor
17
CPU負載
cat /proc/loadavg
18
CPU負載
mpstat 1 1
19
內存空間
free
20
磁盤空間
df -h
21
如發現某個分區空間接近用盡,可以進入該分區的掛載點,用以下命令找出占用空間最多的文件或目錄
du -cks * | sort -rn | head -n 10
22
磁盤I/O負載
iostat -x 1 2
23
網絡負載
sar -n DEV
24
網絡錯誤
netstat -i
cat /proc/net/dev
25
網絡連接數目
netstat -an | grep -E “^(tcp)” | cut -c 68- | sort | uniq -c | sort -n
26
進程總數
ps aux | wc -l
27
查看進程樹
ps aufx
28
可運行進程數目
vmwtat 1 5
29
檢查DNS Server工作是否正常,這裡以61.139.2.69為例
dig www.baidu.com @61.139.2.69
30
檢查當前登錄的用戶個數
who | wc -l
31
日志查看、搜索
cat /var/log/rflogview/*errors
grep -i error /var/log/messages
grep -i fail /var/log/messages
tail -f -n 2000 /var/log/messages
32
內核日志
dmesg
33
時間
date
34
已經打開的句柄數
lsof | wc -l
35
網絡抓包,直接輸出摘要信息到文件。
tcpdump -c 10000 -i eth0 -n dst port 80 > /root/pkts
36
然後檢查IP的重復數 並從小到大排序 注意 “-t\ +0″ 中間是兩個空格,less命令的用法。
less pkts | awk {‘printf $3″\n”‘} | cut -d. -f 1-4 | sort | uniq -c | awk {‘printf $1″ “$2″\n”‘} | sort -n -t\ +0
37
kudzu查看網卡型號
kudzu –probe –class=network