专栏首页Web技术布道师困扰已久的问题 cgi、fastcgi、PHP-fpm 汇总

困扰已久的问题 cgi、fastcgi、PHP-fpm 汇总

一个模糊的概念

无论是php,python编程语言,还是apache,nginx服务器对于cgi协议是个绕不开的话题。安装,部署都会经常的看到,那么它们到底是干什么的,网上的答案非常的多!今天通过它们进行一波汇总,彻底告别这个难关。参考: https://www.dayuzy.com/?p=476

HTTP到cgi协议

当浏览器的客户端输入网站走http协议到了web服务器,比如apache,这个大家都很清楚。web服务器没有处理php文件的功能,就会请求php解释器( php-cgi.exe )。或者,不是PHP文件,比如是python文件,web服务器也会去请求python的解释器。既然这么多解释器,不能没有一个协议规定它们的标准,否则乱套了,这时候 cgi协议就出来了 ,说白了就是 apache/nginx 和后端的脚本语言(php,python等)交互之间制定的协议。

php-cgi是什么

在windows系统上面,安装了php后,在安装目录下面有下面三个文件:

php.exe
php-cgi.exe
php-win.exe

以上的三个文件互不影响,我本地测试删除两个另外一个也能用。

在命令行运行一个php文件

F:\softwares\phpStudy\PHPTutorial\php\php-7.2.1-nts>
F:\softwares\phpStudy\PHPTutorial\php\php-7.2.1-nts> php F:\softwares\phpStudy\PHPTutorial\index.php
Hello World #php.exe运行结果
F:\softwares\phpStudy\PHPTutorial\php\php-7.2.1-nts>php-cgi F:\softwares\phpStudy\PHPTutorial\index.php
X-Powered-By: PHP/7.2.1 #php-cgi.exe运行结果
Content-type: text/html; charset=UTF-8 #php-cgi.exe运行结果

Hello World #php-cgi.exe运行结果
F:\softwares\phpStudy\PHPTutorial\php\php-7.2.1-nts>php-win 
F:\softwares\phpStudy\PHPTutorial\index.php #php-win.exe运行,结果是空行

F:\softwares\phpStudy\PHPTutorial\php\php-7.2.1-nts>

apache如何支持php

apache调用php有三种方式,模块、cgi、FastCgi,这些方法网上都能找到,下面说明一下原理。

  1. 模块:这是apache独有的对php支持,nginx是没有这种方式的,通过这种方式apache就可以直接处理php脚本了,至于是多进程、多线程要取决于apache的工作方式。参加: Apache三种工作模式介绍与配置
  2. cgi(通用网关接口):当apache有php脚本需要处理时,通过走cgi协议调用php解释器 php-cgi.exe ,并且 php-cgi.exe 会读取 php.ini 配置文件,作为apache的子进程。这里有个缺点:客户端浏览器的请求多了,apache创建的子进程会特别多,并且每次都重新读取 php.ini 配置文件。
  3. FastCgi就是为了解决cgi的问题,制定的协议。该协议规定, php-cgi.exe 我不再做你apache的子进程了,我独立了,这样你轻松了吧!我单独构成一个服务,这个服务规定一个master主进程,再启用几个worker进程。master负责对 php.ini 等配置文件,以及接收apache发过来的请求,分配给worker进程进行处理。这样就构成了 apache 作为客户端, FastCgi协议程序 作为服务端。这个 FastCgi协议程序 就是PHP-fpm,它就是 FastCgi协议 的具体实现。

cgi和FastCgi是什么

它们都是协议,FastCgi解决了cgi的一些缺点。

php-cgi.exe和PHP-fpm是什么?

php-cgi.exe 是解释器,也可以当作一个简易的 cgi/FastCgi 管理器。比如在windows系统中nginx是如何与php结合的呢?linux通过php-fpm,但是windows没有php-fpm,这个时候打开任务管理器会发现 CGI/FastCGI(32位) 这个进程,nginx就是反向代理给它的。

location ~ \.php(.*)$  {
            fastcgi_pass   127.0.0.1:9000; #这里的9000端口就是``php-cgi.exe``监听的
            fastcgi_index  index.php;
            fastcgi_split_path_info  ^((?U).+\.php)(/?.+)$;
            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
            fastcgi_param  PATH_INFO  $fastcgi_path_info;
            fastcgi_param  PATH_TRANSLATED  $document_root$fastcgi_path_info;
            include        fastcgi_params;
        }

我们在命令行查看一下 php-cgi.exe 的帮助,它也是可以进行一些简单的配置的。

