ajax调用接口很慢,nodejs 请求接口在高并发下耗时很大,而单个请求非常快

在Node.js应用中,使用request.js库请求接口时,单个请求耗时较低,但在高并发(如webbench和ab工具进行的500并发测试)情况下,请求耗时显著增加,达到2000ms以上。问题可能涉及到连接池、并发限制和服务器处理能力。寻求解决此类问题的经验分享。
摘要由CSDN通过智能技术生成

情况: request.js 库请求接口, express.js 做 server ,实现了 curl http://localhost:8080/proxy-api 本地一个地址,在 router 里用 request.js 请求接口,统计了一下请求耗时,单个请求耗时很低,如下:

get http://ip:9190/user/getUserInfo 13 ms

然后分别使用 webbench 和 ab 做并发测试,并发 500 ,发现接口有非常大的耗时。

# 测试命令

ab -n 1000 -c 200 -r http://localhost:8080/proxy-api

webbench -t 10 -c 500 http://localhost:8080/proxy-api# 截取部分响应耗时:

get http://ip:9190/user/getUserInfo 2019 ms

cost time: 2020

get http://ip:9190/user/getUserInfo 2062 ms

cost time: 2062

get http://ip:9190/user/getUserInfo 2064 ms

cost time: 2065

get http://ip:9190/user/getUserInfo 2063 ms

cost time: 2063

get http://ip:9190/user/getUserInfo 2062 ms

cost time: 2063

get http://ip:9190/user/getUserInfo 2063 ms

cost time: 2063

get http:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Node.js通过事件循环和Cluster模块来支持高并发接口。事件循环是指Node.js执行非阻塞I/O操作的机制,它可以将操作装载到系统内核中处理,在后台执行多个操作。当其中一个操作完成时,内核会通知Node.js,以便将相应的回调添加到轮询队列中最终执行。这种机制使得Node.js能够处理大量并发请求。\[1\] 另外,Cluster模块可以使单进程架构的Node.js支持多进程的服务器架构,更好地利用多核。Node.js支持两种多进程服务器架构:轮询和共享。轮询是主进程处理连接,然后将连接分发给子进程处理;共享是子进程共享socket,通过竞争的方式获取连接进行处理。可以通过环境变量在Node.js中进行设置。这样可以进一步提高Node.js的并发处理能力。\[2\] 在处理完一个连接后,Node.js会根据是否设置了single_accept标记来决定是否睡眠一段时间,以给其他进程处理剩下的连接,从而避免负载不均衡。如果没有设置该标记,Node.js会继续尝试处理下一个连接。这样可以更好地处理高并发情况下的请求。\[3\] 综上所述,Node.js通过事件循环和Cluster模块的支持,可以实现高并发接口处理。 #### 引用[.reference_title] - *1* [说说Nodejs高并发的原理](https://blog.csdn.net/m0_67614517/article/details/128284842)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [理解Nodejs的单线程实现高并发原理](https://blog.csdn.net/qq_42415326/article/details/124564825)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值