在Gatling中实现自动下载HTML页面关联的CSS、JS等静态资源,主要通过资源推断功能来实现,目的是高保真地模拟真实浏览器行为,来进行准确的性能测试。
机制:资源推断和自动请求
Gatling在协议层面提供了.inferHtmlResources()方法。启用后,当脚本执行一个返回HTML内容的请求(例如访问一个页面)时,Gatling会自动解析该HTML文档,并从中提取出需要下载的关联资源链接,如<script src="...">、<link rel="stylesheet" href="...">和<img src="...">。之后会为每个提取出的资源链接自动发起并发的HTTP请求进行下载。
配置
以下是启用和优化此功能的具体配置方法。
启用资源推断
可以在协议(httpProtocol)级别全局启用,也可以在单个请求级别启用。
协议级全局启用:此配置会对该协议下的所有请求生效。
scala
val httpProtocol = http
.baseUrl("https://your-website.com")
.inferHtmlResources() // 全局启用资源推断
请求级启用:更推荐此方式,可以更精确地控制。通常只为返回HTML页面的关键请求启用,避免不必要的资源解析。
scala
exec(http("访问首页")
.get("/")
.inferHtmlResources() // 仅对此请求启用
)
资源过滤和静默
自动下载的资源请求可能会在测试报告中产生大量没必要的资源。Gatling提供了两种方式优化报告:
静默特定资源:使用silentUri方法,通过正则表达式匹配URI,使匹配的请求不在报告中单独统计。这常用于过滤图片、样式表等静态资源。
scala
val httpProtocol = http
.silentUri(".*\\.(css|js|png|jpg|gif|ico).*") // 使常见静态资源请求在报告中静默
静默所有推断资源:设置silentResources = true,可以使所有通过.inferHtmlResources()下载的资源(即非顶级请求)自动静默。
连接和并发优化
为了更真实地模拟浏览器行为(如对同一主机建立多个并发连接),可能需要调整连接池设置。
scala
val httpProtocol = http
.inferHtmlResources()
.maxConnectionsPerHost(6) // 模拟现代浏览器,每个用户对每个主机最多6个并发连接
完整配置示例
以下是一个整合了上述要点的实战配置示例,其中包含了重要的HTTP协议配置,如设置基础URL、启用HTTP/2支持和异步DNS解析。
scala
import io.gatling.core.Predef._
import io.gatling.http.Predef._
import scala.concurrent.duration._
class WebPageSimulation extends Simulation {
val httpProtocol = http
.baseUrl("https://your-website.com")
.enableHttp2 // 启用HTTP/2支持[citation:9]
.acceptHeader("text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8")
.userAgentHeader("Mozilla/5.0 (兼容; Gatling)")
.silentUri(".*\\.(css|js|png|jpg|gif|ico|woff2?).*") // 过滤静态资源报告噪音[citation:9]
.asyncNameResolution("8.8.8.8") // 使用异步DNS解析提升性能[citation:9]
val scn = scenario("浏览网站")
.exec(
http("访问商品列表页")
.get("/products")
.inferHtmlResources() // 为此页面启用自动资源下载
.check(status.is(200))
)
.pause(2 seconds)
.exec(
http("访问商品详情页")
.get("/product/123")
.inferHtmlResources() // 为此页面启用自动资源下载
.check(status.is(200))
)
setUp(
scn.inject(rampUsers(100).during(30 seconds))
).protocols(httpProtocol)
}
注意事项
非浏览器:Gatling在HTTP协议层面工作,不会执行JavaScript、渲染页面或触发由JS动态加载的资源。只解析初始HTML响应中的静态链接。
缓存模拟:默认情况下,Gatling会启用缓存模拟(遵循Cache-Control等头部)。在测试时,你可以通过.disableCaching来禁用,来模拟所有用户都首次访问的场景。
资源白名单和黑名单:如果需要更精细的控制(如排除特定第三方域名资源),可以在.inferHtmlResources()方法内使用WhiteList()或BlackList()参数进行配置。