回答
收藏
分享
举报
nginx为什么性能这么优越?
提问于2020-05-08 16:39

浏览 1.9k

已修改于2023-03-17 17:59



写下您的回答
发表回答
全部回答(4)

按点赞数排序

按时间排序

所谓性能好,一般指2点:低时延、高并发,由这2点会带来高吞吐量,也就是百万级的QPS。

我先说低时延是怎么办到的:

1、Nginx内部的算法都非常优秀,是性能优先的。

比如hash表会考虑cpu cache line(参见https://www.nginx-cn.net/article/71),比如location匹配是基于URI规则封装的多叉树(参见https://www.nginx-cn.net/article/69)。


2、Nginx充分使用了OS的各种高性能特性

比如Linux的reuseport、accept_defer、lingering_close、sendfile、aio等等。


再说高并发是怎么达到的:

1、每个请求占用的内存极为有限

每个连接占用的基本内存不过几百字节,这需要很深厚的功力,也只有C语言才能办得到。


2、基于事件驱动的多路复用框架

这个已经说烂了,就不多说了

赞同

5

回复举报

回答于2020-05-20 19:47



回复陶辉
回复
lnx回复了


老师,请问这种场景怎么解决呢?nginx代理服务器会不会存在性能瓶颈呢?

0

回复举报

回答于2021-11-04 11:35



回复lnx
回复

说多了就一句话,充分利用系统的特性。

以 Linux 为例,

    在 Linux 中的多进程,epoll 模型, reuseport, send_file ....都是高并发的利器

1 多进程让所有核心都在干活,而不是划水

2 epoll 模型让每个核心都干它值得干的事情(相对 select/poll,减少不必要的轮询)

3 reuseport 解决狗界难题-惊群

4 。。。未完待续

赞同

1

回复举报

回答于2020-05-20 16:15



回复头号游戏教父B哥
回复

因为C语言编写的

赞同

1

回复举报

回答于2020-05-08 16:50



回复13191816265@qq.com
回复
黄阿马回复了
您这句话倒是简单粗暴啊

0

回复举报

回答于2020-05-21 08:12



回复黄阿马
回复

同问,坐等回答

赞同

0

回复举报

回答于2020-05-08 16:40



回复你猜我不猜
回复
提问者
繁星
这家伙很懒还未留下介绍~
0
文章
6
问答
8
粉丝
相关问答

proxy_http_version为1.1,同时Connection: keep-alive,这只是说:HTTP协议是支持长连接的。但客户端要不要使用长连接呢?如果使用长连接,就得有连接池,那么连接池应该是多少呢?毕竟一旦有连接池,就可能存在资源浪费,在用户没有明确的配置keepalive连接池时,Nginx还是不会使用长连接。

点赞 0
浏览 1.6k

location ^~ /forum {
set $args mod=viewthread&${args};
rewrite ^(.*)$ /$uri last;
}

点赞 0
浏览 712
主要性能优势来源于连接复用和 lua 变成 rust
个人认为调度上 stealing 未必比绑核更好
点赞 0
浏览 1.2k