news 2026/6/25 17:27:13

第2节:项目性能优化(中)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
第2节:项目性能优化(中)

Jmeter插件使用

首先我们安装完插件配置后,要在插件中心安装这两个插件

下载成功后出现以下结果:

响应时间

  • 响应时间:jp@gc - Response Times Over Time

活动线程数

  • 活动线程数:jp@gc - Active Threads Over Time

每秒事务数

  • 每秒事务数:jp@gc - Transactions per Second

  1. RT(响应时间)
    • 平均值:332ms
    • P50(中位数):8ms 内
    • P90:514ms 内
    • P95:1051ms 内
    • P99:6797ms 内
    • 最小值:2ms
    • 最大值:35s
  1. 压力机活动线程数
    • 代表压测过程中施加的压力情况
  1. TPS(每秒事务数)
    • 数值越大,性能越好
  1. QPS(每秒查询数量)
    • 数值越大,性能越好
    • (TPS >= QPS)
  1. 吞吐量(每秒请求数量)
    • 数值越大,性能越好

压测监控平台

压测平台架构图:

Docker环境配置

首先我们需要配置docker环境

# 1.更新yum包 sudo yum update -y # 2.安装软件包 sudo yum install -y yum-utils device-mapper-persistent-data lvm2 # 3.设置yum源为阿里云 sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo # 4.安装docker sudo yum install docker-ce # 5.检查docker版本 docker -v

安装InfluxDB

# 1.下载镜像 docker pull influxdb:1.8 # 2.启动容器 docker run -d --name influxdb -p 8086:8086 -p 8083:8083 influxdb:1.8 # 3.进入容器创建jmeter数据库 docker exec -it influxdb /bin/bash

操作influxDB

# 进入操作界面 influx # 创建数据库 create database jmeter # 查看数据库是否创建成功 show databases

创建完的结果为

Connected to http://localhost:8086 version 1.8.10 InfluxDB shell version: 1.8.10 > create database jmeter > show databases name: databases name ---- _internal jmeter >

使用influxDB

# 使用jmeter库 use jmeter # 查询数据库中的数据 select * from jmeter

设置Jmeter脚本后置监听器

  • influxdbUrl:需要改为自己influxdb的部署ip和映射端口,我这里是部署在阿里云服务器,所以就是47.93.59.248,口是容器启动时映射的8086端口,db后面跟的是刚才创建的数据库名称
  • application:可根据需要自由定义,只是注意后面在 grafana 中选对即可
  • measurement:表名,默认是 jmeter ,也可以自定义
  • summaryOnly:选择true的话就只有总体的数据。false会记录总体数据,然后再将每个transaction都分别记录
  • samplersRegex:样本正则表达式,将匹配的样本发送到数据库
  • percentiles:响应时间的百分位P90、P95、P99
  • testTitle:events表中的text字段的内容
  • eventTags:任务标签,配合Grafana一起使用

然后我们启动压测工具,再查看数据库表,发现出现以下结构

安装Grafana

# 1.下载Grafana镜像 docker pull grafana/grafana # 2.启动Grafana容器 docker run -d --name grafana -p 3000:3000 grafana/grafana

访问连接:http://guslegend:3000/login,默认用户名/密码:admin/admin

选择添加数据源

导入模版

  • 直接输入模版id号;
  • 上传模版json文件;
  • 输入模版json内容;

在Grafana的官网找到我们需要的展示模板

  • Apache JMeter Dashboard
    • dashboad-ID:5496
  • JMeter Dashboard(3.2 and up)
    • dashboad-ID:3351

启动压测工具,查看结果

安装node_exporter

# 下载 wget -c https://github.com/prometheus/node_exporter/releases/download/v0.18.1/node_exporter-0.18.1.linux-amd64.tar.gz # 解压 tar zxvf node_exporter-0.18.1.linux-amd64.tar.gz -C /usr/local/hero/ # 启动 cd /usr/local/hero/node_exporter-0.18.1.linux-amd64 nohup ./node_exporter > node.log 2>&1 &

安装Prometheus

