共计 4700 个字符,预计需要花费 12 分钟才能阅读完成。
1、删除 0 字节文件
find -type f -size 0 -exec rm -rf {} ;
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
(从中理解到 awk 的用处)
killall -TERM mysqld
kill -9 `cat /usr/local/apache2/logs/httpd.pid` #试试查杀过程 PID
8、显示运行 3 级别开启的服务:
ls /etc/rc3.d/S* |cut -c 15- (从中理解到 cut 的用处,截取数据)
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
netstat -an -t | grep ":80" | grep ESTABLISHED | awk '{printf"%s %sn",$5,$6}' | sort
14、查看 Apache 的并发申请数及其 TCP 连贯状态:
netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'
15、因为共事要统计一下服务器上面所有的 jpg 的文件的大小,写了个 SHELL 给他来统计。原来用 xargs 实现,但他一次解决一部分。搞的有多个总和……,上面的命令就能解决。
find / -name *.jpg -exec wc -c {} ;|awk '{print $1}'|awk '{a+=$1}END{print a}'
CPU 的数量(多核算多个 CPU,cat /proc/cpuinfo |grep -c processor)越多,零碎负载越低,每秒能解决的申请数也越多。
16、CPU 负载
cat /proc/loadavg
查看前三个输入值是否超过了零碎逻辑 CPU 的 4 倍。
17、CPU 负载
mpstat 1 1
查看 %idle 是否过低(比方小于 5%)。
18、内存空间
free
查看 free 值是否过低,也能够用 # cat /proc/meminfo
19、SWAP 空间
free
查看 swap used 值是否过高,如果 swap used 值过高,进一步查看 swap 动作是否频繁:
vmstat 1 5
察看 si 和 so 值是否较大
20、磁盘空间
df -h
查看是否有分区使用率(Use%)过高(比方超过 90%)如发现某个分区空间靠近用尽,能够进入该分区的挂载点,用以下命令找出占用空间最多的文件或目录:
du -cks * | sort -rn | head -n 10
21、磁盘 I/O 负载
iostat -x 1 2
查看 I / O 使用率(%util)是否超过 100%
22、网络负载
sar -n DEV
查看网络流量(rxbyt/s, txbyt/s)是否过高
23、网络谬误
netstat -i
查看是否有网络谬误(drop fifo colls carrier),也能够用命令:# cat /proc/net/dev
24、网络连接数目
netstat -an | grep -E“^(tcp)”| cut -c 68- | sort | uniq -c | sort -n
25、过程总数
ps aux | wc -l
查看过程个数是否失常 (比方超过 250)
26、可运行过程数目
vmwtat 1 5
列给出的是可运行过程的数目,查看其是否超过零碎逻辑 CPU 的 4 倍
27、过程
top -id 1
察看是否有异样过程呈现。
28、网络状态,查看 DNS,网关等是否能够失常连通
ping traceroute nslookup dig
29、用户
who | wc -l
查看登录用户是否过多 (比方超过 50 个) 也能够用命令:# uptime。
30、系统日志
# cat /var/log/rflogview/*errors
查看是否有异样谬误记录 也能够搜查一些异样关键字,例如:grep -i error /var/log/messages
grep -i fail /var/log/messages
31、外围日志
dmesg
查看是否有异样谬误记录。
32、零碎工夫
date
查看零碎工夫是否正确。
33、关上文件数目
lsof | wc -l
查看关上文件总数是否过多。
34、日志
# logwatch –print
配置 /etc/log.d/logwatch.conf,将 Mailto 设置为本人的 email 地址,启动 mail 服务 (sendmail 或者 postfix),这样就能够每天收到日志报告了。缺省 logwatch 只报告昨天的日志,能够用 # logwatch –print –range all 取得所有的日志剖析后果。能够用 # logwatch –print –detail high 取得更具体的日志剖析后果 (而不仅仅是出错日志)。
35、杀掉 80 端口相干的过程
lsof -i :80|grep -v“ID”|awk‘{print“kill -9”,$2}’|sh
36、革除僵死过程
ps -eal | awk '{if ($2 =="Z") {print $4}}' | kill -9
37、tcpdump 抓包,用来避免 80 端口被人攻打时能够剖析数据
tcpdump -c 10000 -i eth0 -n dst port 80 > /root/pkts
38、而后查看 IP 的反复数并从小到大排序 留神“-t +0”两头是两个空格
# less pkts | awk {'printf $3"n"'} | cut -d. -f 1-4 | sort | uniq -c | awk {'printf $1""$2"n"'} | sort -n -t +0
39、查看有多少个流动的 php-cgi 过程
netstat -anp | grep php-cgi | grep ^tcp | wc -l
40、查看零碎自启动的服务
chkconfig --list | awk '{if ($5=="3:on") print $1}'
41、kudzu 查看网卡型号
kudzu --probe --class=network
罕用正则表达式
1. 匹配中文字符的正则表达式:[u4e00-u9fa5]
评注:匹配中文还真是个头疼的事,有了这个表达式就好办了
2. 匹配双字节字符 (包含汉字在内):[^x00-xff]
评注:能够用来计算字符串的长度(一个双字节字符长度计 2,ASCII 字符计 1)
3. 匹配空白行的正则表达式:ns*r
评注:能够用来删除空白行
4. 匹配 HTML 标记的正则表达式:<(S*?)[^>]*>.*?</1>|<.*? />
评注:网上流传的版本太蹩脚,下面这个也仅仅能匹配局部,对于简单的嵌套标记仍旧无能为力
5. 匹配首尾空白字符的正则表达式:^s*|s*$
评注:能够用来删除行首行尾的空白字符 (包含空格、制表符、换页符等等),十分有用的表达式
6. 匹配 Email 地址的正则表达式:
w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
评注:表单验证时很实用
7. 匹配网址 URL 的正则表达式:[a-zA-z]+://[^s]*
评注:网上流传的版本性能很无限,下面这个根本能够满足需要
8. 匹配帐号是否非法 (字母结尾,容许 5 -16 字节,容许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
评注:表单验证时很实用
9. 匹配国内电话号码:d{3}-d{8}|d{4}-d{7}
评注:匹配模式如 0511-4405222 或 021-87888822
10. 匹配腾讯 QQ 号:[1-9][0-9]{4,}
评注:腾讯 QQ 号从 10000 开始
11. 匹配中国邮政编码:[1-9]d{5}(?!d)
评注:中国邮政编码为 6 位数字
12. 匹配×××:d{15}|d{18}
评注:中国的×××为 15 位或 18 位
13. 匹配 ip 地址:d+.d+.d+.d+
评注:提取 IP 地址时有用
14. 匹配特定数字:
^[1-9]d*$ // 匹配正整数
^-[1-9]d*$ // 匹配负整数
^-?[1-9]d*$ // 匹配整数
^[1-9]d*|0$ // 匹配非负整数(正整数 + 0)^-[1-9]d*|0$ // 匹配非正整数(负整数 + 0)^[1-9]d*.d*|0.d*[1-9]d*$ // 匹配正浮点数
^-([1-9]d*.d*|0.d*[1-9]d*)$ // 匹配负浮点数
^-?([1-9]d*.d*|0.d*[1-9]d*|0?.0+|0)$ // 匹配浮点数
^[1-9]d*.d*|0.d*[1-9]d*|0?.0+|0$ // 匹配非负浮点数(正浮点数 + 0)^(-([1-9]d*.d*|0.d*[1-9]d*))|0?.0+|0$ // 匹配非正浮点数(负浮点数 + 0)
评注:解决大量数据时有用,具体利用时留神修改
15. 匹配特定字符串:
^[A-Za-z]+$ // 匹配由 26 个英文字母组成的字符串
^[A-Z]+$ // 匹配由 26 个英文字母的大写组成的字符串
^[a-z]+$ // 匹配由 26 个英文字母的小写组成的字符串
^[A-Za-z0-9]+$ // 匹配由数字和 26 个英文字母组成的字符串
^w+$ // 匹配由数字、26 个英文字母或者下划线组成的字符串
评注:最根本也是最罕用的一些表达式
起源:https://blog.51cto.com/wangwe…