问题背景
项目使用的是Torando
框架,请求第三方应用,用的是 AsyncHttpClient
。 昨天有个需求是在项目直接进行http请求数据,但是http需要长连接,由于 AsyncHttpClient
不支持使用长连接,根据官方文档,换成了 CurlAsyncHTTPClient
, 这个可以满足需求。之后,在运行过程中发现,相对于替换之前,请求时间增加了 40ms, 查了一下,发现是由于 TCP
的 设置导致的 https://github.com/tornadoweb/tornado/issues/1826
原因
- Nagle’s算法
在TCP请求中,如果每次生成一点数据都要推送,就会导致传输很多包,降低了总体的传输效率,导致网络拥塞。因此,有大神提出了Nagle’s算法: 通常会在TCP程序里,在未确认数据发送的时候让发送器把数据送到缓存里。任何数据随后继续直到得到明显的数据确认或者直到攒到了一定数量的数据了再发包。
解决方案:
- 将
TCP_NODELAY
选项设置为 1.