网站首页 > 技术教程 正文
nginx的进程模型可以理解为:多进程+多路复用。
nginx的进程模型
使用linux的ps命令查看当前nginx的进程(ps -ef | grep nginx),可以看到有两个进程,分别是nginx:master和nginx:worker。
两个进程之间的关系可以用如下图来表示:
nginx这样处理的优点有:
- 当nginx启动后,产生一个master进程,当master执行一系列操作后会产生一个或多个worker进程。
- 当有请求进来时,master会向worker发信号,然后通过worker进程去处理请求,一个请求对应一个worker。
- master会监控worker的状态。当worker产生异常时,会启动一个新的woker。
- 多个worker之间是一种竞争关系。每个worker进程可以产生多路复用。
- nginx的每个进程都是独立的,相互之间是安全的。一个worker 宕机了,其它work还是继续工作,相互没有影响。
当我们将配置文件中work_processes由1改成2后,重启nginx会发现多了一个work_processes,理论上单机nginx支持的并发数为(work_processes * work_connections)。
worker_processes配置
上面已经介绍了work_processes的配置,但是这个数并不是越大越好,建议配置为1,最大也不要超过8。比你当前CPU核数小就可以了。官方原文建议是:
Nginx unlike Apache and other process per connection webservers.
It uses one master process to start and monitor a small number of worker processes
that actually handle the connections.
My recommendation is to start with the default number of workers, which is 1.
worker_cpu_affinity配置
这个参数默认是不开启的。所以我们如果要配置,建议首先查看CPU核数(与上面一致)。它是由0和1这样的二进制参数 组成。
以2核CPU开启2进程为例,"01"代表使用第一个CPU内核,“10”代表使用第二个CPU内核。组数代表进程数。
配置示例如下所示:
测试
配置完成后重启nginx,使用ab命令测试,然后使用top命令查看CPU使用情况。
# /usr/local/nginx-1.16.1/sbin/nginx -s reload
# ab -n 30000 -k http://localhost/index.html
# top
猜你喜欢
- 2024-10-14 还在为购买了便宜的服务器却不能用来做更多事而烦恼吗?
- 2024-10-14 快速Nginx入门,看此文即可快速掌握
- 2024-10-14 Nginx进程间的通信机制(nginx进程数)
- 2024-10-14 5分钟搞懂nginx进程模型及相关配置
- 2024-10-14 nginx——优化 Nginx worker 进程数
- 2024-10-03 Nginx 最大连接数(nginx最大连接数设置)
- 2024-10-03 浅谈linux下进程最大数、最大线程数、进程打开的文件数
- 2024-10-03 Nginx凭啥并发数可以达到3w?(nginx10万并发)
- 2024-10-03 Nginx基础配置实例需求分析(nginx配置文件详解带实例)
- 2024-10-03 nginx的进程模型及框架(nginx的进程结构)
你 发表评论:
欢迎- 最近发表
-
- 阿里P8大佬总结的Nacos入门笔记,从安装到进阶小白也能轻松学会
- Linux环境下,Jmeter压力测试的搭建及报错解决方法
- Java 在Word中合并单元格时删除重复值
- 解压缩软件哪个好用?4款大多数人常用的软件~
- Hadoop高可用集群搭建及API调用(hadoop3高可用)
- lombok注解@Data没有toString和getter、setter问题
- Apache Felix介绍(apache fineract)
- Spring Boot官方推荐的Docker镜像编译方式-分层jar包
- Gradle 使用手册(gradle详细教程)
- 字节二面:为什么SpringBoot的 jar可以直接运行?
- 标签列表
-
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)
本文暂时没有评论,来添加一个吧(●'◡'●)