PHP7中php.ini、php-fpm和www.conf 配置

程式設計師的貓發表於2021-02-09

php.ini是php執行核心配置檔案,下面是一些常用配置

extension_dir=””

● 設定PHP的擴充套件庫路徑

expose_php = Off

● 避免PHP資訊暴露在http頭中

display_errors = Off

● 避免暴露php呼叫mysql的錯誤資訊

log_errors = On

● 在關閉display_errors後開啟PHP錯誤日誌(路徑在php-fpm.conf中配置)

zend_extension=opcache.so extension=mysqli.so extension=pdo_mysql.so

● 設定PHP的opcache和mysql動態庫

date.timezone = PRC

● 設定PHP的時區

opcache.enable=1

● 開啟opcache

open_basedir = /usr/share/nginx/html;

● 設定PHP指令碼允許訪問的目錄(需要根據實際情況配置)

php-fpm.conf是php-fpm程式服務的配置檔案,下面是一些常用配置

error_log = /usr/local/php/logs/php-fpm.log

● 設定錯誤日誌的路徑

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

● 引入www.conf檔案中的配置(預設已設定)

php-fpm.conf 以及 www.conf的主要配置資訊

pid = run/php-fpm.pid

● pid設定,預設在安裝目錄中的var/run/php-fpm.pid,建議開啟

error_log = log/php-fpm.log

● 錯誤日誌,預設在安裝目錄中的var/log/php-fpm.log

log_level = notice

● 錯誤級別. 可用級別為: alert(必須立即處理), error(錯誤情況), warning(警告情況), notice(一般重要資訊), debug(除錯資訊). 預設: notice.

emergency_restart_threshold = 60

emergency_restart_interval = 60s

● 表示在emergency_restart_interval所設值內出現SIGSEGV或者SIGBUS錯誤的php-cgi程式數如果超過 emergency_restart_threshold個,php-fpm就會優雅重啟。這兩個選項一般保持預設值。

process_control_timeout = 0

● 設定子程式接受主程式複用訊號的超時時間. 可用單位: s(秒), m(分), h(小時), 或者 d(天) 預設單位: s(秒). 預設值: 0.

daemonize = yes

● 後臺執行fpm,預設值為yes,如果為了除錯可以改為no。在FPM中,可以使用不同的設定來執行多個程式池。 這些設定可以針對每個程式池單獨設定。

listen = 127.0.0.1:9000

● 監聽埠,即nginx中php處理的地址,一般預設值即可。可用格式為: ‘ip:port’, ‘port’, ‘/path/to/unix/socket’. 每個程式池都需要設定.

listen.backlog = -1

● backlog數,-1表示無限制,由作業系統決定,此行註釋掉就行。

listen.allowed_clients = 127.0.0.1

● 允許訪問FastCGI程式的IP,設定any為不限制IP,如果要設定其他主機的nginx也能訪問這臺FPM程式,listen處要設定成本地可被訪問的IP。預設值是any。每個地址是用逗號分隔. 如果沒有設定或者為空,則允許任何伺服器請求連線

listen.owner = www listen.group = www listen.mode = 0666

● unix socket設定選項,如果使用tcp方式訪問,這裡註釋即可。

user = www group = www

● 啟動程式的帳戶和組

php-fpm 程式池優化方法

pm = dynamic

● 對於專用伺服器,pm可以設定為static。

如何控制子程式,選項有static和dynamic。如果選擇static,則由pm.max_children指定固定的子程式數。如果選擇dynamic,則由下開引數決定:

pm.max_children

● 靜態方式下開啟的php-fpm程式數量,在動態方式下他限定php-fpm的最大程式數(這裡要注意pm.max_spare_servers的值只能小於等於pm.max_children)

pm.start_servers

● 動態方式下的起始php-fpm程式數量。

pm.min_spare_servers

● 保證空閒程式數最小值,如果空閒程式小於此值,則建立新的子程式

