问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

Linux系统监控要用到哪些命令

发布网友 发布时间:2022-04-30 22:46

我来回答

1个回答

热心网友 时间:2022-06-19 20:03

记录一下自己常用的linux系统命令,方便以后查阅,发觉记忆越来越不行了
找到最耗CPU的java线程ps命令
命令:ps -mp pid -o THREAD,tid,time 或者 ps -Lfp pid

结果展示:

这个命令的作用,主要是可以获取到对应一个进程下的线程的一些信息。 比如你想分析一下一个java进程的一些运行瓶颈点,可以通过该命令找到所有当前Thread的占用CPU的时间,也就是这里的最后一列。

比如这里找到了一个TID : 30834 ,所占用的TIME时间最高。

通过 printf "%x\n" 30834 首先转化成16进制, 继续通过jstack命令mp出当前的jvm进程的堆栈信息。 通过Grep命令即可以查到对应16进制的线程id信息,很快就可以找到对应最耗CPU的代码快在哪。

简单的解释下,jstack下这一串线程信息内容:

"DboServiceProcessor-4-thread-295" daemon prio=10 tid=0x00002aab047a9800 nid=0x7d9b waiting on condition [0x0000000046f66000]
nid : 对应的linux操作系统下的tid,就是前面转化的16进制数字

tid: 这个应该是jvm的jmm内存规范中的唯一地址定位,如果你详细分析jvm的一些内存数据时用得上,我自己还没到那种程度,所以先放下

top命令
命令:top -Hp pid

结果显示:

和前面的效果一下,你可以实时的跟踪并获取指定进程中最耗cpu的线程。 再用前面的方法提取到对应的线程堆栈信息。

判断I/O瓶颈

mpstat命令
命令:mpstat -P ALL 1 1000

结果显示:

注意一下这里面的%iowait列,CPU等待I/O操作所花费的时间。这个值持续很高通常可能是I/O瓶颈所导致的。

通过这个参数可以比较直观的看出当前的I/O操作是否存在瓶颈

iostat命令
命令: iostat -m -x 1 1000

同样你可以观察对应的CPU中的%iowait数据,除此之外iostat还提供了一些更详细的I/O状态数据,比如比较重要的有:

avgqu-sz : The average queue length of the requests that were issued to the device. (磁盘队列的请求长度,正常的话2,3比较好。可以和cpu的load一样的理解)

await : The average time (in milliseconds) for I/O requests issued to the device to be served. (代表一个I/O操作从wait到完成的总时间)

svctm和%util都是代表处理该I/O请求花费的时间和CPU的时间比例。 判断是否瓶颈时,这两个参数不是主要的

r/s w/s 和 rMB/s wMB/s 都是代表当前系统处理的I/O的一些状态,前者是我们常说的tps,后者就是吞吐量。这也是评价一个系统的性能指标

pid命令
命令: pidstat -p pid -u -d -t -w -h 1 1000

结果显示:

相当实用的一个命令,可以基于当个进程分析对应的性能数据,包括CPU,I/O,IR , CS等,可以方便开发者更加精细化的观察系统的运行状态。不过pidstat貌似是在2.6内核的一些较新的版本才有,需要安装sysstat包。

ubuntu下,可以通过sudo apt-get install sysstat进行安装。

sar命令
命令:sar -x pid 1 1000

sar也可以指定对应的pid,关注固定的几个参数,没有pidstat那么强大。 看不到对应的I/O, IR等信息。

sar的功能可以覆盖mpstat , iostat的相关功能。

dstat命令
命令:dstat -y --tcp 1 1000

通过dstat --tcp可以比较方便的看到当前的tcp的各种状态,不需要每次netstat -nat去看

其他命令
netstat -natp : 查看对应的网络链接,关注下Recv-Q , Send-Q , State。

lsof -p pid : 查找对应pid的文件句柄

lsof -i : 80 : 查找对应端口被哪个进程占用

lsof /tmp/1.txt :查找对应文件被哪个进程占用

tcpmp / wireshark :抓包分析工具

jstat / jmap / jstack / jps 等一系列的java监控命令

最后
如果你想做一些性能调优的工作,一定要善于利用一些工具进行关注相应的状态。通过linux命令你可以比较方便的观测到CPU , I/O , network等一些比较外围的状态, 很多时候就已经可以解决大部分的问题。jvm内部的一些运行状态监控,得需要借助一些特有的工具进行细粒度的观测。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
...爱你你是我的罗密欧 , 我愿意变成你的朱丽叶' 谁知 有句歌词是“我爱你你是我的朱丽叶,我愿意变成你的梁山伯”是哪... 为什么打印出来的文档页码和原来的不一样 ...两台电脑用路由器上网一台是W7一台是XP如何实现两台电脑共享文件 win7怎么联另一台电脑win7怎么让网络和另一台电脑共享 w7的系统怎么共享电脑w7系统里面文件怎么共享另一台电脑 共享win7电脑w7系统里面文件怎么共享另一台电脑 翡翠有收藏价值吗,我们玩家如何去投资 价格一两万元的翡翠如何挑选 ppt怎么转换成视频?简单四步法,轻松搞定ppt微课录制 命令行使用ant脚本编译时出现OutOfMemoryError: GC overhead limit exceeded 白衣服沾上咖喱汁如何清洗? 写sql语句时应注意什么,怎样才能写好sql? 怎样保存视频到手机上 白色衣服上的咖喱汁怎么洗掉?家里没有那些化学试剂 王者荣耀两个切换时为什么不提示选择号的图像 换了,怎么把原来的王者荣耀数据移动到新上面来 怎么把一个王者号转移到另一个? 有俩个玩王者荣耀怎么切换?- 问一问 3月份还有草莓吗? 草莓种植如何巧施捕食螨 首次飞入太空的宇航员是谁 航天员飞上太空的工具有哪些? 在编写sql查询语句关于性能方面有哪些注意 涨姿势!第一位航天员是怎么飞上太空的? 宇航员进入太空的步骤是怎样的? 好看的种田文,重生小地主看过了。 女生喜欢看的重生之类的田园小说,像重生小地主之类的! 类似重生小地主的小说 找几篇 篇幅比较长的 关于田园生活的小说, 类似重生小地主 田园风光类型的 自驾游去龙口南山旅游景区的路线是什么 websphere自带jdk能使用jps,jstat等命令吗 重庆南山风景区旅游路线 烟台南山大佛的门票,里面有什么好玩的,从潍坊自驾游路线怎么走啊? 下面哪个命令常用于监测jvm各区内存分配,占用及gc信息 我要去溧阳南山竹海去玩,我住在新北区,请问自驾游路线怎么走?谢谢! 南京到南山竹海自驾路线 桂林 湖南南山自驾游 山东龙口南山区自驾游到秦皇岛需要多少小时多少公里 想知道烟台南山大佛有什么好玩的,周边有什么好的景区,还有希望有潍坊到景区的自驾路线 从天目湖到南山竹海自驾路线 三亚高铁站在哪?从南山旅游区去大概多少公里? 办公软件中.word.excel.poweroint用英语如何念这三个词 小白求助如何卸载debian Word,Excel,PowerPoint用英语怎么说 晋城巴公南山村自驾游线路 Debian要怎样才能彻底卸载文件 ERP,Word、Excel和PPT怎么读 debian 8 如何移除无用软件,如gnome版中的内置游戏等 word excel ppt阅读模式