PHP-FPM的原理及使用

最近有人问我,一个Api请求的整个运行周期,在解答这个问题的过程中,发现自己对php-fpm相关的知识点不熟,以下是自己的相关总结。

一 为什么要使用php-fpm

出现的原因很简单,早期的Web Server只能处理HTML等静态文件,随着动态语音,比如PHP的出现,Web Server无法处理这种请求。于是CGI协议出现了,它的全称是Common Gateway Interface(公共网关接口),它 解决不同语言解释器与Web Server的通信问题。开发者可以按照CGI协议的要求使用任何语言编写程序,这样就能实现语言解释器同Web Server的通信,比如php-cgi程序。

但是,Web Server每收到一个请求,都会去fork一个cgi进程,请求结束之后再kill掉这个进程。这样有1000个请求,就需要fork、kill php-cgi进程1000次。这样的话,访问量一旦上来,Web Server就扛不住了。于是就出现了出现了cgi的改良版本,fast-cgi。php-fpm就是fastcgi的实现。

二 Php-fpm的原理说明

Php-fpm即Php-Fastcgi Process Manager,是 FastCGI 的实现。它提供了进程管理的功能,就是用于调度管理php解释器php-cgi的程序(因为php-cgi只只是个CGI程序,他自己本身只能解析请求,返回结果,不会进程管理)。进程包含 master 进程和 worker 进程两种进程。master 进程只有一个,负责监听端口,接收来自 Web Server 的请求,而 worker 进程则一般有多个(具体数量根据实际需要配置),每个进程内部都嵌入了一个 PHP 解释器,是 PHP 代码真正执行的地方。

三 Php-fpm如何使用

Php-fpm如何使用,说得更直白一点就是如何与nginx结合,怎么获取得到用户的请求。关于如何配置 Nginx + FPM 的文章,网上有很多,基本上如下所示:

server {
    listen       80; #监听80端口,接收http请求
    server_name  www.xxxxx.com; #就是网站地址
    root /root/html/www; # 代码路径
    #路由到网站根目录时候的处理
    location / {
        index index.php; #跳转到 www.xxxxx.com/index.php
        autoindex on;
    }   

    #请求网站下php文件的时候,被反向代理到php-fpm
    location ~ \.php$ {
        include /usr/local/etc/nginx/fastcgi.conf; #加载nginx的fastcgi模块
        fastcgi_intercept_errors on;
        fastcgi_pass   127.0.0.1:9000; #fastcgi进程监听的IP地址和端口
    }
}

这样,外界若有请求(php代码),则会被nginx转发到127.0.0.1:9000(当然,采用fastcgi_pass unix:/tmp/php-cgi.sock;也是可以的)。fpm(master进程)监听该端口号,发现有请求过来 ,就启动worker 进程去处理。这样整个过程(nginx转向fpm)就完成了。流程图如下:

Sea Bridge

古之立大志者,不惟有超世之才 亦必有坚韧不拔之志!

发表评论