pm.max_spare_servers

● 保證空閒程式數最大值,如果空閒程式大於此值,此進行清理

● 如果dm設定為static,那麼其實只有pm.max_children這個引數生效。系統會開啟引數設定數量的php-fpm程式。php-fpm一個程式大概會佔20m-40m的記憶體,所以他的數字大小的設定要根據你的實體記憶體的大小來設定,還要注意到其他的記憶體佔用,如資料庫,系統程式等,來確定以上4個引數的設定值!

● 如果dm設定為dynamic,4個引數都生效。系統會在php-fpm執行開始時啟動pm.start_servers個php-fpm程式,然後根據系統的需求動態在pm.min_spare_servers和pm.max_spare_servers之間調整php-fpm程式數。引數要求pm.start_servers的值在pm.min_spare_servers和pm.max_spare_servers之間。

pm.max_requests = 1000

● 設定每個子程式重生之前服務的請求數.

● 最大處理請求數是指一個php-fpm的worker程式在處理多少個請求後就終止掉,master程式會重新respawn一個新的。

● 這個配置的主要目的是避免php直譯器或程式引用的第三方庫造成的記憶體洩露。

對於可能存在記憶體洩漏的第三方模組來說是非常有用的. 如果設定為 ‘0’ 則一直接受請求. 等同於 PHP_FCGI_MAX_REQUESTS 環境變數. 預設值: 0.

pm.status_path = /status

● FPM狀態頁面的網址. 如果沒有設定, 則無法訪問狀態頁面. 預設值: none. munin監控會使用到

ping.path = /ping

● FPM監控頁面的ping網址. 如果沒有設定, 則無法訪問ping頁面. 該頁面用於外部檢測FPM是否存活並且可以響應請求. 請注意必須以斜線開頭 (/)。

ping.response = pong

● 用於定義ping請求的返回相應. 返回為 HTTP 200 的 text/plain 格式文字. 預設值: pong.

request_terminate_timeout = 0

● 設定單個請求的超時中止時間. 該選項可能會對php.ini設定中的’max_execution_time’因為某些特殊原因沒有中止執行的指令碼有用. 設定為 ‘0’ 表示 ‘Off’.當經常出現502錯誤時可以嘗試更改此選項。

request_slowlog_timeout = 10s

● 當一個請求該設定的超時時間後,就會將對應的PHP呼叫堆疊資訊完整寫入到慢日誌中. 設定為 ‘0’ 表示 ‘Off’

slowlog = log/$pool.log.slow

● 慢請求的記錄日誌,配合request_slowlog_timeout使用

rlimit_files = 1024

● 設定檔案開啟描述符的rlimit限制. 預設值: 系統定義值預設可開啟控制程式碼是1024,可使用 ulimit -n檢視,ulimit -n 2048修改。

rlimit_core = 0

● 設定核心rlimit最大限制值. 可用值: ‘unlimited’ 、0或者正整數. 預設值: 系統定義值.

chroot =

● 啟動時的Chroot目錄. 所定義的目錄需要是絕對路徑. 如果沒有設定, 則chroot不被使用.

chdir =

● 設定啟動目錄,啟動時會自動Chdir到該目錄. 所定義的目錄需要是絕對路徑. 預設值: 當前目錄,或者/目錄(chroot時)

catch_workers_output = yes

