![Apache 2.4 + PHP-FPM + 使用 Unix 套接字的 ProxyPassMatch](https://rvso.com/image/726377/Apache%202.4%20%2B%20PHP-FPM%20%2B%20%E4%BD%BF%E7%94%A8%20Unix%20%E5%A5%97%E6%8E%A5%E5%AD%97%E7%9A%84%20ProxyPassMatch.png)
我嘗試使用 Unix 套接字設定 Apache v2.4 + PHP-FPM + ProxyPassMatch。
使用 Debian 9 Stretch、PHP v5.6.37、PHP v7.0.31、Apache v2.4.25。
我的虛擬主機設定如下(000-default.conf):
<VirtualHost *:80>
ServerAdmin webmaster@localhost
ServerName local.lc
DocumentRoot /var/www
ProxyPassMatch "^/(.*\.php(/.*)?)$" "unix:/var/run/php5.6-fpm.sock|fcgi://localhost/var/www/"
<Directory />
Options FollowSymLinks
AllowOverride None
</Directory>
<Directory /var/www/>
Options Indexes FollowSymLinks MultiViews
AllowOverride None
Order allow,deny
allow from all
</Directory>
ScriptAlias /cgi-bin/ /usr/lib/cgi-bin/
<Directory "/usr/lib/cgi-bin">
AllowOverride None
Options +ExecCGI -MultiViews +SymLinksIfOwnerMatch
Order allow,deny
Allow from all
</Directory>
ErrorLog ${APACHE_LOG_DIR}/error.log
# Possible values include: debug, info, notice, warn, error, crit,
# alert, emerg.
LogLevel warn
CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>
我執行了以下命令:
sudo apt-get install php7.0-cli php7.0-fpm php-pear libapache2-mod-fcgid
sudo apt install software-properties-common
# add repo to get PHP5
sudo apt-get -y install apt-transport-https lsb-release ca-certificates
sudo curl https://packages.sury.org/php/apt.gpg | apt-key add -
sudo wget -O /etc/apt/trusted.gpg.d/php.gpg https://packages.sury.org/php/apt.gpg
sudo echo 'deb https://packages.sury.org/php/ stretch main' > /etc/apt/sources.list.d/deb.sury.org.list
sudo apt-get update
sudo apt-get install php5.6-cli php5.6-fpm
sudo apt-get install php7.0 php7.0-fpm
sudo a2enconf php5.6-fpm
sudo systemctl reload apache2
sudo a2dismod php5 php7 php5.6 php7.0 mpm_prefork
sudo a2enmod actions alias proxy_fcgi mpm_worker
sudo systemctl restart apache2 php5.6-fpm php7.0-fpm
更改後使用以下命令重新啟動伺服器:
sudo systemctl restart apache2 php5.6-fpm php7.0-fpm
當我加載時,我得到空白頁面
http://local.lc/
我的基於 Windows 的開發電腦上的網站。 local.lc 位於「hosts」檔案中。
我在日誌(/var/log/apache2/error.log)中看到以下內容:
[Tue Aug 28 23:24:26.685004 2018] [mpm_worker:notice] [pid 43104:tid 140487559849152] AH00295: caught SIGTERM, shutting down
[Tue Aug 28 23:24:27.001054 2018] [:notice] [pid 43531:tid 139833116394688] ModSecurity for Apache/2.9.1 (http://www.modsecurity.org/) configured.
[Tue Aug 28 23:24:27.001189 2018] [:notice] [pid 43531:tid 139833116394688] ModSecurity: APR compiled version="1.5.2"; loaded version="1.5.2"
[Tue Aug 28 23:24:27.001205 2018] [:notice] [pid 43531:tid 139833116394688] ModSecurity: PCRE compiled version="8.39 "; loaded version="8.39 2016-06-14"
[Tue Aug 28 23:24:27.001223 2018] [:notice] [pid 43531:tid 139833116394688] ModSecurity: LUA compiled version="Lua 5.1"
[Tue Aug 28 23:24:27.001236 2018] [:notice] [pid 43531:tid 139833116394688] ModSecurity: YAJL compiled version="2.1.0"
[Tue Aug 28 23:24:27.001248 2018] [:notice] [pid 43531:tid 139833116394688] ModSecurity: LIBXML compiled version="2.9.4"
[Tue Aug 28 23:24:27.001498 2018] [:notice] [pid 43531:tid 139833116394688] ModSecurity: StatusEngine call: "2.9.1,Apache/2.4.25 (Debian),1.5.2/1.5.2,8.39/8.39 2016-06-14,Lua 5.1,2.9.4,cb"
[Tue Aug 28 23:24:27.135554 2018] [:notice] [pid 43531:tid 139833116394688] ModSecurity: StatusEngine call successfully sent. For more information visit: http://status.modsecurity.org/
[Tue Aug 28 23:24:28.005175 2018] [mpm_worker:notice] [pid 43532:tid 139833116394688] AH00292: Apache/2.4.25 (Debian) OpenSSL/1.0.2l mod_fcgid/2.3.9 configured -- resuming normal operations
[Tue Aug 28 23:24:28.005270 2018] [core:notice] [pid 43532:tid 139833116394688] AH00094: Command line: '/usr/sbin/apache2'
我在日誌中沒有看到任何有用的信息。
知道可能出了什麼問題嗎?
為什麼預設頁面未載入?
答案1
您的設定中缺少DirectoryIndex
指令,因此在請求類似以下的 URL 時http://local.lc/Apache 不知道要在磁碟上尋找什麼檔案並提供服務,而不僅僅是向您顯示目錄的內容(這可能不是您想要的)。
假設您使用的是 PHP-FPM,我希望您設定DirectoryIndex
類似的值index.php
,然後由 PHP-FPM 處理。
直接使用類似實用程式的工具測試 PHP-FPMcgi-fcgi
將允許您在 Apache 仍然無法工作的情況下繞過它。
答案2
訪問http://local.lc/index.html
沒有產生任何頁面,error.log 中也沒有錯誤。
DirectoryIndex
使用@bodgit 建議的指令修復此問題並http://local.lc/index.php
立即載入後,會在 error.log 中產生錯誤。
查看error.log,現在我看到以下錯誤訊息:
No such file or directory: AH02454: FCGI: attempt to connect to Unix domain socket /var/run/php5.6-fpm.sock (localhost) failed".
檢查/var/run/php5.6-fpm.sock
路徑沒有找到,但是/var/run/php/php5.6-fpm.sock
找到了。
我的虛擬主機設定中的路徑已修復,如下所示 (000-default.conf):
<VirtualHost *:80>
ServerAdmin webmaster@localhost
ServerName local.lc
DocumentRoot /var/www
ProxyPassMatch "^/(.*\.php(/.*)?)$" "unix:/var/run/php/php5.6-fpm.sock|fcgi://localhost/var/www/"
<Directory />
Options FollowSymLinks
AllowOverride None
</Directory>
<Directory /var/www/>
Options Indexes FollowSymLinks MultiViews
AllowOverride None
Order allow,deny
allow from all
</Directory>
ScriptAlias /cgi-bin/ /usr/lib/cgi-bin/
<Directory "/usr/lib/cgi-bin">
AllowOverride None
Options +ExecCGI -MultiViews +SymLinksIfOwnerMatch
Order allow,deny
Allow from all
</Directory>
ErrorLog ${APACHE_LOG_DIR}/error.log
# Possible values include: debug, info, notice, warn, error, crit,
# alert, emerg.
LogLevel warn
CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>
因此,修復虛擬主機設定檔中的路徑,然後載入
http://local.lc/index.php
頁面,現在顯示:
「有用!」。
問題已解決!