PHP連接Nginx服務(wù)器并解析Nginx日志的方法
php與nginx整合
PHP-FPM也是一個(gè)第三方的FastCGI進(jìn)程管理器,它是作為PHP的一個(gè)補(bǔ)丁來(lái)開(kāi)發(fā)的,在安裝的時(shí)候也需要和PHP源碼一起編譯,也就是說(shuō)PHP-FPM被編譯到PHP內(nèi)核中,因此在處理性能方面更加優(yōu)秀;同時(shí)它在處理高并發(fā)方面也比spawn-fcgi引擎好很多,因此,推薦Nginx+PHP/PHP-FPM這個(gè)組合對(duì)PHP進(jìn)行解析。
FastCGI 的主要優(yōu)點(diǎn)是把動(dòng)態(tài)語(yǔ)言和HTTP Server分離開(kāi)來(lái),所以Nginx與PHP/PHP-FPM經(jīng)常被部署在不同的服務(wù)器上,以分擔(dān)前端Nginx服務(wù)器的壓力,使Nginx專(zhuān)一處理靜態(tài)請(qǐng)求和轉(zhuǎn)發(fā)動(dòng)態(tài)請(qǐng)求,而PHP/PHP-FPM服務(wù)器專(zhuān)一解析PHP動(dòng)態(tài)請(qǐng)求
#fastcgi
FastCGI是一個(gè)可伸縮地、高速地在HTTP server和動(dòng)態(tài)腳本語(yǔ)言間通信的接口。多數(shù)流行的HTTP server都支持FastCGI,包括Apache、Nginx和lighttpd等,同時(shí),F(xiàn)astCGI也被許多腳本語(yǔ)言所支持,其中就有PHP。
FastCGI是從CGI發(fā)展改進(jìn)而來(lái)的。傳統(tǒng)CGI接口方式的主要缺點(diǎn)是性能很差,因?yàn)槊看蜨TTP服務(wù)器遇到動(dòng)態(tài)程序時(shí)都需要重新啟動(dòng)腳本解析器來(lái)執(zhí)行解析,然后結(jié)果被返回給HTTP服務(wù)器。這在處理高并發(fā)訪(fǎng)問(wèn)時(shí),幾乎是不可用的。另外傳統(tǒng)的CGI接口方式安全性也很差,現(xiàn)在已經(jīng)很少被使用了。
FastCGI接口方式采用C/S結(jié)構(gòu),可以將HTTP服務(wù)器和腳本解析服務(wù)器分開(kāi),同時(shí)在腳本解析服務(wù)器上啟動(dòng)一個(gè)或者多個(gè)腳本解析守護(hù)進(jìn)程。當(dāng)HTTP服務(wù)器每次遇到動(dòng)態(tài)程序時(shí),可以將其直接交付給FastCGI進(jìn)程來(lái)執(zhí)行,然后將得到的結(jié)果返回給瀏覽器。這種方式可以讓HTTP服務(wù)器專(zhuān)一地處理靜態(tài)請(qǐng)求或者將動(dòng)態(tài)腳本服務(wù)器的結(jié)果返回給客戶(hù)端,這在很大程度上提高了整個(gè)應(yīng)用系統(tǒng)的性能。
Nginx+FastCGI運(yùn)行原理
Nginx不支持對(duì)外部程序的直接調(diào)用或者解析,所有的外部程序(包括PHP)必須通過(guò)FastCGI接口來(lái)調(diào)用。FastCGI接口在Linux下是socket,(這個(gè)socket可以是文件socket,也可以是ip socket)。為了調(diào)用CGI程序,還需要一個(gè)FastCGI的wrapper(wrapper可以理解為用于啟動(dòng)另一個(gè)程序的程序),這個(gè)wrapper綁定在某個(gè)固定socket上,如端口或者文件socket。當(dāng)Nginx將CGI請(qǐng)求發(fā)送給這個(gè)socket的時(shí)候,通過(guò)FastCGI接口,wrapper接納到請(qǐng)求,然后派生出一個(gè)新的線(xiàn)程,這個(gè)線(xiàn)程調(diào)用解釋器或者外部程序處理腳本并讀取返回?cái)?shù)據(jù);接著,wrapper再將返回的數(shù)據(jù)通過(guò)FastCGI接口,沿著固定的socket傳遞給Nginx;最后,Nginx將返回的數(shù)據(jù)發(fā)送給客戶(hù)端,這就是Nginx+FastCGI的整個(gè)運(yùn)作過(guò)程。
php與nginx整合
php.ini:php的主配置文件
[root@server79 php-5.4.12]# cp php.ini-production /usr/local/lnmp/php/etc/php.ini
拷貝php的啟動(dòng)腳本
[root@server79 fpm]# pwd /root/php-5.4.12/sapi/fpm [root@server79 fpm]# cp init.d.php-fpm /etc/init.d/php-fpm
給啟動(dòng)腳本加可執(zhí)行權(quán)限
[root@server79 fpm]# chmod +x /etc/init.d/php-fpm [root@server79 ~]# vim /usr/local/lnmp/php/etc/php.ini cgi.fix_pathinfo=0 date.timezone = /Asia/Shanghai [root@server79 ~]# cp /usr/local/lnmp/php/etc/php-fpm.conf.default /usr/local/lnmp/php/etc/php-fpm.conf [root@server79 etc]# vim php-fpm.conf
打開(kāi)注釋pid = run/php-fpm.pid
php-fpm.conf文件參數(shù)解析
PHP的全局配置文件是php.ini,在上面的步驟中,已經(jīng)將此文件復(fù)制到了/usr/local/lnmp/php/etc/php.ini下??梢愿鶕?jù)每個(gè)應(yīng)用需求的不同,對(duì)php.ini進(jìn)行相應(yīng)的配置。
下面重點(diǎn)介紹PHP-FPM引擎的配置文件。
根據(jù)上面指定的安裝路徑,PHP-FPM的默認(rèn)配置文件為/usr/local/lnmp/php/etc/php-fpm.conf。
php-fpm.conf是一個(gè)XML格式的純文本文件,其內(nèi)容很容易看明白。這里重點(diǎn)介紹幾個(gè)重要的配置標(biāo)簽:
標(biāo)簽listen_address是配置fastcgi進(jìn)程監(jiān)聽(tīng)的IP地址以及端口,默認(rèn)是127.0.0.1:9000。
listen = 127.0.0.1:9000
標(biāo)簽user和group用于設(shè)置運(yùn)行FastCGI進(jìn)程的用戶(hù)和用戶(hù)組。需要注意的是,這里指定的用戶(hù)和用戶(hù)組要和Nginx配置文件中指定的用戶(hù)和用戶(hù)組一致。
user = nginx group = nginx
標(biāo)簽max_children用于設(shè)置FastCGI的進(jìn)程數(shù)。根據(jù)官方建議,小于2GB內(nèi)存的服務(wù)器,可以只開(kāi)啟64個(gè)進(jìn)程,4GB以上內(nèi)存的服務(wù)器可以開(kāi)啟200個(gè)進(jìn)程。
<value name="max_children">5</value>
標(biāo)簽request_terminate_timeout用于設(shè)置FastCGI執(zhí)行腳本的時(shí)間。默認(rèn)是0s,也就是無(wú)限執(zhí)行下去,可以根據(jù)情況對(duì)其進(jìn)行修改。
<value name="request_terminate_timeout">0s</value>
標(biāo)簽rlimit_files用于設(shè)置PHP-FPM對(duì)打開(kāi)文件描述符的限制,默認(rèn)值為1024。這個(gè)標(biāo)簽的值必須和Linux內(nèi)核打開(kāi)文件數(shù)關(guān)聯(lián)起來(lái),例如要將此值設(shè)置為65535,就必須在Linux命令行執(zhí)行'ulimit -HSn 65536'。
<value name="rlimit_files">1024</value>
標(biāo)簽max_requests指明了每個(gè)children最多處理多少個(gè)請(qǐng)求后便會(huì)被關(guān)閉,默認(rèn)的設(shè)置是500。
pm.max_requests = 500
標(biāo)簽allowed_clients用于設(shè)置允許訪(fǎng)問(wèn)FastCGI進(jìn)程解析器的IP地址。如果不在這里指定IP地址,Nginx轉(zhuǎn)發(fā)過(guò)來(lái)的PHP解析請(qǐng)求將無(wú)法被接受。
<value name="allowed_clients">127.0.0.1</value>
5.管理FastCGI進(jìn)程
在配置完php-fpm后,就可以啟動(dòng)FastCGI進(jìn)程了。啟動(dòng)fastcgi進(jìn)程有兩種方式:
/usr/local/php/bin/php-cgi --fpm
/usr/local/php/sbin/php-fpm start
建議采用第二種方式啟動(dòng)FastCGI進(jìn)程。
/usr/local/php/sbin/php-fpm還有其他參數(shù),具體為start|stop|quit|restart|reload|logrotate。
每個(gè)啟動(dòng)參數(shù)的含義如下:
- q start,啟動(dòng)PHP的FastCGI進(jìn)程。
- q stop,強(qiáng)制終止PHP的FastCGI進(jìn)程。
- q quit,平滑終止PHP的FastCGI進(jìn)程。
- q restart,重啟PHP的FastCGI進(jìn)程。
- q reload,重新加載PHP的php.ini。
- q logrotate,重新啟用log文件。
- reload是個(gè)很重要的參數(shù),它可以在PHP的FastCGI進(jìn)程不中斷的情況下重新加載改動(dòng)過(guò)的php.ini,因此通過(guò)php-fpm可以平滑變更FastCGI模式下的PHP設(shè)置。
[root@server79 etc]# /etc/init.d/php-fpm start
配置nginx的主配置文件,打開(kāi)與php的接口
[root@server79 conf]# pwd /usr/local/lnmp/nginx/conf [root@server79 conf]# vim nginx.conf user nginx; # location ~ \.php$ { root html; fastcgi_pass 127.0.0.1:9000; //本地9000端口 fastcgi_index index.php; # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; include fastcgi.conf; } [root@server79 conf]# nginx -t^C [root@server79 conf]# nginx -s reload^C [root@server79 html]# pwd /usr/local/lnmp/nginx/html [root@server79 html]# cat index.php <?php phpinfo()?>
測(cè)試:瀏覽器中輸入192.168.0.179/index.php,出現(xiàn)php頁(yè)面
PHP解析Nginx日志
nginx日志格式
access_log日志格式
log_format main '$server_name$remote_addr$remote_user[$time_local]"$request"' '$status$body_bytes_sent"$http_referer"' '"$http_user_agent""$http_x_forwarded_for"';
日志參數(shù)
server_name : 虛擬主機(jī)的主機(jī)名稱(chēng)
remote_addr : 遠(yuǎn)程客戶(hù)端的ip地址
remote_user : 遠(yuǎn)程客戶(hù)端用戶(hù)名稱(chēng)
time_local : 訪(fǎng)問(wèn)的時(shí)間與時(shí)區(qū)
status : 記錄請(qǐng)求返回的http狀態(tài)碼
body_bytes_sent : 發(fā)送給客戶(hù)端的文件主體內(nèi)容的大小
http_referer : 從哪個(gè)頁(yè)面鏈接訪(fǎng)問(wèn)過(guò)來(lái)
http_user_agent : 客戶(hù)端瀏覽器信息
http_x_forwarded_for : 客戶(hù)端的真實(shí)ip
日志分割符
使用特殊的不可打印字符^A(ctrl+v,ctrl+a)作為日志分割符
根據(jù)關(guān)鍵字過(guò)濾文件內(nèi)容
需求
根據(jù)http的請(qǐng)求里是否有“weibo”這個(gè)關(guān)鍵字提取文件的內(nèi)容
php代碼
/** * Description:按行讀取文件內(nèi)容進(jìn)行過(guò)濾匹配 * * @return array */ function readFileContent ($filename) { $weibo_content = array(); $fh = @fopen($filename, 'r'); if ($fh) { while (! feof($fh)) { $row = fgets($fh, 4096); $row_arr = explode("", $row); if (isset($row_arr[3]) && preg_match('/weibo/', $row_arr[3])) { $weibo_content[] = $row_arr; } } } fclose($fh); return $weibo_content; }
- nginx日志配置指令詳解
- 詳解用ELK來(lái)分析Nginx服務(wù)器日志的方法
- nginx服務(wù)器中access_log日志分析與配置詳解
- shell腳本分析 nginx日志訪(fǎng)問(wèn)次數(shù)最多及最耗時(shí)的頁(yè)面(慢查詢(xún))
- Nginx日志統(tǒng)計(jì)分析的常用命令總結(jié)
- Nginx服務(wù)狀態(tài)監(jiān)控的方法
- Nginx配置檢測(cè)服務(wù)狀態(tài)的實(shí)現(xiàn)方法
- python監(jiān)控nginx端口和進(jìn)程狀態(tài)
- Nginx狀態(tài)監(jiān)控以及日志分析詳解
相關(guān)文章
PHP實(shí)現(xiàn)對(duì)xml進(jìn)行簡(jiǎn)單的增刪改查(CRUD)操作示例
這篇文章主要介紹了PHP實(shí)現(xiàn)對(duì)xml進(jìn)行簡(jiǎn)單的增刪改查(CRUD)操作,結(jié)合簡(jiǎn)單實(shí)例形式分析了php針對(duì)xml文件數(shù)據(jù)進(jìn)行載入、修改等相關(guān)操作技巧,需要的朋友可以參考下2017-05-05php實(shí)現(xiàn)utf-8和GB2312編碼相互轉(zhuǎn)換函數(shù)代碼
php實(shí)現(xiàn)utf-8和GB2312編碼相互轉(zhuǎn)換的一個(gè)函數(shù),有需要的朋友可以參考下2013-02-02PHP cookie與session會(huì)話(huà)基本用法實(shí)例分析
這篇文章主要介紹了PHP cookie與session會(huì)話(huà)基本用法,結(jié)合實(shí)例形式分析了PHP cookie與session會(huì)話(huà)基本存儲(chǔ)、設(shè)置、刪除等相關(guān)使用方式,需要的朋友可以參考下2019-11-11解析zend Framework如何自動(dòng)加載類(lèi)
本篇文章是對(duì)zend Framework如何自動(dòng)加載類(lèi)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06深入理解PHP中mt_rand()隨機(jī)數(shù)的安全
mt_rand()使用mersennetwister算法返回隨機(jī)整數(shù),這個(gè)大家都知道,但下面這篇文章主要給大家介紹的是關(guān)于PHP中mt_rand()隨機(jī)數(shù)安全的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-10-10PHP Session變量不能傳送到下一頁(yè)的解決方法
在PHP中使用過(guò)SESSION的朋友可能會(huì)碰到這么一個(gè)問(wèn)題,SESSION變量不能跨頁(yè)傳遞。這令我苦惱了好些日子,最終通過(guò)查資料思考并解決了這個(gè)問(wèn)題。2009-11-11PHP基于數(shù)組實(shí)現(xiàn)的分頁(yè)函數(shù)實(shí)例
這篇文章主要介紹了PHP基于數(shù)組實(shí)現(xiàn)的分頁(yè)函數(shù)實(shí)例,是非常實(shí)用的一個(gè)技巧,需要的朋友可以參考下2014-08-08php實(shí)現(xiàn)的數(shù)字驗(yàn)證碼及數(shù)字運(yùn)算驗(yàn)證碼
這篇文章主要介紹了php實(shí)現(xiàn)的數(shù)字驗(yàn)證碼及數(shù)字運(yùn)算驗(yàn)證碼,以實(shí)例形式分別描述了php實(shí)現(xiàn)數(shù)字驗(yàn)證碼及數(shù)學(xué)運(yùn)算驗(yàn)證碼的相關(guān)技巧,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-07-07