Nginx基本原理 Nginx常见问题分析

本文介绍了Nginx的基本原理,包括其多进程模型,其中Master进程管理Worker进程,Worker进程处理网络请求。Nginx采用多进程+异步非阻塞的IO多路复用模型实现高性能、高并发。文章还深入探讨了Nginx与Apache的区别,以及Nginx的最大连接数计算,并讨论了HTTP请求响应、IO模型和Nginx的并发处理能力。
摘要由CSDN通过智能技术生成

01 基本原理

1.1 Nginx 的进程模型

Nginx 服务器,正常运行过程中:

多进程:一个 Master 进程、多个 Worker 进程

Master 进程:管理 Worker 进程

对外接口:接收外部的操作(信号)

对内转发:根据外部的操作的不同,通过信号管理 Worker

监控:监控 worker 进程的运行状态,worker 进程异常终止后,自动重启 worker 进程

Worker 进程:所有 Worker 进程都是平等的

实际处理:网络请求,由 Worker 进程处理;

Worker 进程数量:在 nginx.conf 中配置,一般设置为核心数,充分利用 CPU 资源,同时,避免进程数量过多,避免进程竞争 CPU 资源,增加上下文切换的损耗。

思考:

请求是连接到 Nginx,Master 进程负责处理和转发?

如何选定哪个 Worker 进程处理请求?请求的处理结果,是否还要经过 Master 进程?

HTTP 连接建立和请求处理过程:

Nginx 启动时,Master 进程,加载配置文件

Master 进程,初始化监听的 socket

Master 进程,fork 出多个 Worker 进程

Worker 进程,竞争新的连接,获胜方通过三次握手,建立 Socket 连接,并处理请求

Nginx 高性能、高并发:

Nginx 采用:多进程 + 异步非阻塞方式(IO 多路复用 epoll)

请求的完整过程:

建立连接

读取请求:解析请求

处理请求

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值