這篇文章主要介紹“怎么解決php fpm出錯問題”,在日常操作中,相信很多人在怎么解決php fpm出錯問題問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”怎么解決php fpm出錯問題”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
成都網(wǎng)絡公司-成都網(wǎng)站建設(shè)公司成都創(chuàng)新互聯(lián)十年經(jīng)驗成就非凡,專業(yè)從事成都網(wǎng)站建設(shè)、做網(wǎng)站,成都網(wǎng)頁設(shè)計,成都網(wǎng)頁制作,軟文推廣,1元廣告等。十年來已成功提供全面的成都網(wǎng)站建設(shè)方案,打造行業(yè)特色的成都網(wǎng)站建設(shè)案例,建站熱線:028-86922220,我們期待您的來電!
php fpm出錯的解決辦法:1、在nginx的目錄中創(chuàng)建個php的檢測腳本index.php;2、找到nginx加載php配置的部分;3、修改路徑即可。
本文操作環(huán)境:linux5.9.8系統(tǒng)、PHP5.5版、Dell G3電腦。
如何解決php fpm出錯問題?
nginx調(diào)用php-fpm出錯解決方法和nginx配置詳解
這篇文章介紹了nginx調(diào)用php-fpm出錯的解決方法,最后給出了nginx配置方法,需要的朋友可以參考下
裝完了nginx和php-5.5,配置好了nginx調(diào)用php后,就開始啟動php-fpm。
使用下面的命令
代碼如下:
/usr/local/php/sbin/php-fpm
就可以啟動了。
在nginx的目錄中創(chuàng)建個php的檢測腳本index.php
結(jié)果在打開http://localhost/index.php
悲劇的發(fā)現(xiàn)居然無法打開 。查看日志文件,看了下報錯原因
代碼如下:
2013/07/01 22:34:26 [error] 3214#0: *64 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream, client: 192.168.168.19, server: localhost, request: "GET /index.php HTTP/1.1", upstream: "fastcgi://127.0.0.1:9000", host: "192.168.168.140"
查看下端口 ??吹絧hp-fpm的9000端口已經(jīng)打開了,說明php-fpm是沒什么問題的,問題出在了nginx上了??赡苁俏业呐渲梦募袉栴}。
找到nginx加載php配置的那塊。另外參考了下網(wǎng)上nginx的配置文件。
在第69行有一個調(diào)用腳本路徑
代碼如下:
fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
我把路徑改下,改成下面的就可以了。
代碼如下:
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; http://localhost/index.php
可以出現(xiàn)php的版本信息了。
大家還可以參考下面的配置方法
php-fpm不用再依賴其它的fastcgi啟動器,比如lighttpd的spawn-fcgi。
php-fpm的使用非常方便,配置都是在php-fpm.ini的文件內(nèi)
而啟動,重啟都可以從php/sbin/php-fpm中進行
更方便的是修改php.ini后可以直接使用php-fpm reload進行加載 無需殺掉進程就可以完成php.ini的修改加載
結(jié)果顯示使用php-fpm可以使php有不小的性能提升
php-fpm控制的進程.cpu回收的速度比較慢.內(nèi)存分配的很均勻
而spawn-cgi控制的進程CPU下降的很快.而內(nèi)存分配的比較不均勻.
有很多進程似乎未分配到,而另外一些卻占用很高.
可能是由于進程任務分配的不均勻?qū)е碌?而這也導致了總體響應速度的下降
而php-fpm合理的分配.導致總體響應的提到以及任務的平均
使用php-fpm需要在php源碼上打補丁,然后重新編譯php
一.下載php-fpm
wget http://cn.php.net/get/php-5.2.8.tar.gz/from/www.php.net/mirror wget http://php-fpm.anight.org/downloads/head/php-5.2.8-fpm-0.5.10.diff.gz
與php-5.2.9在同一級目錄
gzip -cd php-5.2.8-fpm-0.5.10.diff.gz | patch -d php-5.2.9 -p1
補丁打好以后,編譯php的時候增加了下面幾個參數(shù):
–enable-fpm 激活fastcgi模式的fpm支持
–with-fpm-conf php-fpm的配置文件(默認是PREFIX/etc/php-fpm.conf)
–with-fpm-log php-fpm的日志文件(默認是PREFIX/logs/php-fpm.log)
–with-fpm-pid php-fpm的pid文件(默認是PREFIX/logs/php-fpm.pid) ./configure --prefix=/EBS/php \ --with-config-file-path=/EBS/php/etc \ --enable-fastcgi \ --enable-fpm \ --OTHERS
注:--enable-fastcgi \ 需要在--enable-fpm \的前面,否則,fpm不能編譯上。
二.編譯好php后,修改配置文件
vi /EBS/php/etc/php-fpm.conf
需要注意下面幾處配置
127.0.0.1:9000
這個表示php的fastcgi進程監(jiān)聽的ip地址以及端口
nobody nobody
表示php的fastcgi進程以什么用戶以及用戶組來運行,默認該行是注釋掉的,需要打開
0
是否顯示php錯誤信息
5
最大的子進程數(shù)目
運行php-fpm:
php-fpm用一個程序來控制fastcgi進程,這個文件在$PREFIX/sbin/php-fpm
/usr/local/php/sbin/php-fpm
該程序有如下參數(shù):
start 啟動php的fastcgi進程
stop 強制終止php的fastcgi進程
quit 平滑終止php的fastcgi進程
restart 重啟php的fastcgi進程
reload 重新加載php的php.ini
logrotate 重新啟用log文件
也就是說,在修改了php.ini之后,我們可以使用
/usr/local/php/sbin/php-fpm reload
這樣,就保持了在php的fastcgi進程持續(xù)運行的狀態(tài)下,又重新加載了php.ini。
代碼如下:
user www www; worker_processes 10; error_log logs/error.log notice; pid logs/nginx.pid; #Specifies the value for maximum file descriptors that can be opened by this process. worker_rlimit_nofile 51200; events { use epoll; worker_connections 51200; } http { include mime.types; default_type application/octet-stream; charset gb2312; server_names_hash_bucket_size 128; #sendfile on; #tcp_nopush on; keepalive_timeout 60; tcp_nodelay on; gzip on; gzip_min_length 1k; gzip_buffers 4 8k; gzip_http_version 1.1; gzip_types text/plain application/x-javascript text/css text/html application/xml; { listen 80; server_name 192.168.1.2; index index.html index.htm index.php; root /EBS/www; if (-d $request_filename) { rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent; } location ~ .*\.php?$ { include fcgi.conf fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; } log_format access '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" $http_x_forwarded_for'; access_log logs/access.log access; } }
新建配置文件
代碼如下:
/usr/local/nginx/conf/fcgi.conf
注:nginx自帶了一個配置文件,/usr/local/nginx/conf/fastcgi_params,該配置文件缺少粗體字體的部分,會造成訪問php文件時報404錯誤。
復制代碼代碼如下:
fastcgi_param GATEWAY_INTERFACE CGI/1.1; fastcgi_param SERVER_SOFTWARE nginx; fastcgi_param QUERY_STRING $query_string; fastcgi_param REQUEST_METHOD $request_method; fastcgi_param CONTENT_TYPE $content_type; fastcgi_param CONTENT_LENGTH $content_length; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param SCRIPT_NAME $fastcgi_script_name; fastcgi_param REQUEST_URI $request_uri; fastcgi_param DOCUMENT_URI $document_uri; fastcgi_param DOCUMENT_ROOT $document_root; fastcgi_param SERVER_PROTOCOL $server_protocol; fastcgi_param REMOTE_ADDR $remote_addr; fastcgi_param REMOTE_PORT $remote_port; fastcgi_param SERVER_ADDR $server_addr; fastcgi_param SERVER_PORT $server_port; fastcgi_param SERVER_NAME $server_name; # PHP only, required if PHP was built with --enable-force-cgi-redirect #fastcgi_param REDIRECT_STATUS 200;
四 配置XCache
1、安裝xcache模塊
wgethttp://xcache.lighttpd.net/pub/Releases/1.2.2/xcache-1.2.2.tar.gz tar -xvzf xcache-1.2.2.tar.gz cd xcache-1.2.2 /usr/local/php/bin/phpize ./configure --with-php-config=/usr/local/php/bin/php-config --enable-xcache --enable-xcache-optimizer make make install
2、計算密碼的md5值
echo -n "password"|md5sum 5f4dcc3b5aa765d61d8327deb882cf99
3、配置XCache
;注:zend_extension,用來加載zend的擴展,是絕對路徑, extension是相對路徑,相對于extension_dir的相對路徑,非zend擴展
如果你更改路徑以后,一定要apachectl stop后再start,而不要restart。
vi /usr/local/php/etc/php.ini
添加:
代碼如下:
[xcache-common] zend_extension = /usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/xcache.so [xcache.admin] ; Change xcache.admin.user to your preferred login name xcache.admin.user = "admin" ; Change xcache.admin.pass to the MD5 fingerprint of your password ; Use md5 -s "your_secret_password" to find the fingerprint xcache.admin.pass = "5f4dcc3b5aa765d61d8327deb882cf99" [xcache] ; Change xcache.size to tune the size of the opcode cache xcache.size = 24M xcache.shm_scheme = "mmap" xcache.count = 2 xcache.slots = 8K xcache.ttl = 0 xcache.gc_interval = 0 ; Change xcache.var_size to adjust the size of variable cache xcache.var_size = 8M xcache.var_count = 1 xcache.var_slots = 8K xcache.var_ttl = 0 xcache.var_maxttl = 0 xcache.var_gc_interval = 300 xcache.test = Off xcache.readonly_protection = On xcache.mmap_path = "/tmp/xcache" xcache.coredump_directory = "" xcache.cacher = On xcache.stat = On xcache.optimizer = Off [xcache.coverager] xcache.coverager = On xcache.coveragedump_directory = ""
5、重啟PHP模塊
正常load之后,
在phpinfo顯出的信息內(nèi)
Zend這快應該會加上XCache的內(nèi)容
6、另外兩種加速模塊:
在我們的測試中,效果都要好于xcache,這3中加速不能同時存在兩種,有沖突。
6.1 apc
代碼如下:
wget http://pecl.php.net/get/APC-3.0.19.tgz cd APC-3.0.19 /usr/local/php/bin/phpize ./configure --enable-apc --enable-apc-mmap --with-apxs=/EBS/apache/bin/apxs --with-php-config=/EBS/php/bin/php-config make make install 6.2 eaccelerator wget http://bart.eaccelerator.net/source/0.9.5.3/eaccelerator-0.9.5.3.zip cd eaccelerator-0.9.5.3 /usr/local/php/bin/phpize ./configure --enable-eaccelerator=shared --with-php-config=/EBS/php/bin/php-config make make install vi php.ini zend_extension="/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/eaccelerator.so" eaccelerator.shm_size="16" eaccelerator.cache_dir="/tmp/eaccelerator" eaccelerator.enable="1" eaccelerator.optimizer="1" eaccelerator.check_mtime="1" eaccelerator.debug="0" eaccelerator.filter="" eaccelerator.shm_max="0" eaccelerator.shm_ttl="0" eaccelerator.shm_prune_period="0" eaccelerator.shm_only="0" eaccelerator.compress="1" eaccelerator.compress_level="9"
五、使用nginx對應多臺facgi服務器
思路:前端一臺nginx,用于做為負載均衡和處理靜態(tài)頁面。利用nginx的upstream模塊來將php請求分發(fā)到后段的php-fpm服務器上。
后端多臺php-fpm的服務器,只起php-fpm服務來處理php。
這樣做減少了php-fpm上的nginx服務,相當于少了一層。
到此,關(guān)于“怎么解決php fpm出錯問題”的學習就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
網(wǎng)站標題:怎么解決phpfpm出錯問題
網(wǎng)址分享:http://weahome.cn/article/gghocd.html