一个模糊的概念
无论是 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 脚本文件。 -
php-cgi.exe
:通过 CGI 或 FastCGI 在 web 服务器 (apache) 上运行 PHP 时可以使用的 CGI 可执行文件,可以理解为 php 解释器(也有说是官方的 FastCGI 进程管理器,至于是什么文章后面再分析,这里就当作 php 解释器)。 -
php-win.exe
:用于在不使用命令行窗口的情况下执行 PHP 脚本的 PHP 可执行文件(例如,使用 Windows GUI 的 PHP 应用程序)。
以上的三个文件互不影响,我本地测试删除两个另外一个也能用。
在命令行运行一个 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,这些方法网上都能找到,下面说明一下原理。
- 模块:这是 apache 独有的对 php 支持,nginx 是没有这种方式的,通过这种方式 apache 就可以直接处理 php 脚本了,至于是多进程、多线程要取决于 apache 的工作方式。参加:Apache 三种工作模式介绍与配置
- cgi(通用网关接口):当 apache 有 php 脚本需要处理时,通过走 cgi 协议调用 php 解释器
php-cgi.exe
,并且php-cgi.exe
会读取php.ini
配置文件,作为 apache 的子进程。这里有个缺点:客户端浏览器的请求多了,apache 创建的子进程会特别多,并且每次都重新读取php.ini
配置文件。 - 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 有什么关系?