Nginx 服务器使用多进程架构,主要包括一个 Master 进程和多个 Worker 进程。每种进程都有不同的职责和功能,它们共同协作来处理客户端请求。以下是 Master 进程和 Worker 进程的详细解释:
Master 进程
Master 进程是 Nginx 的主控制进程,负责启动、停止和管理 Worker 进程。Master 进程的主要职责包括:
- 读取和验证配置文件: 当 Nginx 启动或重新加载时,Master 进程读取和验证配置文件。如果配置文件有误,Master进程会报告错误而不会重新加载配置。
- 管理 Worker 进程: Master 进程负责启动、停止和管理 Worker 进程。当 Nginx需要平滑升级或重新加载配置时,Master 进程会优雅地管理 Worker 进程的重启。
- 处理信号: Master 进程接收和处理来自操作系统或管理员的信号,如启动、停止、重新加载配置等。
Worker 进程
Worker 进程是实际处理客户端请求的进程。每个 Worker 进程是独立的,它们通过监听相同的端口来接收和处理客户端请求。Worker 进程的主要职责包括:
- 处理客户端请求: Worker 进程负责接收和处理客户端的所有 HTTP、HTTPS 和其他协议的请求。
- 执行请求处理逻辑: 根据 Nginx 配置,Worker 进程执行请求的处理逻辑,包括访问控制、URL 重写、代理请求、静态文件服务等。
- 非阻塞 I/O 操作: Worker 进程使用异步非阻塞 I/O 模型,通过事件驱动机制高效地处理大量并发连接。
Master 进程和 Worker 进程的交互
- 启动和停止: 当 Nginx 启动时,Master 进程首先启动,然后创建多个 Worker 进程。每个 Worker 进程独立处理请求。当Nginx 停止时,Master 进程会优雅地停止所有 Worker 进程。
- 重新加载配置: 当 Nginx 需要重新加载配置时,Master 进程会读取和验证新的配置文件。如果配置文件没有错误,Master进程会通知所有 Worker 进程优雅地停止,然后启动新的 Worker 进程来应用新的配置。
- 信号处理: Master 进程接收来自操作系统的信号(如 SIGTERM、SIGHUP 等),并将相应的指令传递给 Worker进程。通过这种方式,可以控制 Nginx 的启动、停止和重新加载等操作。