2种部署方式简介
第一种
前置1台nginx服务器做http反向代理和负载均衡
后面n太服务器的nginx做web服务,并调用php-fpm提供的fast cgi服务
此种部署方式最为常见,web服务和php服务在同一台服务器上都有部署
第二种
前置1台nginx服务器做web服务
后面服务器只部署php-fpm服务,供nginx服务器调用
前置1台nginx服务器,在调用后面多例php-fpm服务时,也可以做到负载均衡
如下图 :
对比
从系统设计角度
第一种部署是常规部署方式,大中小规模网站都能适用。
第二种,不同服务部署在不同服务器上,更加细致。但也有几个问题:
前置nginx充当web服务。所有静态资源的访问、压缩传输和缓存设置都被集中到这台服务器上。压力会大,容易成为瓶颈。
如果静态资源都存放于cdn,不需要http 压缩传输,这种部署方式还算比较合理;
承接上面两点,还可以对这种部署方式进行优化。在前面的负载均衡和反向代理层之后,中间是一个 Nginx web 服务器,后面部署了一个 PHP-FPM 服务。 从性能角度
相比第二种部署方式,第一种多走了一次进程间交互。
按照第一种部署,当一个http请求过来,先是nginx反向代理转发至nginx web服务(通过网络),web服务再通过fastcgi协议与php-fpm进行交互(进程间交互);
按照第二种部署,当一个http请求过来,充当web服务的nginx,直接通过网络与php-fpm进行交互
第一种部署,通过网络交互的是http协议,第二种通过网络交互的是fast-cgi协议, 这两种协议对比如何呢?
fast cgi 的数据包会比http稍微大一些,fast cgi协议会比http携带更多的参数信息、传输控制信息等等。 fast cgi 协议比http协议格式化严格一些,解析起来速度更快一些。 从运维角度
第一种是最常见的部署方式,简单统一,所有提供web服务的服务器上的服务都是同构的,单调粗放。
第二种则是将nginx和php-fpm单独分开部署,不同服务在服务器集群上的分布更加细致。如果统计web服务中的压力分布,可以更加精细地利用硬件资源。运维成本也更高。
从开发测试角度
两种部署方式都不合适开发环境或测试环境。
开发和测试环境把nginx和php部署到一台服务器上即可,不需要反向代理和负载均衡。
以上是Nginx和PHP的部署方式是什么的详细内容。更多信息请关注PHP中文网其他相关文章!