admin 管理员组文章数量: 1184232
Nginx学习之Nginx进程
Nginx学习
Nginx命令
- ./nginx:启动Nginx;
- ./nginx -s stop:关闭Nginx,立即关闭,不管有没有已接受的请求;
- ./nginx -s reload:重新加载nginx配置文件,热加载,不需要停止nginx然后重新启动;
- ./nginx -s quit:关闭nginx,不过会处理已接受的请求;
- ./nginx -t:校验配置文件是否正确,如果配置文件正确会输出xxxok的内容;
Nginx进程
Nginx的进程分为master进程:主进程,worker进程:工作进程。master进程负责管理监控worker进程,worker进程负责处理请求,一个master进程可以有多个worker进程。如果worker进程出现问题,那么master会关闭它,重新启动一个worker进程去干活。mater进程就像老板,而worker进程是干活的人。
当开发者执行了某个命令后,master进程会把这些命令发送给每一个worker;每一个worker进程会处理与其连接的客户端的请求。
Worker抢占机制
当客户端发送请求后,worker进程会去争抢这个请求,nginx设置了accept_mutex互斥锁,哪个worker进程抢到了accept_mutex互斥锁,请求就由哪个worker进程处理。
请求处理机制
worker处理请求是基于异步非阻塞模型epoll去处理的,当Client1的请求阻塞了,worker1会继续去处理Client2的请求,这样就大大提高了nginx的并发能力;而传统的服务器是基于同步阻塞的,当Client1的请求被阻塞后,会新建一个进程去处理Client2的请求。
总结
1、为什么要使用多个worker进程?
如果一个worker进程受到黑客攻击或者由于其它某种原因出现问题,那么其它worker进程会继续处理请求,不会停止服务。
2、worker进程设置为几个比较合适?
worker数和服务器cpu数相等比较合适。
参考
- Nginx教程
本文标签: Nginx学习之Nginx进程
版权声明:本文标题:Nginx学习之Nginx进程 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://www.roclinux.cn/p/1698021304a282985.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论