# 下载 wget -c https://github.com/prometheus/prometheus/releases/download/v2.15.1/prometheus-2.15.1.linux-amd64.tar.gz # 解压 mkdir /usr/local/hero/ tar zxvf prometheus-2.15.2.linux-amd64.tar.gz -C /usr/local/hero/ cd prometheus-2.15.2.linux-amd64 # 运行 nohup ./prometheus > prometheus.log 2>&1 &

配置prometheus.yml文件

# my global config global: scrape_interval: 15s # Set the scrape interval to every 15 seconds. Default is every 1 minute. evaluation_interval: 15s # Evaluate rules every 15 seconds. The default is every 1 minute. # scrape_timeout is set to the global default (10s). # Alertmanager configuration alerting: alertmanagers: - static_configs: - targets: # - alertmanager:9093 # Load rules once and periodically evaluate them according to the global 'evaluation_interval'. rule_files: # - "first_rules.yml" # - "second_rules.yml" # A scrape configuration containing exactly one endpoint to scrape: # Here it's Prometheus itself. scrape_configs: # The job name is added as a label `job=<job_name>` to any timeseries scraped from this config. - job_name: 'hero-Linux' static_configs: - targets: ['172.17.0.1:9100','172.17.0.1:9100','172.17.0.1:9100']

访问:http://guslegend:9090/graph

在Grafana中配置Prometheus的数据源

导入Linux系统dashboard

  • Node Exporter for Prometheus Dashboard EN 20201010
    • dashboard-ID: 11074
  • Node Exporter Dashboard
    • dashboard-ID: 16098

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/25 3:02:50

影刀RPA一键批量上传Zozone商品视频,效率提升800%![特殊字符]

影刀RPA一键批量上传Zozone商品视频&#xff0c;效率提升800%&#xff01;&#x1f680;还在手动一个个上传商品视频&#xff1f;每天重复选择文件、填写信息、等待上传&#xff0c;浪费生命又容易出错&#xff1f;今天带你用影刀RPA实现视频批量上传自动化&#xff0c;100个视…

作者头像 李华
网站建设 2026/6/25 16:13:32

【精准护理新标准】:基于患者行为画像的自适应提醒频率算法详解

第一章&#xff1a;精准护理中提醒频率的演进与挑战在数字化医疗快速发展的背景下&#xff0c;精准护理中的提醒频率管理已成为提升患者依从性与治疗效果的关键环节。早期的提醒系统多依赖固定周期通知&#xff0c;如每日定时发送用药提醒&#xff0c;缺乏对个体差异和临床情境…

作者头像 李华
网站建设 2026/6/24 17:57:34

【气象建模必看】:4类Agent模型精度、效率、稳定性全面对比

第一章&#xff1a;气象建模中Agent模型的发展背景与挑战 在复杂系统模拟领域&#xff0c;气象建模长期依赖于偏微分方程和网格化数值方法。然而&#xff0c;随着计算能力的提升与对局部动态行为关注的加深&#xff0c;基于智能体&#xff08;Agent-Based Model, ABM&#xff0…

作者头像 李华
网站建设 2026/6/24 20:44:19

收藏速看!LangGraph1.0入门宝典—— 核心概念与“点边”实战

对于刚入门大模型开发的程序员来说&#xff0c;LangGraph 绝对是值得深耕的框架——它不是简单的工具封装&#xff0c;而是一套能让你“编程式构建智能体”的强大体系。这篇文章作为 LangGraph1.0 系列的开篇&#xff0c;会用最直观的方式拆解核心概念&#xff0c;再通过完整代…

作者头像 李华
网站建设 2026/6/24 21:35:13

小程序毕设项目推荐-基于springboot的“智宠”一站式宠物服务小程序的设计与实现宠物信息管理、服务预约、订单管理、商品管理【附源码+文档,调试定制服务】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/6/25 16:19:30

RabbitMQ 5 大核心模式详解(一):简单模式 工作队列模式

RabbitMQ 作为一款高性能的开源消息队列&#xff0c;基于 AMQP&#xff08;高级消息队列协议&#xff09;实现&#xff0c;凭借其轻量级、高可用、易扩展的特性&#xff0c;被广泛应用于分布式系统的解耦、异步通信、流量削峰等场景。RabbitMQ 的核心能力体现在多种消息投递模式…

作者头像 李华