首页 > 代码库 > 常用Linux Shell命令组合

常用Linux Shell命令组合

序号任务命令组合
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里的URLgrep -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]}’
6sed在这个文里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显示多个信息,用EOFcat << EOF
+————————————————————–+
|   === Welcome to Tunoff services ===                         |
+————————————————————–+
EOF
10for的用法(如给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}’
16CPU的数量cat /proc/cpuinfo |grep -c processor
17CPU负载cat /proc/loadavg
18CPU负载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
37kudzu查看网卡型号kudzu –probe –class=network