JMeter Sampler-http请求之KeepAlive使用总结

简介: JMeter Sampler-http请求之KeepAlive使用总结

Sampler-http请求之KeepAlive使用总结

测试环境

apache-jmeter-2.13

KeepAlive使用介绍

说明:

1、Use KeepAlive 勾上,则表示为求连接设置请求头Connection: keep-alive,该配置对默认的HTTP实现不起作用,因为连接重用不受用户控制,对Apache HTTP组件HttpClient起作用。

这个配置到底有啥用呢?

我们都知道,发起HTTP请求时,需要建立TCP连接,对于普通非keep-alive请求,即不包含请求头Connection: keep-alive的请求,请求完成后,会关闭该TCP连接,再次发起同类请求时,需要再次建立TCP连接,高并发的情况下,会增加服务器资源消耗,对于keep-alive请求,则会告诉服务器,HTTP请求结束后,在条件允许的情况下,保持TCP连接,下次发送请求时,使用上次建立的TCP连接进行数据传输。至此,这个配置有啥用,就不用我说了吧

2、注意,这里KeepAlive是针对同一个线程而言的,其使用效果受到多

方面影响,如下:

客户端

Http实现

HTTPClient4 使用Apache Http组件 HttpClient 4.x(推荐使用)

Java 使用JVM提供的HTTP实现。

空值 如果HTTP请求默认值配置元件中,Advanced选项卡中有设置非空请求客户端实现,则使用该客户端实现,否则使用jmter.properties文件中jmeter.httpsampler属性定义的客户端实现,否则使用默认的 HttpClient4。(原文:Blank value   does not set implementation on HTTP Samplers, so relies on HTTP Request Defaults if present or on jmeter.httpsampler property defined in jmeter.properties

注意:Java HTTP实现有以下限制:

  • 因为没有对连接重用做控制。所以,当连接被JMeter释放时,该连接可能被相同的线程重用,也可能不被重用。
  • 最适合单线程使用—各种设置都通过系统属性定义,因此作用于所有连接。
  • 通过代理处理HTTPS时存在bug(CONNECT未正确处理)。请参阅Java Bug 6226610和6208335。
  • 不支持虚拟主机。
  • 仅支持这些方法:GETPOSTHEADOPTIONSPUTDELETETRACE
  • 不支持使用密钥库配置进行基于客户端的证书测试。

JMeter配置

使用HTTPClient4实现时,连接重用还受到JMeter自身参数配置文件httpjmeter.propertieshttpclient4.time_to_live参数配置的影响,如下,该参数值以毫秒为单位,默认为2000,无论如何,http的生存时间,超过该参数值的连接,不会被重用。

httpclient4.time_to_live=2000

服务端

JMeter Use KeepAlive使用效果可能受到服务器相关配置影响,不同类型的服务器配置不一样,以Nginx为例子,和以下配置相关

keepalive_requests number 设置通过一条keep-alive连接可以服务的最大请求数。当请求数超过该指令设置的最大值时,连接将被关闭。

keepalive_time time 限制通过keep-alive连接发起的请求,可以被处理的最大时间,达到该时间,则关闭该连接

keepalive_timeout timeout;

timeout 设置keep-alive客户端连接在服务器端保持open状态时间,超过这个时间服务器将关闭连接。如果设置为0,那么禁用keep-alive客户端连接。

目录
相关文章
|
28天前
|
Rust 前端开发 API
Tauri 开发实践 — Tauri HTTP 请求开发
本文介绍了如何在 Tauri 中发起 HTTP 请求。首先通过安装 Tauri 生态中的工具包并配置 `tauri.conf.json` 文件来允许特定域名的 HTTP 通信。接着封装了一个简单的 HTTP 客户端类,并在页面中使用该客户端实现 GET 和 POST 请求。最后提供了完整的源码地址以供参考。此功能使得桌面应用能够与远程服务器进行交互,增强了应用的实用性。
75 1
Tauri 开发实践 — Tauri HTTP 请求开发
|
8天前
|
缓存 前端开发 API
|
13天前
|
数据采集 前端开发 算法
Python Requests 的高级使用技巧:应对复杂 HTTP 请求场景
本文介绍了如何使用 Python 的 `requests` 库应对复杂的 HTTP 请求场景,包括 Spider Trap(蜘蛛陷阱)、SESSION 访问限制和请求频率限制。通过代理、CSS 类链接数控制、多账号切换和限流算法等技术手段,提高爬虫的稳定性和效率,增强在反爬虫环境中的生存能力。文中提供了详细的代码示例,帮助读者掌握这些高级用法。
Python Requests 的高级使用技巧:应对复杂 HTTP 请求场景
|
1天前
|
前端开发 JavaScript Java
如何捕获和处理HTTP GET请求的异常
如何捕获和处理HTTP GET请求的异常
|
3天前
|
开发者
HTTP 协议请求方法的发展历程
【10月更文挑战第21天】
|
3天前
|
安全
HTTP 协议的请求方法
【10月更文挑战第21天】
|
3天前
|
缓存 安全 前端开发
HTTP 协议的请求方法在实际应用中有哪些注意事项?
【10月更文挑战第29天】HTTP协议的请求方法在实际应用中需要根据具体的业务场景和需求,合理选择和使用,并注意各种方法的特点和限制,以确保网络通信的安全、高效和数据的一致性。
|
7天前
|
安全 API 数据安全/隐私保护
常见的HTTP请求方法
【10月更文挑战第25天】这些HTTP请求方法共同构成了客户端与服务器之间交互的基础,使得客户端能够根据不同的需求对服务器资源进行各种操作。在实际应用中,开发者需要根据具体的业务场景和资源的性质选择合适的请求方法来实现客户端与服务器之间的有效通信。
|
13天前
|
网络协议
Lua中实现异步HTTP请求的方法
Lua中实现异步HTTP请求的方法
|
12天前
|
存储 安全 网络协议
HTTP 请求方法
【10月更文挑战第22天】HTTP 请求方法
21 2