javascript – node.js HTTP Server,请求和响应超时之间的区别

当涉及到超时HTTP请求时,看起来node.js有三个单独的超时:

> server.setTimeout http://nodejs.org/api/http.html#http_server_settimeout_msecs_callback
> request.setTimeout http://nodejs.org/api/http.html#http_request_settimeout_timeout_callback
> response.setTimeout http://nodejs.org/api/http.html#http_response_settimeout_msecs_callback

任何人都可以澄清每种方法间的区别,以及为什么有人想要使用每种方法

解决方法

>您正在node.js应用程序中运行Web服务器.这决定了在空闲超时之前,节点将关闭客户端请求连接的开放时间,没有流量.一个例子是在您的应用程序下载大型文件时,用户在家中失去电力.您设置一次,它将适用于您的服务器接收的所有客户端连接.
>这是用于从节点程序到远程Web服务器的传出请求.所以你下载文件时要写一个刮刀来下载文件,你的互联网连接就会死机.这决定了节点何时最终放弃等待远端的数据.这将仅影响特定请求,因为底层TCP连接将被关闭,并且每个传出请求将获得不同的TCP连接.
>由于HTTP请求和相应的响应通过相同的底层TCP套接字发生,我的理解是req.setTimeout和res.setTimeout最终导致相同的底层系统调用,使用相应的libuv / os调用在TCP套接字本身上设置超时.所以我认为两者都是等同的,你们可以无论哪一个更方便,哪一个人觉得语义上更清楚.我可能错了,但是如果有人知道肯定会自由地纠正我的话.

一般认值是合理的.但是,如果您知道您有很多客户端的速度非常慢或连接不平坦(您在偏远地区或卫星或其他任何地方提供移动电话),那么您可能需要设置更长的时间,以及由于时间到.如果您知道您的客户端连接良好(如同一数据中心中的服务器),并希望更有效地释放资源,那么您可能希望缩短设置.

相关文章

什么是深拷贝与浅拷贝?深拷贝与浅拷贝是js中处理对象或数据...
前言 今天复习了一些前端算法题,写到一两道比较有意思的题:...
最近在看回JavaScript的面试题,this 指向问题是入坑前端必须...
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面