● 重定向執行過程中的stdout和stderr到主要的錯誤日誌檔案中. 如果沒有設定, stdout 和 stderr 將會根據FastCGI的規則被重定向到 /dev/null . 預設值: 空.`

clear_env = no          

● 清理環境

variables_order

● PHP中的$_ENV是一個包含伺服器端環境變數的陣列。它是PHP中一個超級全域性變數,我們可以在PHP 程式的任何地方直接訪問它。

● $_ENV只是被動的接受伺服器端的環境變數並把它們轉換為陣列元素,你可以嘗試直接輸出它。

● 當你想看看一個變數中究竟有什麼東西在裡面時,我所知道的方式有三種:

1、var_dump($_ENV);

2、print_r($_ENV);

3、foreach($_ENV as $key=>$val){echo $key.’——–’.$val.’
‘;}

● 這三種方式中,第一種我覺得最方便而且輸出的內容格式清晰。

● 由於$_ENV變數是取決於伺服器的環境變數的,從不同的伺服器上獲取的$_ENV變數列印出的結果可能是完全不同的。所以無法像$_SERVER 那樣列出完整的列表。以下是$_ENV 陣列包含的比較通用的元素:

● 有時候,$_ENV會為空,其原因通常是php的配置檔案php.ini的配置項為:variables_order = “GPCS”。要想讓$_ENV的值不為空,那麼variables_order的值應該加上一個大寫字母“E”,即:variables_order = “EGPCS”。

● 上述配置表示了PHP接受的外部變數來源及順序,EGPCS是Environment、Get、Post、Cookies、Server的縮寫。如果variables_order 的配置中缺少E ,則PHP 無法接受環境變數,那麼$_ENV 也就為空了。

● 由於開啟$_ENV,即variables_order = “EGPCS”會導致一些效能損失,按php官方的說法是,在生產環境中,不推薦使用。他們更推薦使用getenv (string $varname)函式來獲取Environment中的值,而這點需要在程式設計時就注意到。如果程式設計時用了$_ENV而variables_order中又沒有配置為variables_order = “EGPCS”,則程式執行時可能會報錯。

常見錯誤及解決辦法整理

請求的超時中止時間未設定

● request_terminate_timeout的值如果設定為0或者過長的時間,可能會引起PHP 指令碼會一直執行下去。這樣,當所有的 php-cgi 程式都卡在 file_get_contents() 函式時,這臺 Nginx+PHP 的 WebServer 已經無法再處理新的 PHP 請求了,Nginx 將給使用者返回“502 Bad Gateway”。設定一個

PHP指令碼最大執行時間是必要的,但是,治標不治本。例如改成 30s,如果發生 file_get_contents() 獲取網頁內容較慢的情況,這就意味著 150 個 php-cgi 程式,每秒鐘只能處理 5 個請求,WebServer 同樣很難避免”502 Bad Gateway”。解決辦法是request_terminate_timeout設定為10s或者一個合理的值,或者給file_get_contents加一個超時引數!

max_requests引數配置不當

● max_requests引數配置不當,可能會引起間歇性502錯誤:

pm.max_requests = 1000

● 設定每個子程式重生之前服務的請求數. 對於可能存在記憶體洩漏的第三方模組來說是非常有用的. 如果設定為 ‘0’ 則一直接受請求. 等同於 PHP_FCGI_MAX_REQUESTS 環境變數. 預設值: 0.

這段配置的意思是,當一個 PHP-CGI 程式處理的請求數累積到 500 個後,自動重啟該程式。

● 但是為什麼要重啟程式呢?

● 一般在專案中,我們多多少少都會用到一些 PHP 的第三方庫,這些第三方庫經常存在記憶體洩漏問題,如果不定期重啟 PHP-CGI 程式,勢必造成記憶體使用量不斷增長。因此 PHP-FPM 作為 PHP-CGI 的管理器,提供了這麼一項監控功能,對請求達到指定次數的 PHP-CGI 程式進行重啟,保證記憶體使用量不增長。

php-fpm的慢日誌,debug及異常排查神器

● request_slowlog_timeout設定一個超時的引數,slowlog設定慢日誌的存放位置,tail -f /var/log/www.slow.log即可看到執行過慢的php過程。

大家可以看到經常出現的網路讀取超過、Mysql查詢過慢的問題,根據提示資訊再排查問題就有很明確的方向了。

本作品採用《CC 協議》,轉載必須註明作者和本文連結
你還差得遠吶!

相關文章