步骤一:
需要在服务器安装Sreveragent,下面介绍serveragent的安装与配置
- 用XFTP工具讲serveragent.zip复制到服务器中,加压serveragent.zip。执行
unzip serveragent.zip
如果找不到unzip命令,那么可以先安装unzip,执行如下命令,下载并安装unzip命令与zip命令
sudo yum install -y unzip zip
不了加压完成后,进入命令找到startAgent.sh文件。./startAgent.sh
执行该文件,此时就会启动对服务器的监听,如果提示 Permission denide,表示没有执行该文件的权限,Linux中,一般红色为压缩文件或者链接,白色为普通文件,蓝色为文件夹,绿色为可执行文件。
#给最高权限
chmod 777 serveragent.sh
- 扩展:
数字权限法 1执行 2写入 4读写,百位的数字指向的是文件的所有者,十位的数字指向的是文件所在小组的用户,个位的数字指向的是小组外的其他用户。
serveragent的默认端口号是4444,可以输入netstat -tpln来查看它是否处于工作中。
步骤二:
-
Jmeter如果想要监控服务器,还需要安装插件,点击选项-->Plugins Manager进行安装
-
安装成功后在选择监听器
jp@gc-PerfMon Metrics Collector
插件选择完成后,填写监控数据Host/IP为监控的服务器地址,Port为Serveragent的端口号,Metric to Collect为监控的数据。还需要填写所有数据写入一个文件,填写文件格式为CSV后缀的文件。
-
上面内容填写成功后线程组的线程数和循环次数,这里要勾选持续时间,因为我们监控的是服务器一段时间内的数据。
-
现在直接运行Jmeter脚本会发现监控页面没有任何数据。这是因为4444端口被防火墙拦截了,可以将服务器的防火墙关闭(公司的服务器慎重操作,防止被攻击,我这操作的是虚拟机),
服务器防火墙的相关操作
systemctl stop firewalld #关闭防火墙
systemctl start firewalld #启动防火墙
systemctl status firewalld #查看防火墙运行状态
除了关闭防火墙的操作,还可以将4444端口加入白名单
firewall-cmd --add-port=4444/tcp --permanent #永久添加4444端口
firewall-cmd --list-ports #列出开放的端口
完成上列操作后,执行Jmeter脚本,可以看到成功监控到数据。
注意:如果需要监控网络,CPU和内存的数据会变得很大,这个是因为他们的数据被X100倍,我们看数据的时候需要除以100
我们在工作过程如果需要监控比较大的数据,可以单独在新增一个监听器jp@gc-PerfMon Metrics Collector
去监控
小技巧
执行 ./startAgent.sh
命令后需要在打开一个窗口
如果想只运行一个窗口可以执行后台运行命令,之后按下ctrl+c,即可后台运行
./serverAgent.sh&
后台运行的服务,如果想关闭,可以先执行。
netstat -tpln
找到服务的PID,然后执行kill -9进行删除