Nginx学习之Nginx进程

Nginx学习

Nginx命令

  1. ./nginx:启动Nginx;
  2. ./nginx -s stop:关闭Nginx,立即关闭,不管有没有已接受的请求;
  3. ./nginx -s reload:重新加载nginx配置文件,热加载,不需要停止nginx然后重新启动;
  4. ./nginx -s quit:关闭nginx,不过会处理已接受的请求;
  5. ./nginx -t:校验配置文件是否正确,如果配置文件正确会输出xxxok的内容;

Nginx进程

Nginx学习之Nginx进程_第1张图片

Nginx的进程分为master进程:主进程,worker进程:工作进程。master进程负责管理监控worker进程,worker进程负责处理请求,一个master进程可以有多个worker进程。如果worker进程出现问题,那么master会关闭它,重新启动一个worker进程去干活。mater进程就像老板,而worker进程是干活的人。

Nginx学习之Nginx进程_第2张图片
当开发者执行了某个命令后,master进程会把这些命令发送给每一个worker;每一个worker进程会处理与其连接的客户端的请求。

Worker抢占机制

Nginx学习之Nginx进程_第3张图片
当客户端发送请求后,worker进程会去争抢这个请求,nginx设置了accept_mutex互斥锁,哪个worker进程抢到了accept_mutex互斥锁,请求就由哪个worker进程处理。

请求处理机制

Nginx学习之Nginx进程_第4张图片
worker处理请求是基于异步非阻塞模型epoll去处理的,当Client1的请求阻塞了,worker1会继续去处理Client2的请求,这样就大大提高了nginx的并发能力;而传统的服务器是基于同步阻塞的,当Client1的请求被阻塞后,会新建一个进程去处理Client2的请求。

总结

1、为什么要使用多个worker进程?
如果一个worker进程受到黑客攻击或者由于其它某种原因出现问题,那么其它worker进程会继续处理请求,不会停止服务。

2、worker进程设置为几个比较合适?
worker数和服务器cpu数相等比较合适。

参考

  • Nginx教程

你可能感兴趣的:(JavaEE,nginx,学习,服务器)