美文网首页
5.nginx的keepalive和pipe

5.nginx的keepalive和pipe

作者: 无处安放的menta | 来源:发表于2020-11-13 12:40 被阅读0次
image

小张当上了村里的邮差,每日带着村民的信件到nginx帝国,傍晚带着大量的回信回到村子。小张去了师傅家里,师傅听了小张讲述的已经逐渐熟悉了的server_name匹配顺序和规则,又从房间拿出了一些新的工具牌。nginx协议http 1.0和http 1.1是支持长连接的。http基于tcp协议之下,一次请求,需要建立tcp链接,而tcp链接是需要三次握手进行确定,结束请求需要四次交互。这种方式nginx需要耗费资源,时间开销都会影响整体速度。

而如果知道请求头和响应体的长度,我们是可以在在一个链接上执行多个请求。如post请求,我们在请求头上加上请求体body的大小用content-length表示,否则返回400错误。请求体是确定的,响应体中body的长度:

1.http 1.0中响应头中有content-length头,就是响应体body的长度,取出对应的长度的数据就可以结束了。如果nginx的响应头没有给出content-length头信息,那么就一直接受数据,等待nginx自动结束。

2.http 1.1中响应头中的transfer-encoding为chunked传输,代表流式输出,body体被分为几个块,每块的开始都会标注当前块的长度,body不需要指定长度。非chunked传输时,有content-length头信息,则接受对应长度的数据,没有则等待nginx传输结束自动结束掉请求。

除了上面两种不知道响应体长度的,body的长度是可以知道的。这时候,我可以在请求头中增加connection信息,当对应的值为keepalive时,代表为长连接,nginx在输出响应体之后,并不关闭连接,而是等待下一次的请求。http 1.0中connection的值默认为cloes,而http 1.1默认keep-alive。

小张拿着师傅给的工具牌,有了这keepalive,将信件归类之后,速度就快多了。

老王:当然,你速度也要快,nginx看到keep-alive之后,不会马上关闭连接,但是也不可能一直等待。nginx设置了keepalive链接属性和一个keepalive_timeout等待时间,超出这个时间,nginx还没有收到请求,就会关掉链接。keepalive_timeout也可以配置为0,这样表示nginx不接受长连接,无论请求头是否添加了keepalive属性。(如果有大量的请求,开启长连接,nginx可以减少大量的tine-wait)。

小张:那这个pipe有什么用呢?

老王:这是http 1.1的属性,pipeline是基于长连接的,目的是用一个链接做多次请求。对于keepalive,多个请求中第二个请求必须等待第一个请求结束,pipeline可以在第一个请求没有结束就发起第二个请求。(nginx支持pipeline,但是内部已然是一个一个处理,但是减少了处理完第一个请求,等待第二个请求的时间)

相关文章

  • 5.nginx的keepalive和pipe

    小张当上了村里的邮差,每日带着村民的信件到nginx帝国,傍晚带着大量的回信回到村子。小张去了师傅家里,师傅听了小...

  • 关于http keep-alive 2022-04-10

    TCP的keepalive和HTTP的keep-alive TCP keepalive是用来检测保活的 HTTP ...

  • Android进程间通信机制-管道

    PIPE和FIFO的使用及原理 PIPE和FIFO都是指管道,只是PIPE独指匿名管道,FIFO独指有名管道,我们...

  • 管道

    man 7 PIPE pipe和FIFO介绍pipe匿名管道,只能用于有亲缘关系的进程间通信FIFO命名管道,任意...

  • flutter KeepAlive

    KeepAlive KeepAlive通过设置parentData(KeepAliveParentDataMixi...

  • 聊聊storagetapper的pipe

    序 本文主要研究一下storagetapper的pipe Pipe storagetapper/pipe/pipe...

  • HTTP修炼手册-HTTP 和 TCP 的 KEEP ALIVE

    先把结论放这:TCP 的 keepalive 和 HTTP 请求和响应的包头里的 keepalive 不是一回事。...

  • NIO十二-Pipe

    Java NIO Pipe Creating a Pipe Writing to a Pipe Reading f...

  • Keepalive和lvs

    1.简介 keepalive起初是为LVS设计的,专门用来监控lvs各个服务节点的状态,后来加入了vrrp的功能,...

  • 进程间通信的方式

    管道(pipe),流管道(s_pipe)和有名管道(FIFO) 信号(signal) 消息队列 共享内存 信号量 ...

网友评论

      本文标题:5.nginx的keepalive和pipe

      本文链接:https://www.haomeiwen.com/subject/sosmbktx.html