nginx配置keepalive长连接

nginx之keepalive详解与其配置_keepalive_timeout_恒者走天下的博客-CSDN博客

为什么要有keepalive?

因为每次建立tcp都要建立三次握手,消耗时间较长,所以为了减少tcp建立连接需要的时间,就可以设置keep_alive长连接。

nginx中keep_alive对客户端的配置

keepalived_disable 禁用某些浏览器

keepalive_request:在我们的tcp连接中并不是等一个请求处理完成后再继续下一个请求,而是进行异步请求,也就是说一个tcp连接可以进行很多个请求。这个参数默认1000,已经完全够用了。

send_request:tcp建立连接后,服务端在准备数据过程中的时间,如果超过设定的时间,则断开连接。

keepalive_timeout:tcp连接过程超过这个设定的时间,则断开连接。

keepalive_time:tcp连接最长时间。(不能让客户端无限复用tcp连接)

nginx对上游后端服务的keepalive

配置目的:在nginx与上有服务器连接的时候,通过配置keepalive达到连接复用,提高传输效率。

在upstream服务器列表中可配置的参数:

keepalive:可支持线程个数

keepalive_requests: 每个线程可以并发多少TCP连接数

keepalive_timeout:连接保留时间

在server中配置的参数:

proxy_http_version:1.1; 设置http版本,默认情况下是http1.0版本像后端服务发起请求,1.0发起每次请求后会关闭连接,下次发起请求后会再次建立连接,消耗时间。

proxy_set_header Connection ""; 由nginx向后端服务器发送请求时,Connection参数默认是close关闭状态,那么就不会和后端服务器建立长连接keepalive,这个参数意思是将nginx发送到后端的header的Connection参数设置成空或者设置成keepalive,那么就支持keepalive长连接(http1.1默认支持长连接)。

用ab压力测试工具对nginx的keepalive参数调优前后性能进行对比

安装ab压力测试工具

yum install httpd-tools -y

ab工具直接对nginx服务器进行压力测试

1.先对后端服务器直接进行压力测试

-n:请求数

-c:并发数

ab -n 10000 -c 30 http://192.168.44.120/

Transfer rate:吞吐量速率,每秒下载速率

Requests per second(qps): 每秒并发量

2.对nginx代理服务器进行ab压力测试(不加keepalive长连接配置)

可以看到经过nginx代理后,吞吐量和qps并发量都大幅度下降。这是因为经过代理后nginx需要再与后端服务器进行数据传输,而且没有加长连接配置,所以性能下降。

3.对nginx代理服务器进行ab压力测试(添加keepalive长连接配置)

添加配置

观察效果:

并发量和吞吐量都有提升,响应延迟下降。证明keepalive配置有对请求效率进行有效的优化。

用ab压力测试工具对nginx的keepalive参数调优前后性能进行对比(后端是tomcat)

用ab直连测试tomcat,性能居中

用ab加nginx(无keepalive)代理测试tomcat,性能比直连稍低

用ab加nginx(keepalive)代理测试tomcat,性能比直连大幅提高

结论:所以再tomcat前加nginx代理绝对不仅仅是为了做动静分离和负载均衡,也是为了keepalive做性能优化提升并发量。

注:

有一些特殊的场景比如客户端浏览器不支持keepalive,或者只是通过暴露tomcat接口进行访问的形式可以通过nginx添加代理keepalive进行调优,一般的浏览器是带有keepalive的,所以一般也不需要通过nginx去做tomcat的keepalive性能调优

相关推荐
JY.yuyu31 分钟前
Docker常用命令——数据卷管理 / 端口映射 / 容器互联
运维·docker·容器
alice--小文子1 小时前
cursor-mcp工具使用
java·服务器·前端
lpruoyu1 小时前
【Docker进阶-06】docker-compose & docker swarm
运维·docker·容器
China_Yanhy2 小时前
入职 Web3 运维日记 · 第 8 日:黑暗森林 —— 对抗 MEV 机器人的“三明治攻击”
运维·机器人·web3
艾莉丝努力练剑2 小时前
hixl vs NCCL:昇腾生态通信库的独特优势分析
运维·c++·人工智能·cann
酉鬼女又兒2 小时前
每天一个Linux命令_printf
linux·运维·服务器
翼龙云_cloud2 小时前
国际云代理商:2026年国际云注册风控升级实战指南 8 大平台无卡解决方案对比
服务器·阿里云·云计算
虾说羊2 小时前
docker容器化部署项目流程
运维·docker·容器
Trouvaille ~2 小时前
TCP Socket编程实战(三):线程池优化与TCP编程最佳实践
linux·运维·服务器·网络·c++·网络协议·tcp/ip
大大大反派2 小时前
CANN 生态中的自动化部署引擎:深入 `mindx-sdk` 项目构建端到端 AI 应用
运维·人工智能·自动化