之间的差异和缺点/优势:Fast-CGI、CGI、Mod-PHP、SuPHP、PHP-FPM

Gac*_*cek 96 php fastcgi mod-php php-fpm suphp

很少有不同的php“包装器”(?)。它们之间有什么区别?试图谷歌一些,但似乎无法找到信息。(mod-php 不能用谷歌搜索)。

为什么我可以选择一个而不是另一个?

Ale*_*ník 177

CGI 和 FastCGI 是两个非 PHP 特有的协议:

  • CGI 脚本是一种如何在 HTTP 请求到达时运行服务器端脚本(不仅仅是 PHP!)的方法。在此设置中,Web 服务器为每个传入请求启动一个新的 CGI 进程,从而导致显着的性能开销。

  • FastCGI是一种“更好的 CGI”——为了解决 CGI 的局限性,FastCGI 作为服务器(TCP 或 UNIX)运行,以便可以跨请求重用资源。

支持 PHP 的网络服务器可以配置如下:

  • mod_php是一个运行 PHP 的 Apache 模块。在这个设置中,PHP 请求是在 Apache 进程下处理的,它附带的一切:PHP 进程在 Apache 配置中定义,PHP 在 Apache 用户和权限下运行等。

  • PHP-FPM是 PHP 的 FastCGI 实现。在此设置中,PHP-FPM 作为独立的 FastCGI 服务器运行,Apache 使用 FastCGI 模块(例如mod_fcgidmod_fastcgimod_proxy_fcgi(Apache 2.4+)连接到它)。在这个配置中,权限、进程相关的东西以及其他一切都由 PHP-FPM 服务器控制。性能与mod_php.

  • SuPHP -这用来解决的一些不足mod_php有关权限:用mod_phpPHP脚本在Apache用户/组下运行,但mod_suphp可以运行这些脚本为不同的用户。suPHP 不再维护,不应使用。

  • CGI/FastCGI - 我根据评论中的一个问题添加了这个。在不知道设置细节的情况下,PHP 可以使用任何其他 FastCGI 实现作为 FastCGI 服务器运行 - 如另一个问题所述。我不使用这个设置,也没有看到比 PHP-FPM 有任何好处。

  • CGI - PHP 也可以作为 good-ol 的 CGI 脚本运行,但我无法想象一个好的用例,除了与一些非常过时的环境的兼容性。

关于这些不同方法的优缺点,我只坚持使用mod_phpPHP-FPM,涵盖两个主要用例:

  • mod_php在某些 Docker 设置中可能很有用,在这些设置中,您希望交付运行支持 PHP 的 Web 服务器的单个容器。一切都作为单个进程运行的事实使 Docker 容器配置更容易。另一方面,在带有 Web 服务器的单个容器中运行 PHP-FPM 服务器将需要使用supervisord、高级 bash 脚本或其他一些方法进行流程编排,这与编写 Docker 容器的最佳实践背道而驰。

  • PHP-FPM 是一种更强大的方法,可以更好地分离关注点,因此 PHP-FPM 服务器可以与 Web 服务器分开配置、(性能)调整和维护。这也允许在池中或与 web 服务器不同的机器上运行 PHP-FPM 服务器。如上所述,对于 Docker 容器,在这种情况下建议使用单独的 PHP-FPM 和 webserver 容器,从而使配置更复杂(也更强大)。PHP-FPM 方法也是使用nginx网络服务器的唯一方法,因为它的 PHP 模块 AFAIK 不存在。

可以在此处找到我对上述两种方法的 Docker 实现:

该实现旨在与我的 Kubernetes 集群中的一些旧项目和新项目一起使用。随意使用它。

所以,TLDR:

  • CGI、FastCGI是协议;CGI 很慢,FastCGI 快得多
  • mod_php 和 PHP-FPM 是运行 PHP 的两种主要方式
  • mod_SuPHP是一种用于解决mod_php缺点的方法。它已过时,应改用 PHP-FPM。

  • 我不知道 ISPConfig 面板真正使用的是什么,但 PHP 以 PHP-FPM 运行意味着,PHP 将启动它自己的内置 FastCGI 服务器并通过 FastCGI 协议侦听请求。HTTP 服务器将接收来自 Internet 的请求,照常处理它们,如果页面需要使用 PHP 运行,请求将通过 FastCGI 协议传递给 PHP,并将结果发送回浏览器。将其视为位于浏览器和 PHP (PHP-FPM FastCGI) 服务器之间的 HTTP 服务器。PHP-FPM 是 FastCGI 协议的一个实现。 (14认同)
  • php-fpm 就是为了消除初始化成本。php-fpm 预启动几个 php 进程,准备处理请求,并让它们休眠直到请求进来——这意味着它可以比传统的 cgi 响应快得多,因为当请求到来时 php 已经在运行,而不是传统的 CGI,为每个请求启动一个新的 php 进程,php-fpm 也不会在处理请求后关闭 php 进程,而是继续重用相同的进程。- 启动和停止进程的开销为 0,php-fpm 响应速度更快。启动和停止过程需要时间。 (4认同)
  • @landed PHP-FPM 二进制文件是自 5.3.3 或 5.4.0 以来每个 PHP 发行版的一部分(请查看:https://php-fpm.org/),对于特定的 PHP 版本。 (2认同)