当前位置: 首页 > news >正文

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

2种部署方式简介

第一种

  • 前置1台nginx服务器做HTTP反向代理和负载均衡
  • 后面多态服务器部署Nginx Web服务和php-fpm提供的fast cgi服务

第二种

  • 前置1台nginx服务器做Web服务
  • 后面服务器只部署php-fpm服务,供nginx服务器调用
  • 前置1台nginx服务器,在调用后面多例php-fpm服务时,也可以做到负载均衡

如下图 :

对比

从系统设计角度

第一种部署是常见部署方式,大中小规模网站都能适用。

第二种,web服务和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协议格式化严格一些,解析起来速度更快一些。

从运维角度

  • 第一种是最常见的部署方式,后面所有服务器上的服务都是同构的,简单粗放。

  • 第二种则是将nginx和php-fpm单独分开部署,不同服务在服务器集群上的分布更加细致。通过统计Web服务中的压力分布,可以更加精细地利用硬件资源。运维成本也更高。

从开发测试角度

两种部署方式都不合适开发环境或测试环境,都仅适用于生产环境。

开发和测试环境把nginx和PHP部署到一台服务器上即可,也不需要反向代理和负载均衡。

总结

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

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

后记

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

转载请注明来源,原地址保持永久更新。 
博客首页:作程的技术博客 
文章标题:《Nginx 和 PHP 的两种部署方式比较》 
本文链接:https://it.zuocheng.net/compare-2-nginx-php-deployee-mode-zh

相关文章:

  • MVVM 简介
  • Android支付宝SDK开发笔记
  • Future模式-多任务并行汇总 or 同步任务回调
  • mysql组内排序取最大值
  • 科学家制作“更绿”香草
  • Advanced Auto Layout:Programmatically Creating Constraints
  • JavaScript中基本数据类型和引用数据类型的区别
  • 人类的情感需要与未来私人机器人助理
  • Linux后台研发超实用命令总结
  • 《转》python学习(5)--数据类型
  • spring data jpa自定义bean字段映射
  • Java 利用枚举实现单例模式
  • Bzoj3611 [Heoi2014]大工程
  • HashMap的简单实现
  • 【后缀自动机】hihocoder1441 后缀自动机一·基本概念
  • 【跃迁之路】【585天】程序员高效学习方法论探索系列(实验阶段342-2018.09.13)...
  • Angular6错误 Service: No provider for Renderer2
  • conda常用的命令
  • dva中组件的懒加载
  • github从入门到放弃(1)
  • JavaScript标准库系列——Math对象和Date对象(二)
  • Less 日常用法
  • Meteor的表单提交:Form
  • Shell编程
  • Vue小说阅读器(仿追书神器)
  • 不用申请服务号就可以开发微信支付/支付宝/QQ钱包支付!附:直接可用的代码+demo...
  • 二维平面内的碰撞检测【一】
  • 快速体验 Sentinel 集群限流功能,只需简单几步
  • 前端学习笔记之原型——一张图说明`prototype`和`__proto__`的区别
  • 深度解析利用ES6进行Promise封装总结
  • 树莓派 - 使用须知
  • 双管齐下,VMware的容器新战略
  • 看到一个关于网页设计的文章分享过来!大家看看!
  • #13 yum、编译安装与sed命令的使用
  • #14vue3生成表单并跳转到外部地址的方式
  • $(selector).each()和$.each()的区别
  • (二)斐波那契Fabonacci函数
  • (二)学习JVM —— 垃圾回收机制
  • (每日持续更新)信息系统项目管理(第四版)(高级项目管理)考试重点整理 第13章 项目资源管理(七)
  • (四)搭建容器云管理平台笔记—安装ETCD(不使用证书)
  • (轉)JSON.stringify 语法实例讲解
  • .[hudsonL@cock.li].mkp勒索病毒数据怎么处理|数据解密恢复
  • .NET Entity FrameWork 总结 ,在项目中用处个人感觉不大。适合初级用用,不涉及到与数据库通信。
  • .net 程序 换成 java,NET程序员如何转行为J2EE之java基础上(9)
  • .NET 简介:跨平台、开源、高性能的开发平台
  • .NET/C# 将一个命令行参数字符串转换为命令行参数数组 args
  • .NET和.COM和.CN域名区别
  • .pub是什么文件_Rust 模块和文件 - 「译」
  • [20171101]rman to destination.txt
  • [2021]Zookeeper getAcl命令未授权访问漏洞概述与解决
  • [android] 请求码和结果码的作用
  • [Angular] 笔记 8:list/detail 页面以及@Input
  • [AX]AX2012 SSRS报表Drill through action
  • [BUUCTF]-Reverse:reverse3解析
  • [CSS]文字旁边的竖线以及布局知识