按点赞数排序
按时间排序
所谓性能好,一般指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
说多了就一句话,充分利用系统的特性。
以 Linux 为例,
在 Linux 中的多进程,epoll 模型, reuseport, send_file ....都是高并发的利器
1 多进程让所有核心都在干活,而不是划水
2 epoll 模型让每个核心都干它值得干的事情(相对 select/poll,减少不必要的轮询)
3 reuseport 解决狗界难题-惊群
4 。。。未完待续
1
回答于2020-05-20 16:15
proxy_http_version为1.1,同时Connection: keep-alive,这只是说:HTTP协议是支持长连接的。但客户端要不要使用长连接呢?如果使用长连接,就得有连接池,那么连接池应该是多少呢?毕竟一旦有连接池,就可能存在资源浪费,在用户没有明确的配置keepalive连接池时,Nginx还是不会使用长连接。
location ^~ /forum {
set $args mod=viewthread&${args};
rewrite ^(.*)$ /$uri last;
}