nginx高性能原因
2021/12/8 7:17:33
本文主要是介绍nginx高性能原因,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
epoll多路复用
BIO(堵塞式IO)
缺点: client和server一旦建立连接,就可以建立通信套接字在这个通信套接字上进行读写操作,此时不能再接收其他客户端连接请求,只能等待同当前连接的客户端的操作执行完成。
select模型
缺点: 变更触发轮询查找,有1024数量上限
epoll模型
好处: 变更触发回调函数直接读取,理论无上限
master-worker进程模型
允许其做平滑重启和平滑重新加载配置且不会断开与客户端连接
- 管理员: 相当于root用户,用于启动和管理nginx进程.
- 信号,可以理解为启动nginx, 即./nginx命令
- master进程: 当nginx启动后,就会产生一个master进程.管理worker进程(子进程)的内存空间.
- worker进程,master进程的子进程(fork实现),worker进程数等于worker_processes的值(一般等于核数).用于处理客户端连接.
工作实现
- client向master进程请求建立连接,worker进程抢占内存锁,抢到的worker进程便会处理client连接,以后该client的请求均由该worker处理.
- 平滑重启和平滑重新加载配置实现的解释
当worker进程挂掉或者管理员执行重启命令,master进程不会挂掉,master进程会向worker进程发送一个信号,让worker将所有的sockert句柄都让master进程管理,master进程会重新加载配置文件,启动一个新的worker进程,并且将管理的socket句柄交给新创建的worker进程管理,全部操作都是基于内存,瞬时完成.(基于worker进程是master进程fork出来的子进程,master进程共享所有worker进程变量)
- worker进程只有一个线程,因为当客户端请求服务器,需要worker进程向客户端发送数据时,通过回调函数实现,没有堵塞,所以单线程比多线程更快,多线程有切换开销.
基于协程的非堵塞式编程机制
完成单进程上单线程的模型,同时可以支持并发的编程的调用接口
- 依附于线程的内存模型,切换开销小
协程是一个比线程更小的概念,一个线程可以有多个协程,协程的切换开销极小,因为它没有像线程切换一样有CPU的切换开销,只需要一个内存的切换开销即可.
- 遇堵塞,归还执行权,代码同步
当执行socket.read的时候,nginx对应的协程机制会自动将对应的协程的执行权限剥夺,并调出一个不堵塞的协程运行,当socker.read操作完成,epoll的多路复用机制会回调通知worker,这个回调直接是方法的return.
- 无需加锁
协程依附于线程,是一个串行执行的过程,不需要加锁.
这篇关于nginx高性能原因的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-10-29Nginx发布学习:从入门到实践的简单教程
- 2024-10-28Nginx发布:新手入门教程
- 2024-10-21nginx 怎么设置文件上传最大20M限制-icode9专业技术文章分享
- 2024-10-17关闭 nginx的命令是什么?-icode9专业技术文章分享
- 2024-09-17Nginx实用篇:实现负载均衡、限流与动静分离
- 2024-08-21宝塔nginx新增8022端口方法步骤-icode9专业技术文章分享
- 2024-08-21nginx配置,让ws升级为wss访问的方法步骤-icode9专业技术文章分享
- 2024-08-15nginx ws代理配置方法步骤-icode9专业技术文章分享
- 2024-08-14nginx 让访问带有/relid的地址返回404 ,例子 /relid-x-0.36-y-131.html-icode9专业技术文章分享
- 2024-08-14nginx 判断地址有/statics/的路径,指向到/home/html/statics/目录-icode9专业技术文章分享