当前位置:首页 > 运维 > 正文内容

linux中cpu占用过高排查方法

phpmianshi5年前 (2016-04-17)运维188
CPU使用率查看
top

通过top -d 0.1可以缩短采样时间。

-d:指定每两次屏幕信息刷新之间的时间间隔。当然用户可以使用s交互命令来改变之。

load average后面的三个数分别是1分钟、5分钟、15分钟的负载情况。是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。

查看多核CPU

top 输入1就可以看到各个核心的CPU使用率
mpstat -P ALL
sar -P ALL

当然你也可以用htop代替top,htop的详细用法请自行搜索,这里不多介绍了。

找到最耗CPU的进程
top -c

PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND           
3715 www       20   0  139m  18m 8256 S  2.0  0.5   0:05.22 php-fpm: pool www

-c:显示整个命令行而不只是显示命令名。
按大写P   按照cpu使用率排序
假设最耗CPU的进程PID为3715

找到最耗CPU的线程

top -Hp 3715

 PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND           
 3715 www       20   0  138m  18m 8280 S  0.0  0.5   0:04.92 php-fpm

-p:通过指定监控进程ID来仅仅监控某个进程的状态。
-H 显示线程信息 show all threads

显示一个进程的线程运行信息列表

按大写P   线程按照cpu使用率排序

查看堆栈,找到线程在干嘛

pstack/jstack/grep  
C进程使用pstack查看线程堆栈信息
java进程采用jstack查看线程堆栈信息.
[root@dev logs]# pstack 3715       
#0  0x00007fa864a334e0 in __accept_nocancel () from /lib64/libc.so.6
#1  0x0000000000857ca1 in fcgi_accept_request ()
#2  0x000000000085f42d in main ()

如果提示 -bash: pstack: command not found 只要安装gdb就可以了

yum install gdb -y

查看CPU的平均状况信息

[root@dev logs]# mpstat -P ALL -I SUM 
Linux 2.6.32-504.30.3.el6.x86_64 (dev.aigupiao.com)     06/10/20        _x86_64(2 CPU)

21:09:44     CPU    intr/s
21:09:44     all   2855.24
21:09:44       0    113.53
21:09:44       1   1887.97
mpstat是 Multiprocessor Statistics的缩写,是实时系统监控工具。其报告与CPU的一些统计信息,这些信息存放在/proc/stat文件中。
当mpstat不带参数时,输出为从系统启动以来的平均值
mpstat [-P {cpu|ALL}] [internal [count]]
internal 相邻的两次采样的间隔时间    
count 采样次数,只能和internal一起使用

-P { cpu [,...] | ON | ALL }   #表示监控哪个CPU, cpu在[0,cpu个数-1]中取值
-I { SUM | CPU | ALL }  查看cpu中断的统计 Report interrupts statistics
版权声明:本文由PHP面试资料网发布,如需转载请注明出处。
分享给朋友:

相关文章

linux中连接数过多(TIME_WAIT/CLOSE_WAIT)读这一篇就够了

根据TCP/IP介绍,socket大概包含10个连接状态。我们平常工作中遇到的,除了针对SYN的拒绝服务攻击,如果有异常,大概率是TIME_WAIT和CLOSE_WAIT的问题。TIME_WAIT一般...

快速删除复制代码中的行号

有时我们copy的代码中前面有行号,一个一个删除太麻烦可以用下面三种方式删除行号:1.awk操作 awk '{for(i=2;i<=NF;i++)printf(&qu...

内存分配堆与栈的区别

堆(Heap)与栈(Stack)是开发人员必须面对的两个概念,在理解这两个概念时,需要放到具体的场景下,因为不同场景下,堆与栈代表不同的含义。一般情况下,有两层含义:(1)程序内存布局场景下,堆与栈表...

Nginx中对同一IP限速限流DDOS预防

作用:Nginx通过limit_conn_zone和limit_req_zone对同一个IP地址进行限速限流,可防止DDOS/CC和flood攻击limit_conn_zone是限制同一个IP的连接数...






TCP(Transmission Control Protocol) 传输控制协议

三次握手

TCP是主机对主机层的传输控制协议,提供可靠的连接服务,采用三次握手确认建立一个连接:

位码即tcp标志位,有6种标示:

SYN(synchronous建立联机) 同步报文段

ACK(acknowledgement 确认)

PSH(push传送)

FIN(finish结束) 结束报文段

RST(reset重置) 复位报文段

URG(urgent紧急) 紧急指针

Sequence number(顺序号码)

Acknowledge number(确认号码)

客户端TCP状态迁移:

CLOSED->SYN_SENT->ESTABLISHED->FIN_WAIT_1->FIN_WAIT_2->TIME_WAIT->CLOSED

服务器TCP状态迁移:

CLOSED->LISTEN->SYN收到->ESTABLISHED->CLOSE_WAIT->LAST_ACK->CLOSED


各个状态的意义如下: 

LISTEN - 侦听来自远方TCP端口的连接请求; 

SYN-SENT -在发送连接请求后等待匹配的连接请求; 

SYN-RECEIVED - 在收到和发送一个连接请求后等待对连接请求的确认; 

ESTABLISHED- 代表一个打开的连接,数据可以传送给用户; 

FIN-WAIT-1 - 等待远程TCP的连接中断请求,或先前的连接中断请求的确认;

FIN-WAIT-2 - 从远程TCP等待连接中断请求; 

CLOSE-WAIT - 等待从本地用户发来的连接中断请求; 

CLOSING -等待远程TCP对连接中断的确认; 

LAST-ACK - 等待原来发向远程TCP的连接中断请求的确认; 

TIME-WAIT -等待足够的时间以确保远程TCP接收到连接中断请求的确认; 

CLOSED - 没有任何连接状态;


TCP/IP协议中,TCP协议提供可靠的连接服务,采用三次握手建立一个连接,如图1所示。

(1)第一次握手:建立连接时,客户端A发送SYN包(SYN=j)到服务器B,并进入SYN_SEND状态,等待服务器B确认。

(2)第二次握手:服务器B收到SYN包,必须确认客户A的SYN(ACK=j+1),同时自己也发送一个SYN包(SYN=k),即SYN+ACK包,此时服务器B进入SYN_RECV状态。

(3)第三次握手:客户端A收到服务器B的SYN+ACK包,向服务器B发送确认包ACK(ACK=k+1),此包发送完毕,客户端A和服务器B进入ESTABLISHED状态,完成三次握手。

完成三次握手,客户端与服务器开始传送数据。

确认号:其数值等于发送方的发送序号 +1(即接收方期望接收的下一个序列号)。

图1 TCP三次握手建立连接  


TCP协议中的三次握手和四次挥手

理解:窗口和滑动窗口TCP的流量控制TCP使用窗口机制进行流量控制什么是窗口?连接建立时,各端分配一块缓冲区用来存储接收的数据,并将缓冲区的尺寸发送给另一端接收方发送的确认信息中包含了自己剩余的缓冲区...

linux中nf_conntrack table full dropping packet问题处理

概述:在日常的服务器运维过程中,发现某段时间 /var/log/messages日志报错nf_conntrack:table full,drop packet简介:nf_connt...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。