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

34次阅读

共计 4349 个字符,预计需要花费 11 分钟才能阅读完成。

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 << EOF+--------------------------------------------------------------+|       === Welcome to Tunoff services ===                |+--------------------------------------------------------------+EOF

10 for 的巧用(如给 MySQL 建软链接)

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 '{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 %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 的文件的大小,写了个 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,网关等是否能够失常连通
29 用户

who | wc -l

查看登录用户是否过多 (比方超过 50 个)   也能够用命令:# uptime。
30 系统日志

# cat /var/log/rflogview/*errors

查看是否有异样谬误记录   也能够搜查一些异样关键字,例如:

grep -i error /var/log/messagesgrep -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. 匹配双字节字符(包含汉字在内):1
评注:能够用来计算字符串的长度(一个双字节字符长度计 2,ASCII 字符计 1)
3. 匹配空白行的正则表达式:\n\s*\r
评注:能够用来删除空白行
4. 匹配 HTML 标记的正则表达式:<(\S?)2>.?</\1>|<.? />
评注:网上流传的版本太蹩脚,下面这个也仅仅能匹配局部,对于简单的嵌套标记仍旧无能为力
5. 匹配首尾空白字符的正则表达式:^\s|\s$
评注:能够用来删除行首行尾的空白字符 (包含空格、制表符、换页符等等),十分有用的表达式
6. 匹配 Email 地址的正则表达式:
\w+([-+.]\w+)@\w+([-.]\w+).\w+([-.]\w+)*
评注:表单验证时很实用
7. 匹配网址 URL 的正则表达式:[a-zA-z]+://3*
评注:网上流传的版本性能很无限,下面这个根本能够满足需要
8. 匹配帐号是否非法(字母结尾,容许 5 -16 字节,容许字母数字下划线):^a-zA-Z{4,15}$
评注:表单验证时很实用
9. 匹配国内电话号码:\d{3}-\d{8}|\d{4}-\d{7}
评注:匹配模式如 0511-4405222 或 021-87888822
10. 匹配腾讯 QQ 号:1-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 个英文字母或者下划线组成的字符串
评注:最根本也是最罕用的一些表达式


  1. \x00-\xff ↩
  2. > ↩
  3. \s ↩

正文完
 0