F:\softwares\phpStudy\PHPTutorial\php\php-7.2.1-nts>php-cgi -h
Usage: php [-q] [-h] [-s] [-v] [-i] [-f <file>]
       php <file> [args...]
  -a               Run interactively
  -b <address:port>|<port> Bind Path for external FASTCGI Server mode
  -C               Do not chdir to the script's directory
  -c <path>|<file> Look for php.ini file in this directory
  -n               No php.ini file will be used
  -d foo[=bar]     Define INI entry foo with value 'bar'
  -e               Generate extended information for debugger/profiler
  -f <file>        Parse <file>.  Implies `-q'
  -h               This help
  -i               PHP information
  -l               Syntax check only (lint)
  -m               Show compiled in modules
  -q               Quiet-mode.  Suppress HTTP Header output.
  -s               Display colour syntax highlighted source.
  -v               Version number
  -w               Display source with stripped comments and whitespace.
  -z <file>        Load Zend extension <file>.
  -T <count>       Measure execution time of script repeated <count> times.

php-fpm又是什么?

PHP-fpm 这个就是 FastCgi进程管理器 ,它的概念并不模糊!它启动服务监听端口,通过nginx反向代理给它,并且它自己内置php解释器。但是,但是windows上面不能使用 PHP-fpm

对于客户端浏览器而言, nginx/apache 是服务端。对于 PHP-fpm 而言, apache/nginx 是客户端。

总结

cgi、fastcgi是协议,是标准,是web服务器到后台脚本语言之间的协议。

php-cgi和PHP-fpm是程序,至于php-cgi是解释器还是管理器,网上怎么说的也有,并且它也能监听端口处理web服务器代理的请求,那它就是简单的 cgi/FastCgi进程管理器 管理器吧!

参考

搞不清FastCgi与PHP-fpm之间是个什么样的关系

PHP 连接方式介绍以及如何攻击 PHP-FPM

php-cgi和php-fpm有什么关系?

Apache三种工作模式介绍与配置

php手册:在旧的Windows系统上安装

php-cgi和php-fpm有什么关系?

原文:https://segmentfault.com/a/1190000019550920

本文分享自微信公众号 - PHP技术大全(phpgod)

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-06-24

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • PHP获取HTTP body内容的方法总结

    有时候我们获取数据时需要根据Header中的格式来解析,比如上传一个json而不是一个文本。这里用到了 php输入|输出流 的概念。

    猿哥
  • php://output和php://stdout的区别

    PHP包含了以php://开头的一系列输出输出流,如php://stdin, php://stdout等。今天查看代码时,忽然想到一个问题:php://outp...

    猿哥
  • 介绍个PHP以太坊包Laravel-ethereum

    Laravel-ethereum是一个简单的Laravel服务提供程序,提供Generic JSON RPC和管理API。

    猿哥
  • 【代码审计】EasySNS_V1.6远程图片本地化导致Getshell

    ESPHP开发框架基础上开发而成的EasySNS极简社区为全新数据库架构和程序结构。本文以EasySNS_V1.6作为代码审计的目标,分享一个远程图片本地化导致...

    Bypass
  • 一次粗心,让我学会了如何搭建php环境,坑越多越有成就感

    线上php程序出现了问题,商品页面无法正常访问,对于java开发工程师来说有一些困难,因为之前没有相关经验,一开始自己内心也是挺排斥的,然而问题摆在那里,只能去...

    用户4361942
  • Google SQL 注入搜索列表:2018最新版

    这是一个Google注入查询列表(傻瓜式),更新于2018年;根据一些关键字和URL结构,可批量查询出存在安全隐患的站点。

    HACK学习
  • Centos7.3 部署 LAMP 架构动静分离

    一、LAMP动静分离 当需要搭建一个高效的web架构时,采用动静分离无疑是最好的选择,这篇博文将写下来LAMP的动静分离部署方式。

    小手冰凉
  • php的各种 I/O流 以及用法

    或许有人看到这个会懵逼,这是什么东东?这有啥用?这咋用?我是谁?我在哪?我要去往何处?

    仙士可
  • 关于PHP的cli模式

    用户2475223
  • 使用docker方式部署"禅道"

    禅道 项目管理软件 是国产的开源项目管理软件,专注研发项目管理,内置需求管理、任务管理、bug管理、缺陷管理、用例管理、计划发布等功能,实现了软件的完整生命周期...

    小老鼠

扫码关注云+社区

领取腾讯云代金券