你知道的越多,不知道的就越多,业余的像一棵小草!
你来,我们一起精进!你不来,我和你的竞争对手一起精进!
编辑:业余草
推荐:https://www.xttblog.com/?p=5176
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 -i '/Root/s/no/yes/' /etc/ssh/sshd_config
sed 在这个文里 Root 的一行,匹配 Root 一行,将 no 替换成 yes。
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 <
10、for 的巧用&#xff08;如给 MySQL 建软链接&#xff09;
cd /usr/local/mysql/binfor i in *do ln /usr/local/mysql/bin/$i /usr/bin/$idone
11、取 IP 地址
ifconfig eth0 |grep "inet addr:" |awk &#39;{print $2}&#39;| cut -c 6- 或者ifconfig | grep &#39;inet addr:&#39;| grep -v &#39;127.0.0.1&#39; | cut -d: -f2 | awk &#39;{ print $1}&#39;
12、内存的大小:
free -m |grep "Mem" | awk &#39;{print $2}&#39;
13
netstat -an -t | grep ":80" | grep ESTABLISHED | awk &#39;{printf "%s %s\n",$5,$6}&#39; | sort
14、查看 Apache 的并发请求数及其 TCP 连接状态&#xff1a;
netstat -n | awk &#39;/^tcp/ {&#43;&#43;S[$NF]} END {for(a in S) print a, S[a]}&#39;
15、因为同事要统计一下服务器下面所有的 jpg 的文件的大小&#xff0c;写了个 SHELL 给他来统计。原来用 xargs 实现&#xff0c;但他一次处理一部分。搞的有多个总和……&#xff0c;下面的命令就能解决。
find / -name *.jpg -exec wc -c {} \;|awk &#39;{print $1}&#39;|awk &#39;{a&#43;&#61;$1}END{print a}&#39;
CPU 的数量&#xff08;多核算多个CPU&#xff0c;cat /proc/cpuinfo |grep -c processor
&#xff09;越多&#xff0c;系统负载越低&#xff0c;每秒能处理的请求数也越多。
16、CPU负载
cat /proc/loadavg
检查前三个输出值是否超过了系统逻辑 CPU 的4倍。
17、 CPU负载
mpstat 1 1
检查 %idle 是否过低&#xff08;比如小于5%&#xff09;。
18、内存空间
free
检查 free 值是否过低&#xff0c;也可以用 # cat /proc/meminfo
19、SWAP 空间
free
检查 swap used 值是否过高&#xff0c;如果 swap used 值过高&#xff0c;进一步检查 swap 动作是否频繁&#xff1a;
vmstat 1 5
观察 si 和 so 值是否较大
20、磁盘空间
df -h
检查是否有分区使用率&#xff08;Use%&#xff09;过高&#xff08;比如超过90%&#xff09;如发现某个分区空间接近用尽&#xff0c;可以进入该分区的挂载点&#xff0c;用以下命令找出占用空间最多的文件或目录&#xff1a;
du -cks * | sort -rn | head -n 10
21、磁盘 I/O 负载
iostat -x 1 2
检查I/O使用率&#xff08;%util&#xff09;是否超过 100%
22、网络负载
sar -n DEV
检查网络流量&#xff08;rxbyt/s, txbyt/s&#xff09;是否过高
23、网络错误
netstat -i
检查是否有网络错误&#xff08;drop fifo colls carrier&#xff09;&#xff0c;也可以用命令&#xff1a;# 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
列给出的是可运行进程的数目&#xff0c;检查其是否超过系统逻辑 CPU 的 4 倍
27、进程
top -id 1
观察是否有异常进程出现。
28、网络状态&#xff0c;检查DNS&#xff0c;网关等是否可以正常连通
29、用户
who | wc -l
检查登录用户是否过多 (比如超过50个) 也可以用命令&#xff1a;# uptime。
30、系统日志
# cat /var/log/rflogview/*errors
检查是否有异常错误记录 也可以搜寻一些异常关键字&#xff0c;例如&#xff1a;
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&#xff0c;将 Mailto 设置为自己的 email 地址&#xff0c;启动 mail 服务(sendmail或者postfix)&#xff0c;这样就可以每天收到日志报告了。
缺省 logwatch 只报告昨天的日志&#xff0c;可以用 # 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 &#39;{ if ($2 &#61;&#61; "Z") {print $4}}&#39; | kill -9
37、tcpdump 抓包&#xff0c;用来防止80端口被人攻击时可以分析数据
tcpdump -c 10000 -i eth0 -n dst port 80 > /root/pkts
38、然后检查IP的重复数并从小到大排序 注意 “-t\ &#43;0” 中间是两个空格
# less pkts | awk {&#39;printf $3"\n"&#39;} | cut -d. -f 1-4 | sort | uniq -c | awk {&#39;printf $1" "$2"\n"&#39;} | sort -n -t\ &#43;0
39、查看有多少个活动的 php-cgi 进程
netstat -anp | grep php-cgi | grep ^tcp | wc -l
40、查看系统自启动的服务
chkconfig --list | awk &#39;{if ($5&#61;&#61;"3:on") print $1}&#39;
41、kudzu 查看网卡型号
kudzu --probe --class&#61;network
常用正则表达式
1.匹配中文字符的正则表达式&#xff1a; [\u4e00-\u9fa5]
评注&#xff1a;匹配中文还真是个头疼的事&#xff0c;有了这个表达式就好办了
2.匹配双字节字符(包括汉字在内)&#xff1a;[^\x00-\xff]
评注&#xff1a;可以用来计算字符串的长度&#xff08;一个双字节字符长度计2&#xff0c;ASCII字符计1&#xff09;
3.匹配空白行的正则表达式&#xff1a;\n\s*\r
评注&#xff1a;可以用来删除空白行
4.匹配 HTML 标记的正则表达式&#xff1a;<(\S*?)[^>]*>.*?\1>|<.*? />
评注&#xff1a;网上流传的版本太糟糕&#xff0c;上面这个也仅仅能匹配部分&#xff0c;对于复杂的嵌套标记依旧无能为力
5.匹配首尾空白字符的正则表达式&#xff1a;^\s*|\s*$
评注&#xff1a;可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等)&#xff0c;非常有用的表达式
6.匹配Email地址的正则表达式&#xff1a;
\w&#43;([-&#43;.]\w&#43;)*&#64;\w&#43;([-.]\w&#43;)*\.\w&#43;([-.]\w&#43;)*
评注&#xff1a;表单验证时很实用
7.匹配网址URL的正则表达式&#xff1a;[a-zA-z]&#43;://[^\s]*
评注&#xff1a;网上流传的版本功能很有限&#xff0c;上面这个基本可以满足需求
8.匹配帐号是否合法(字母开头&#xff0c;允许5-16字节&#xff0c;允许字母数字下划线)&#xff1a;^[a-zA-Z][a-zA-Z0-9_]{4,15}$
评注&#xff1a;表单验证时很实用
9.匹配国内电话号码&#xff1a;\d{3}-\d{8}|\d{4}-\d{7}
评注&#xff1a;匹配形式如 0511-4405222 或 021-87888822
10.匹配腾讯QQ号&#xff1a;[1-9][0-9]{4,}
评注&#xff1a;腾讯QQ号从10000开始
11.匹配中国邮政编码&#xff1a;[1-9]\d{5}(?!\d)
评注&#xff1a;中国邮政编码为6位数字
12.匹配×××&#xff1a;\d{15}|\d{18}
评注&#xff1a;中国的×××为15位或18位
13.匹配ip地址&#xff1a;\d&#43;\.\d&#43;\.\d&#43;\.\d&#43;
评注&#xff1a;提取 IP 地址时有用
14.匹配特定数字&#xff1a;
^[1-9]\d*$ //匹配正整数
^-[1-9]\d*$ //匹配负整数
^-?[1-9]\d*$ //匹配整数
^[1-9]\d*|0$ //匹配非负整数&#xff08;正整数 &#43; 0&#xff09;
^-[1-9]\d*|0$ //匹配非正整数&#xff08;负整数 &#43; 0&#xff09;
^[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&#43;|0)$ //匹配浮点数
^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0&#43;|0$ //匹配非负浮点数&#xff08;正浮点数 &#43; 0&#xff09;
^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0&#43;|0$ //匹配非正浮点数&#xff08;负浮点数 &#43; 0&#xff09;
评注&#xff1a;处理大量数据时有用&#xff0c;具体应用时注意修正
15.匹配特定字符串&#xff1a;
^[A-Za-z]&#43;$ //匹配由26个英文字母组成的字符串^[A-Z]&#43;$ //匹配由26个英文字母的大写组成的字符串^[a-z]&#43;$ //匹配由26个英文字母的小写组成的字符串^[A-Za-z0-9]&#43;$ //匹配由数字和26个英文字母组成的字符串^\w&#43;$ //匹配由数字、26个英文字母或者下划线组成的字符串
评注&#xff1a;最基本也是最常用的一些表达式