异步 httpclient 是如何处理大量并发请求的

2021-04-03 16:06:03 +08:00
 git00ll

这几天在看异步的 http 客户端(java),有一点不解。

  1. 先讲讲同步的 http 客户端,如 okhttp httpclient 每个请求堵塞一个线程,超过客户端的 http 连接池大小后,继续请求,会堵塞住,直到有连接可用,这很好理解。
  2. 异步的 http 客户端如 apache async httpclient 内部使用的 java nio,每次发送请求时都是非堵塞的,需要传递回掉函数处理 http response,但是即使是 nio 大小也不是无限的,如果下游返回太慢,大量的请求注册到 nio 里,到达极限后会怎么样呢,会堵塞吗?如果内部有队列,那队列满了会堵塞吗?
2004 次点击
所在节点    Java
3 条回复
mazyi
2021-04-03 16:19:25 +08:00
队列满了堵不堵看一看进队列的代码就知道了
ikas
2021-04-03 16:40:39 +08:00
队列满了当然是要一个策略了,比如丢弃,比如先保存到其他地方
ikas
2021-04-03 16:51:50 +08:00
正常如果是大量的请求,本身就不能只是依赖 httpclient 的异步,而是自己要实现一个'消费队列',使用自己的策略处理

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/767794

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX