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的进程分为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教程
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值