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教程