Nginx的进程模型
2014-09-13 23:09
477 查看
Nginx分为两种进程模型:Single Master
Single是单进程方式工作
Master是一个Master进程+N个worker进程,通过ngx_master_process_cycle完成,源码在ngx_process_cycle.c
Master进程模型:master进程负责接收客户端的请求,worker负责处理这些请求
master进程在服务器启动时进行全局初始化和管理worker进程
worker的数目应该和cpu的个数一样,效率较高,系统不用在多个worker间调度
每个worker进程都是从master进程fork过来,在master进程里面,先建立好需要listen的socket(listenfd)之后,然后再fork出多个worker进程。所有worker进程的listenfd会在新连接到来时变得可读,为保证只有一个进程处理该连接,所有worker进程在注册listenfd读事件前抢accept_mutex,抢到互斥锁的那个进程注册listenfd读事件,在读事件里调用accept接受该连接。当一个worker进程在accept这个连接之后,就开始读取请求,解析请求,处理请求,产生数据后,再返回给客户端,最后才断开连接,这样一个完整的请求就是这样的了。
nginx采用了异步非阻塞的方式来处理请求,也就是说,nginx是可以同时处理成千上万个请求的。
LINUX系统的特点:
Nginx每次访问完文件,LINUX系统需要写磁盘,修改该文件的访问时间,对这个系统的特性进行修改,减少读写次数
单个用户可以打开的文件,即对文件描述符的使用,默认是1024 ulimit -n
单个用户可以拥有的进程数,默认是8040 ulimit -u
修改limits.conf可以改变这些值
Single是单进程方式工作
Master是一个Master进程+N个worker进程,通过ngx_master_process_cycle完成,源码在ngx_process_cycle.c
Master进程模型:master进程负责接收客户端的请求,worker负责处理这些请求
master进程在服务器启动时进行全局初始化和管理worker进程
worker的数目应该和cpu的个数一样,效率较高,系统不用在多个worker间调度
每个worker进程都是从master进程fork过来,在master进程里面,先建立好需要listen的socket(listenfd)之后,然后再fork出多个worker进程。所有worker进程的listenfd会在新连接到来时变得可读,为保证只有一个进程处理该连接,所有worker进程在注册listenfd读事件前抢accept_mutex,抢到互斥锁的那个进程注册listenfd读事件,在读事件里调用accept接受该连接。当一个worker进程在accept这个连接之后,就开始读取请求,解析请求,处理请求,产生数据后,再返回给客户端,最后才断开连接,这样一个完整的请求就是这样的了。
nginx采用了异步非阻塞的方式来处理请求,也就是说,nginx是可以同时处理成千上万个请求的。
LINUX系统的特点:
Nginx每次访问完文件,LINUX系统需要写磁盘,修改该文件的访问时间,对这个系统的特性进行修改,减少读写次数
单个用户可以打开的文件,即对文件描述符的使用,默认是1024 ulimit -n
单个用户可以拥有的进程数,默认是8040 ulimit -u
修改limits.conf可以改变这些值
相关文章推荐
- 从nginx角度看服务器多进程模型设计(一)
- 图解Nginx-Nginx进程模型1
- nginx源码分析(3)——进程模型
- Nginx的内部(进程)模型
- Nginx学习之六-nginx核心进程模型
- Nginx 多进程模型是如何实现高并发的?
- memcached多线程模型 & nginx 多进程模型
- 3-nginx进程模型
- 从nginx角度看服务器多进程模型设计(二)
- nginx多进程模型之热部署
- Nginx的内部(进程)模型
- Nginx进程模型
- nginx的进程模型
- NginX进程模型-Cache Manager/Cache Loader
- nginx多进程模型之配置热加载
- nginx多进程模型之热代码平滑升级
- Nginx 进程模型
- Nginx学习之六-nginx核心进程模型
- Nginx源码分析 ——Nginx的进程模型
- nginx进程模型