首頁  >  文章  >  後端開發  >  詳解PHP-FPM的安裝與配置

詳解PHP-FPM的安裝與配置

青灯夜游
青灯夜游轉載
2021-03-02 18:07:434327瀏覽

本篇文章帶大家詳細了解PHP-FPM,介紹一下PHP-FPM的安裝和全域設定。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。

詳解PHP-FPM的安裝與配置

【推薦學習:《PHP影片教學》】

作用


#PHP-FPM(PHP FastCGI Process Manager)意:PHP FastCGI 進程管理器,用於管理PHP 進程池的軟體,用於接受web伺服器的請求。

PHP-FPM提供了更好的PHP進程管理方式,可以有效控制記憶體和進程、可以平滑重載PHP配置。

(1). 為什麼會出現php-fpm

fpm的出現全部因為php-fastcgi出現。為了很好的管理php-fastcgi而實現的一個程式

(2). 什麼是php-fastcgi

php-fastcgi 只是一個cgi程式,只會解析php請求,並且傳回結果,不會管理(因此才出現的php-fpm)。

(3)為什麼不叫php-cgi

其實在php-fastcgi出現之前是有一個php-cgi存在的,只是它的執行效率低下,因此被php-fastcgi取代。

(4)那fastcgi和cgi有什麼差別呢?

親們,這區別就大了,當一個服務web-server(nginx)分發過來請求的時候,透過匹配後綴知道該請求是個動態的php請求,會把這個請求轉給php。

在cgi的年代,思想比較保守,總是一個請求過來後,去讀取php.ini裡的基礎配置信息,初始化執行環境,每次都要不停的去創建一個進程,讀取配置,初始化環境,返回數據,退出進程,久而久之,啟動進程的工作變的乏味無趣特別累。

當php來到了5的時代,大家對這種工作方式特別反感,想偷懶的人就拼命的想,我可不可以讓cgi一次啟動一個主進程(master),讓他只讀取一次配置,然後在啟動多個工作進程(worker),當一個請求來的時候,透過master傳遞給worker這樣就可以避免重複勞動了。於是就產生了fastcgi。

(5)fastcgi這麼好,啟動的worker用完怎麼辦?

當worker不夠的時候,master會透過配置裡的信息,動態啟動worker,等空閒的時候可以收回worker

(6)到現在還是沒明白php-fpm 是個什麼東西?

就是來管理啟動一個master進程和多個worker進程的程式.

PHP-FPM 會建立一個主進程,控制何時以及如何將HTTP請求轉送給一個或多個子程序處理。 PHP-FPM主程序也控制著什
麼時候創建(處理Web應用更多的流量)和銷毀(子進程運行時間太久或不再需要了)

PHP子進程。 PHP-FPM進程池中的每個進程存在的時間都比單一HTTP請求長,可以處

理10、50、100、500或更多的HTTP請求。 安裝


PHP在 5.3.3 之後已經把php-fpm併入到php的核心程式碼中了。所以php-fpm不需要單獨的下載安裝。

要想php支援php-fpm,只要在編譯php原始碼的時候帶 --enable-fpm 就可以了。 全域設定

在Centos中,PHP-FPM 的主設定檔是 /etc/php7/php-fpm.conf。

指定一段時間內有指定個子程序失效了,PHP-FPM重啟:

#在指定的一段时间内,如果失效的PHP-FPM子进程数超过这个值,PHP-FPM主进程将优雅重启。
emergency_restart_threshold = 10

#设定emergency_restart_interval 设置采用的时间跨度。
emergency_restart_interval = 1m
設定進程池

PHP-FPM設定檔其餘的內容是一個名為Pool Defintions的區域。這個區域裡的設定用戶設定每個PHP-FPM進程池。 PHP-FPM進程池中是一系列相關的PHP子進程。

通常一個PHP應用程式有自己一個進程池

Centos在PHP-FPM主設定檔的頂端引入進程池定義檔:

include=/etc/php7/php-fpm.d/*.conf

www.conf 是PHP-FPM進程池的預設設定檔。

user= nobody
#拥有这个 PHP-FPM进程池中子进程的系统用户。要把这个设置的值设用的非根用户的用户名。

group = nobody
#拥有这个 PHP-FPM进程池中子进程的系统用户组。要把这个设置的值设应用的非根用户所属的用户组名。

listen=[::]]:9000
#PHP-FPM进程池监听的IP地址和端口号,让 PHP-FPM只接受 nginx从这里传入的请求。

listen. allowed clients =127.0.0.1
#可以向这个 PHP-FPM进程池发送请求的IP地址(一个或多个)。

pm.max children =51
#这个设置设定任何时间点 PHP-FPM进程池中最多能有多少个进程。这个设置没有绝对正确的值,你应该测试你的PHP应用,确定每个PHP进程需要使用多少内存,然后把这个设置设为设备可用内存能容纳的PHP进程总数。对大多数中小型PHP应用来说,每个PHP进程要使用5~15MB内存(具体用量可能有差异)。 假设我们使用设备为这个PHP-FPM进程池分配了512MB可用内存,那么可以把这个设置设为(512MB总内存)/(每个进程使用10MB) = 51个进程。

...

編輯保存,重新啟動PHP-FPM主程序:

sudo systemctl restart php-fpm.service

PHP-FPM進程池的設定詳情請參閱 http://php.net/manual/install.fpm.configuration.php 參考Company開發環境

測試環境的設定如下:

[www]
user = nobody               #进程的发起用户和用户组,用户user是必须设置,group不是  nobody 任意用户
group = nobody

listen = [::]:9000          #监听ip和端口,[::] 代表任意ip
chdir = /app                #在程序启动时将会改变到指定的位置(这个是相对路径,相对当前路径或chroot后的“/”目录) 

pm = dynamic                #选择进程池管理器如何控制子进程的数量  static:  对于子进程的开启数路给定一个锁定的值(pm.max_children)   dynamic:  子进程的数目为动态的,它的数目基于下面的指令的值(以下为dynamic适用参数)
pm.max_children = 16        #同一时刻能够存货的最大子进程的数量
pm.start_servers = 4        #在启动时启动的子进程数量
pm.min_spare_servers = 2    #处于空闲"idle"状态的最小子进程,如果空闲进程数量小于这个值,那么相应的子进程会被创建
pm.max_spare_servers = 16   #最大空闲子进程数量,空闲子进程数量超过这个值,那么相应的子进程会被杀掉。

catch_workers_output = Yes  #将worker的标准输出和错误输出重定向到主要的错误日志记录中,如果没有设置,根据FastCGI的指定,将会被重定向到/dev/null上

生產環境設定:轉送請求給PHP-FPM

nginx為例:

server {
       listen       83;
       server_name mobile.com;
       root /app/mobile/web/;

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   /usr/share/nginx/html;
        }

        location / {
                index  index.html index.htm index.php;
                # Redirect everything that isn't a real file to index.php
                try_files $uri $uri/ /index.php$is_args$args;
        }

        #把HTTP请求转发给PHP-FPM进程池处理
        location ~ .*\.php                 include fastcgi_params;
                fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
                fastcgi_pass   192.168.33.30:9000;      #监听9000端口
                fastcgi_index  index.php;
                try_files $uri =404;
                #include fastcgi.conf;
        }
        location ~ /\.(ht|svn|git) {
                deny all;
        }
        access_log  /app/wwwlogs/access.log;
        error_log   /app/wwwlogs/error.log;
}
##思考


  • [x] 思考問題:
  • 伺服器的並發量取決哪些因素?

PHP-FPM最大進程數、nginx並發數

(nginx只是充當代理伺服器的角色)、記憶體的佔用、cpu的開銷

#伺服器的QPS(每秒處理請求數) = 平均請求連線數*(1/回應時間);

併發量= 有效時間*QPS;###
  • 解決:
  1. 加上機器分流
    • 根據並發量計算需加機器
  2. 增加單機新能
    • 開啟php的opcache,增加記憶體空間
    • 接快取系統
    • sql最佳化
    • php最佳化
      ...

更多程式相關知識,請造訪:程式設計影片! !

以上是詳解PHP-FPM的安裝與配置的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:cnblogs.com。如有侵權,請聯絡admin@php.cn刪除