关于linux:请收藏Linux-运维必备的-40-个命令总结

33次阅读

共计 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…

正文完
 0