网站首页 > 精选教程 正文
用 Spring Boot 搭建完 Spring Cloud 微服务项目后,又用 Nginx 为 Spring Gateway 做了负载均衡,其中做了并发限制和每秒连接数限制,Nginx 的配置如下:
worker_processes 1;
events {
worker_connections 1024;
}
?
http {
include mime.types;
default_type application/octet-stream;
?
sendfile on;
?
keepalive_timeout 65;
?
gzip on;
# 开启令牌桶 - 每秒新增 100 个令牌
limit_req_zone $binary_remote_addr zone=req_one:10m rate=100r/s;
# 开启每个 IP 的并发设置
limit_conn_zone $binary_remote_addr zone=perip:10m;
# 开启服务器的总并发设置
limit_conn_zone $server_name zone=perserver:10m;
# 定义当服务器由于被限制或缓存时,配置写入日志
limit_conn_log_level error;
?
## 配置 Spring Cloud Gateway 测试
# 负载均衡
upstream renda {
server 127.0.0.1:9000;
server 127.0.0.1:9001;
}
server {
listen 80;
server_name www.springcloudgateway.com;
# 限制每个 IP 的并发数
limit_conn perip 10;
# 限制并发连接数
limit_conn perserver 200;
# 限制总令牌数,令牌发完后,多出来的请求就会返回 503
limit_req zone=req_one burst=500 nodelay;
location / {
proxy_pass http://renda;
index index.html index.htm;
}
}
?
}
然后,我使用 Postman 的压力测试 Collection Runner 对配置进行并发测试,选择了 Delay 为 0,Iterations 为 20,对 www.springcloudgateway.com 发起 GET 请求。
然而,Postman 竟然全部测试用例通过了,但是我明明在 Nginx 中限制了每个 IP 的并发数 最多为 10 呀。怎么会与预测不符合呢?
接着,我调大了 Postman 的 Iterations 为 1000,这时候我发现,它是串行执行的;Postman 的 Delay 为 0 不能保证所有请求真的可以同时发起。
于是,我换了测试工具,使用 Jmeter 进行压力测试。
打开 Jmeter,先创建一个 Thread Group,然后创建一个 HTTP Request 和 View Results Tree;在 Thread Group 中设置 Number of Threads 为 20,Ramp-up period 设置为 0;同样地,对 www.springcloudgateway.com 发起 GET 请求。
这时候,一共 10 个测试用例通过了,10 个没有通过,而且测试用例发起得时间都一样,精确到毫秒,符合预测结果。
之后再使用 Jmeter 进行每秒连接数测试,发现也符合预测。
由此可见,Jmeter 虽然配置比较多,但是比 Postman 要可靠一些。
想了解更多,欢迎关注我的微信公众号:Renda_Zhang
猜你喜欢
- 2025-06-15 绿色清新教培行业年终工作总结PPT课件模板,需要收藏下载
- 2025-06-15 PPT模板「第0004期」清新水墨画风格,可下载直接用
- 2025-06-15 PPT 139 | 粉色渐变小清新春暖花开PPT模板
- 2025-06-15 【778期】38套清新雅致的通用PPT模板
- 2025-06-15 清新企业培训商务PPT模板(企业培训课件ppt)
- 2025-06-15 第1340期—淡雅简洁蓝绿清新扁平化工作计划ppt模板
- 2025-06-15 需要吗?第1254期:清新薄荷绿部门工作总结PPT模板
- 2025-06-15 3分钟搞定PPT!打工人必备的一键制作PPT全攻略
- 2025-06-15 GYB逐字稿 第11课 完成企业想法和计划 《产生你的企业想法》课件PPT
- 2025-06-15 两分钟!用DeepSeek制作ppt。(用deepseek和什么可以做ppt)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- nginx反向代理 (57)
- nginx日志 (56)
- nginx限制ip访问 (62)
- mac安装nginx (55)
- java和mysql (59)
- java中final (62)
- win10安装java (72)
- java启动参数 (64)
- java链表反转 (64)
- 字符串反转java (72)
- java逻辑运算符 (59)
- java 请求url (65)
- java信号量 (57)
- java定义枚举 (59)
- java字符串压缩 (56)
- java中的反射 (59)
- java 三维数组 (55)
- java插入排序 (68)
- java线程的状态 (62)
- java异步调用 (55)
- java中的异常处理 (62)
- java锁机制 (54)
- java静态内部类 (55)
- java怎么添加图片 (60)
- java 权限框架 (55)
本文暂时没有评论,来添加一个吧(●'◡'●)