专栏首页北京宏哥Jmeter(四十八) - 从入门到精通高级篇 - Jmeter监控服务器性能(详解教程)

Jmeter(四十八) - 从入门到精通高级篇 - Jmeter监控服务器性能(详解教程)

1.简介

JMeter是一款压力、接口等等的测试工具,Jmeter也可以像loadrunner一样监控服务器CPU、内存等性能参数,用来监控服务器资源使用情况,不过需要安装一些插件。JMeter正常自带可以通过Tomcat的/manager/status来监控服务资源使用情况。这种情况只能监控Tomcat支持的资源使用部分。 通过本文宏哥主要来说一下如何通过JMeter插件来监控服务器CPU、内存(Memory)、磁盘(DisKs I/O)、网络(NetWork I/O)等相关资源。

2.下载Jmeter插件

既然监控需要一些插件,那么宏哥就将准备工作做好了,下载安装需要的插件。 JMeter 插件网址:https://jmeter-plugins.org/downloads/old/

其中JMeterPlugins-Standard和JMeterPlugins-Extras是客户端的(Jmeter插件),ServerAgent是服务端的(放在服务器中的)。

3.解压并安装

1、解压客户端的两个文件,进入其路径JMeterPlugins-Extras(Standard)-1.3.1\lib\ext,复制JmeterPlugins-Extras.jar(JmeterPlugins-Standard.jar)两个文件,放到你安装JMeter客户端的lib/ext文件夹中,打开JMeter,可在监听器中看到Permon Metrics Collector,客户端配置成功。如下图所示:

2、将ServerAgent-2.2.1.jar上传到被监控的服务器,待用。如下图所示:

Windows服务器:

Linux服务器:

4.监控

1、启动客户端的Jmeter,然后添加jp@gc - PerfMon Metrics Collector监听器,并增加你要监控的参数。如下图所示:

2、解压刚刚复制到服务器待用的压缩包,进入目录,Windows环境,双击ServerAgent.bat启动;linux环境执ServerAgent.sh启动,默认使用4444端口,出现如下情况即服务端成功。如下图所示:

Windows环境:

Linux环境:

3、运行Jmeter-观察server日志即chart图标内容,如下图所示:

4、ServerAgent端的日志,如下图所示:

Windows服务器:

Linux服务器:

5、从第三步和第四步可以看出接收了一个TCP的链接,没有反应卡住不懂了,宏哥记得以前做的时候不是这个样子的,后来查看客户端的Jmeter发现报错了,如下图所示:

6、报错信息:java.lang.NoSuchMethodError: org.apache.jmeter.samplers.SampleSaveConfiguration.setFormatter(Ljava/text/DateFormat;)V ,查找资料发现是因为Jmeter的版本太高了,不支持其中一个方法了。jmeter版本太高,setFormatter方法在3.1版本后不支持。但是插件没有高版本,只能卸载5.1重装3.1。重装后成功。再次查看ServerAgent端的日志,如下图所示:

INFO    2021-05-28 09:27:46.540 [kg.apc.p] (): Accepting new TCP connection  #成功连接
INFO    2021-05-28 09:27:46.543 [kg.apc.p] (): Yep, we received the 'test' command   #接收到test消息
INFO    2021-05-28 09:27:46.547 [kg.apc.p] (): Starting measures: cpu:
INFO    2021-05-28 09:27:46.801 [kg.apc.p] (): Client disconnected   #断开连接

7、从上边的日志信息可以看出,运行jmeter时,成功连接然后立刻断开了,并没有获取我们想要的数据。猜想需要一个时间控制的元器件,使其能够获取一段时间的数据。

i 步骤:添加线程组(不添加发送请求),设置循环次数为永远,点击运行。 结果:成功连接然后立刻断开。全部配置如下图所示:

ServerAgent端的日志,如下图所示:

INFO    2021-05-28 09:37:00.520 [kg.apc.p] (): Accepting new TCP connection
INFO    2021-05-28 09:37:00.521 [kg.apc.p] (): Yep, we received the 'test' command
INFO    2021-05-28 09:37:00.523 [kg.apc.p] (): Starting measures: cpu:
INFO    2021-05-28 09:37:00.653 [kg.apc.p] (): Client disconnected

Jmeter客户端配置,如下图所示:

chart图,如下图所示:

ii 添加线程组,设置循环次数为"永远";为线程组任意添加一个Sampler(并不设置参数);添加一个PerfMon Metrics Collector监听器;点击运行。 结果:成功获取chart图,点击stop,即结束监听数据。全部配置如下图所示:

ServerAgent端的日志,如下图所示:

