Nginx 和 PHP 的两种部署方式比较

本文涉及的产品
传统型负载均衡 CLB,每月750个小时 15LCU
网络型负载均衡 NLB,每月750个小时 15LCU
应用型负载均衡 ALB,每月750个小时 15LCU
简介: Nginx 和 PHP 的两种部署方式比较

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 负载均衡和反向代理,中间是 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 部署到一台服务器上即可,不需要反向代理和负载均衡。

总结

如果是 LAMP 环境的部署,第一种比较常见。

如果不是 LAMP,是 nginx 和其他 fastcgi 服务交互,比如 C/C++、Java 的 fastcgi 程序,在大规模的网络应用中,类似第二种的部署是常见的。做到不同服务之间分开部署,反而是简化了系统的网络结构,更加便于维护。

后记

此篇博文的内容,都来自于和百度前同事在 QQ 群里的讨论。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
相关文章
|
编译器 Linux PHP
【Azure App Service】为部署在App Service上的PHP应用开启JIT编译器
【Azure App Service】为部署在App Service上的PHP应用开启JIT编译器
132 1
kde
|
1月前
|
应用服务中间件 网络安全 nginx
手把手教你使用 Docker 部署 Nginx 教程
本文详解Nginx核心功能与Docker部署优势,涵盖镜像拉取、容器化部署(快速、挂载、Compose)、HTTPS配置及常见问题处理,助力高效搭建稳定Web服务。
kde
711 4
|
1月前
|
应用服务中间件 Linux nginx
在虚拟机Docker环境下部署Nginx的步骤。
以上就是在Docker环境下部署Nginx的步骤。需要注意,Docker和Nginix都有很多高级用法和细节需要掌握,以上只是一个基础入门级别的教程。如果你想要更深入地学习和使用它们,请参考官方文档或者其他专业书籍。
109 5
|
9月前
|
应用服务中间件 PHP nginx
今日小结通过aliyun的本地容器镜像部署我的nginx和php环境
简介: 本教程介绍如何基于 Dragonwell 的 Ubuntu 镜像创建一个运行 Nginx 的 Docker 容器。首先从阿里云容器镜像服务拉取基础镜像,然后编写 Dockerfile 确保 Nginx 作为主进程运行,并暴露 80 端口。最后,在包含 Dockerfile 的目录下构建自定义镜像并启动容器,确保 Nginx 在前台运行,避免容器启动后立即退出。通过 `docker build` 和 `docker run` 命令完成整个流程。
354 25
今日小结通过aliyun的本地容器镜像部署我的nginx和php环境
|
4月前
|
小程序 安全 关系型数据库
专业打造一款圈子源码软件系统 / 后端 PHP 搭建部署一样实现利益化
本教程详解基于PHP后端与Uni-app的小程序开发全流程,涵盖技术选型、环境搭建、源码导入、接口对接及功能实现。采用Laravel/Symfony框架,结合MySQL/PostgreSQL数据库,使用WebSocket实现实时通信,并集成IM SDK实现音视频聊天。前端使用Uni-app开发,支持跨平台运行。教程包含完整部署流程与安全优化方案,助力快速搭建高性能、安全稳定的小程序系统。
371 5
|
6月前
|
应用服务中间件 Linux 网络安全
技术指南:如何把docsify项目部署到基于CentOS系统的Nginx中。
总结 与其他部署方法相比,将docsify项目部署到基于CentOS系统的Nginx中比较简单。以上步骤应当帮助你在不花费太多时间的情况下,将你的项目顺利部署到Nginx中。迈出第一步,开始部署你的docsify项目吧!
303 14
|
弹性计算 运维 监控
快速部署 Nginx 社区版
Nginx是一个高性能的HTTP和反向代理服务器。Nginx在计算巢上提供了社区版服务,您无需自行配置云主机,即可在计算巢上快速部署Nginx服务、实现运维监控,从而方便地基于Nginx搭建您自己的应用。本文介绍使用如何通过计算巢快速部署Nginx社区版。
快速部署 Nginx 社区版
|
9月前
|
应用服务中间件 PHP nginx
当你的nginx服务器和php服务器不在一起的时候,这个nginx 的root目录问题
两个服务器的网站代码目录需要对齐,docker容器里面也是一样
|
tengine 应用服务中间件 Linux
Tengine、Nginx安装PHP命令教程
要在阿里云Linux上安装PHP,请先更新YUM源并启用PHP 8.0仓库,然后安装PHP及相关扩展。通过`php -v`命令验证安装成功后,需修改Nginx配置文件以支持PHP,并重启服务。最后,创建`phpinfo.php`文件测试安装是否成功。对于CentOS系统,还需安装EPEL源和Remi仓库,其余步骤类似。完成上述操作后,可通过浏览器访问`http://IP地址/phpinfo.php`测试安装结果。
|
NoSQL 关系型数据库 Redis
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
mall在linux环境下的部署(基于Docker容器),docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongodb、minio详细教程,拉取镜像、运行容器
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
下一篇
oss云网关配置