# client和nginx简易交互过程
- step1:client发起http请求
- step2:dns服务器解析域名得到主机ip
- step3:默认端口为80,通过ip+port建立tcp/ip链接
- step4:建立连接的tcp/ip三次握手,建立成功发送数据包
- step5:nginx匹配请求
- case .html: 静态内容,分发静态内容响应
- case .php: php脚本,转发请求内容到php-fpm进程,分发php-fpm返回的内容响应
- step6:断开连接的tcp/ip四次握手,断开连接
# nginx和php简易交互过程
- 背景:web server和服务端语言交互依赖的是cgi(Common Gateway Interface)协议,由于cgi效率不高(每次请求都需要重新起一个php-cgi解析器进程,
这中间会进行加载php.ini配置等一系列的操作)所以后期产生了fastcgi协议(一种常驻型的cgi协议),php-cgi实现了fastcgi,但是相比php-cgi,php-fpm提供
了更好的PHP进程管理方式,可以有效控制内存和进程并可以平滑重载PHP配置
- 流程:
- step1:nginx接收到一条http请求,会把环境变量,请求参数转变成php能懂的php变量
```
// nginx 配置资料
location ~ \.php$ {
include snippets/fastcgi-php.conf; //step1
fastcgi_pass unix:/run/php/php7.0-fpm.sock;
}
```
- step2:nginx匹配到.php结尾的访问通过fastcgi_pass命令传递给php-fpm.sock文件,其实这里 的ngnix发挥的是反向代理的角色,把http协议请求转到fastcgi协议请求
```
// nginx 配置资料
location ~ \.php$ {
include snippets/fastcgi-php.conf;
fastcgi_pass unix:/run/php/php7.0-fpm.sock;// step2
}
```
- step3:php-fpm.sock文件会被php-fpm的master进程所引用,这里nginx和php-fpm使用的是 linux的进程间通信方式unix domain socks,是一种基于文件而不是网络底册协议的通信方式
- step4:php-fpm的master进程接收到请求后,会把请求分发到php-fpm的子进程,每个php-fpm 子进程都包含一个php解析器
- step5:php-fpm进程处理完请求后返回给nginx
# 附录
- php-fpm进程管理的三种方式
+ static: 静态方式,php-fpm启动时及启动最大子进程数,优点是不需要额外的fork子进程过程,适合专门的服务器
- 参数:
- pm.max_children: 最大子进程数
+ dynamic: 动态方式,配置最大数和启动数,空闲数,实际使用过程fork进程,优点灵活节省内存,缺点fork过程有性能消耗
- 参数:
- pm.max_children: 最大进程数
- pm.start_servers: 启动数,等于min_spare_servers + (max_spare_servers - min_spare_servers)/2
- pm.min_spare_servers: 最小空闲进程数,如果空闲进程(idle)数小于该值,启动一个子进程
- pm.max_spare_servers: 最大空闲进程数,如果空闲进程(idle)数大于该值,kill一个子进程
+ ondemand: 按需方式, 不启动子进程,按需fork,优点节省资源
- 参数:
- pm.max_children:
- pm.process_idle_timeout: 子进程空闲多少秒后被kill
相关文章
- 01-20交互式简易循环计算器-nextLine()和next()等详解
- 01-20Nginx和FastDfs完整配置过程
- 01-2059-10000 前端和后台交互基本过程测试 ,举例说明 输入正确就登录成功,否则进行一个验证提示
- 01-20Ubuntu12.04 安装nginx和mongo过程
- 01-20Nginx与PHP交互过程 + Nginx与PHP通信的两种方式
- 01-20使用Nginx和Logstash以及kafka来实现网站日志采集的详细步骤和过程
- 01-20client和nginx简易交互过程
- 01-20Nginx报错:upstream timed out (110: Connection timed out)和client intended to send too large body【转】
- 01-20拿到新机器,进行初始化和部署Nginx的过程
- 01-20配合阿里云的负载均衡,使用宝塔面板,Nginx服务器作为Springboot和Vue的前后端分离开发过程记录