INFO 2021-05-28 10:02:57.150 [kg.apc.p] (): Accepting new TCP connection
INFO    2021-05-28 10:02:57.152 [kg.apc.p] (): Yep, we received the 'test' command
INFO    2021-05-28 10:02:57.154 [kg.apc.p] (): Starting measures: cpu:  network i/o:    disks i/o:
INFO    2021-05-28 10:03:05.465 [kg.apc.p] (): Client disconnected

Jmeter客户端配置,如下图所示:

chart图,如下图所示:

5.小结

1、运行 ServerAgent-2.2.1\bin\startAgent.bat(Linux使用startAgent.sh)(默认端口为4444,也可以参数指定 –udp-port 4445 –tcp-port 4445)

2、常用组件简要介绍: ① jp@gc - Bytes Throughput Over Time:不同时间吞吐量展示(图表) 聚合报告里,Throughput是按请求个数来展示的,比如说1.9/sec,就是每s发送1.9个请求;而这里的展示是按字节Bytes来展示的图表 ② jp@gc - Composite Graph: 混合图表 在它的Graphs里面可以设置多少个图表一起展示,它可以同时展示多个图表 ③ jp@gc - Hits per Second:每秒点击量 ④ jp@gc - PerfMon Metrics Collector:服务器性能监测控件,包括CPU,Memory,Network,I/O等等 ⑤ jp@gc - Reponse Latencies Over Time:记录客户端发送请求完成后,服务器端返回请求之前这段时间 ⑥ jp@gc - Reponse Times Distribution: 显示测试的响应时间分布,X轴显示由时间间隔分组的响应时间,Y轴包含每个区间的样本数 ⑦ jp@gc - Transactions per Second: 每秒事务数,服务器每秒处理的事务数

  最后为了省去大家查找和下载软件的时间,小伙伴或者童鞋们微信搜索“北京宏哥”,关注宏哥公众号,进入公众号发送“jmeter监控”,获取Jmeter服务器监控全家桶相关软件和插件。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Jmeter(四十九) - 从入门到精通高级篇 - jmeter使用监视器结果监控tomcat性能(详解教程)

    上一篇宏哥讲解了利用jmeter的插件来监控服务器资源,这一篇讲解分享如何使用jmeter的监视器结果监控tomcat性能。

    北京-宏哥
  • Jmeter(十九) - 从入门到精通 - JMeter监听器 -上篇(详解教程)

      监听器用来监听及显示JMeter取样器测试结果,能够以树、表及图形形式显示测试结果,也可以以文件方式保存测试结果,JMeter测试结果文件格式多样,比如XM...

    北京-宏哥
  • Jmeter(二十) - 从入门到精通 - JMeter监听器 -下篇(详解教程)

      监听器用来监听及显示JMeter取样器测试结果,能够以树、表及图形形式显示测试结果,也可以以文件方式保存测试结果,JMeter测试结果文件格式多样,比如XM...

    北京-宏哥
  • Jmeter(十四) - 从入门到精通 - JMeter定时器 - 下篇(详解教程)

      用户实际操作时,并非是连续点击,而是存在很多停顿的情况,例如:用户需要时间阅读文字内容、填表、或者查找正确的链接等。为了模拟用户实际情况,在性能测试中我们需...

    北京-宏哥
  • Jmeter(十) - 从入门到精通 - JMeter逻辑控制器 - 中篇(详解教程)

    Jmeter官网对逻辑控制器的解释是:“Logic Controllers determine the order in which Samplers are ...

    北京-宏哥
  • Jmeter(十八) - 从入门到精通 - JMeter后置处理器 -下篇(详解教程)

    后置处理器是在发出“取样器请求”之后执行一些操作。取样器用来模拟用户请求,有时候服务器的响应数据在后续请求中需要用到,我们的势必要对这些响应数据进行处理,后置处...

    北京-宏哥
  • Jmeter(二十四) - 从入门到精通 - JMeter函数 - 中篇(详解教程)

      在性能测试中为了真实模拟用户请求,往往我们需要让提交的表单内容每次都发生变化,这个过程叫做参数化。JMeter配置元件与前置处理器都能帮助我们进行参数化,但...

    北京-宏哥
  • Jmeter(四十五) - 从入门到精通高级篇 - Jmeter之网页爬虫-上篇(详解教程)

      上大学的时候,第一次听同学说网页爬虫,当时比较幼稚和懵懂,觉得就是几只电子虫子爬在网页上在抓取东西。后来又听说写代码可以实现网页爬虫,宏哥感觉高大上,后来工...

    北京-宏哥
  • Jmeter(十二) - 从入门到精通 - JMeter逻辑控制器 - 终篇(详解教程)

    Jmeter官网对逻辑控制器的解释是:“Logic Controllers determine the order in which Samplers are ...

    北京-宏哥

扫码关注云+社区

领取腾讯云代金券