Gatling介绍

Gatling:基于Scala的高性能负载测试工具

一、Gatling 简介

Gatling 是一个开源的 HTTP 压力测试工具,专为高并发场景设计,支持 HTTP/HTTPS、WebSocket、Kafka 等协议。其基于 Scala 的脚本语法简洁高效,支持实时报告生成和分布式测试。

核心特性:

  • 轻量级:无 GUI,通过代码脚本定义测试场景
  • 高性能:支持每秒数万次请求
  • 实时监控:基于 HTML 的动态报告
  • 协议扩展:支持自定义 DSL 和插件

二、安装指南

1. 基于 SBT 安装(推荐)

python 复制代码
# 下载 Gatling 最新版本
wget https://repo1.maven.org/maven2/io/gatling/highcharts/gatling.highcharts_2.13/3.7.0/gatling.highcharts_2.13-3.7.0.zip

# 解压并进入目录
unzip gatling.highcharts_2.13-3.7.0.zip
cd gatling.highcharts_2.13-3.7.0

# 启动 Gatling
bin/gatling.sh -s your_test_script.scala

2. Docker 快速启动

docker run -d -p 8080:8080 denvazh/gatling

三、基础使用说明

1. 编写测试脚本

示例脚本(BasicSimulation.scala):

python 复制代码
import io.gatling.core.Predef._
import io.gatling.http.Predef._

class BasicSimulation extends Simulation {
  val httpProtocol = http
    .baseUrl("https://example.com")

  val scn = scenario("Basic Test")
    .exec(http("Request Page")
      .get("/"))

  setUp(
    scn.inject(atOnceUsers(100))
  ).protocols(httpProtocol)
}

2. 执行测试

python 复制代码
# 运行测试并生成报告
bin/gatling.sh -s BasicSimulation.scala -rf report -of html

# 查看实时报告
open report/index.html

3. 结果分析

关键指标:

指标 说明
Requests per second 每秒请求数(RPS)
Average response time 平均响应时间(ms)
Error rate 错误率

四、高级配置

1. 参数化测试数据

使用 CSV 文件:

python 复制代码
val feeder = csv("user_data.csv")

exec(http("Login")
  .post("/login")
  .body(StringBodyFromFile("data/${username}"))
  .asJson)

2. 分布式测试

启动 Master 节点:

python 复制代码
bin/gatling.sh -master -localPort 26201 -remotePort 26202

启动 Slave 节点:

bin/gatling.sh -slave -masterHost master_ip -masterPort 26201

五、典型应用场景

  1. Web API 性能测试

    • 模拟高并发用户访问电商网站
    • 验证限时抢购接口稳定性
  2. 微服务压力测试

    • 测试 Kafka 消息队列吞吐量
    • 验证 gRPC 服务在高负载下的表现
相关推荐
可涵不会debug1 小时前
Selenium自动化测试秘籍:解锁常用函数实战指南
python·功能测试·selenium·测试工具·单元测试·模块测试
程序员小远5 小时前
Jmeter接口测试与性能测试
自动化测试·软件测试·测试工具·jmeter·职场和发展·接口测试·性能测试
互联网杂货铺13 小时前
Jmeter基础知识总结
自动化测试·软件测试·python·测试工具·jmeter·职场和发展·测试用例
HoneyMoose17 小时前
周报——服从性测试工具
测试工具
树莓集团17 小时前
树莓百度百科更新!宜宾园区业务再添新篇
百度
微尘hjx18 小时前
【Wireshark 02】抓包过滤方法
网络·测试工具·wireshark
测试笔记(自看)20 小时前
postman上一个接口返回值作为下一个接口的入参
测试工具·lua·postman
互联网杂货铺20 小时前
Postman接口测试工具使用
自动化测试·软件测试·测试工具·职场和发展·测试用例·接口测试·postman
亿牛云爬虫专家1 天前
动态内容加载的解决方案:Selenium与Playwright对比故障排查实录
selenium·测试工具·爬虫代理·playwright·机票·特价·亚航