Назад | Перейти на главную страницу

PHP-FPM - Ошибка 503 - Не удалось подключиться к сокету домена Unix.

Я получаю на сервере эту ошибку (CentOs 7):

[proxy:debug] proxy_util.c(2209): [client 80.251.245.153:61902] AH00944: connecting fcgi://127.0.0.1/data/webs/dev/index.php to 127.0.0.1:8000
[proxy:debug] proxy_util.c(2246): [client 80.251.245.153:61902] AH02545: fcgi: has determined UDS as /tmp/php56-fpm.sock
[proxy:debug] proxy_util.c(2418): [client 80.251.245.153:61902] AH00947: connected /data/webs/dev/index.php to httpd-UDS:0
[proxy:error] (2)No such file or directory: AH02454: FCGI: attempt to connect to Unix domain socket /tmp/php56-fpm.sock (*) failed
[proxy_fcgi:error] AH01079: failed to make connection to backend: httpd-UDS
[proxy:debug] proxy_util.c(2171): AH00943: FCGI: has released connection for (*)

Socket Exists, я пытался изменить разрешения на 777, но не работал:

 ls -l /tmp/php56-fpm.sock
-rw-rw----. 1 apache apache 0 Feb 17 16:11 /tmp/php56-fpm.sock

Настройка прослушивания PHP-FPM www.conf (полный файл находится здесь: https://pastebin.com/uD5GsMna):

слушайте = / tmp / php56-fpm.sock

Виртуальный хост:

<VirtualHost *:80>
   ServerName dev.stavebninyfranek.com
   DocumentRoot "/data/webs/dev"
   <FilesMatch "\.php$">
     SetHandler  "proxy:unix:/tmp/php56-fpm.sock|fcgi://127.0.0.1"
   </FilesMatch> 
 </VirtualHost>

Мои файлы конфигурации (httpd.conf): https://pastebin.com/XS6cDuFQ

Я попробовал изменить сокет, изменить разрешение на apache: пользователь apache, но я не знаю, в чем проблема.

Спасибо

Это потенциально вызвано конфигурацией systemd на Apache, например, на Centos 7 по умолчанию служба настроена с помощью:

PrivateTmp=true

Это означает, что он получает свой собственный подкаталог в / tmp, видимый как / tmp, поэтому он не может видеть файлы в / tmp, добавленные другими программами. Решением было бы не использовать / tmp для ваших сокетов php-fpm (более безопасно, чем установка вышеуказанного значения false).

(Я понимаю, что по крайней мере в одном случае используется производная Debian, но она также использует systemd!)

Поли.

изменить пользователя и группу на вашего текущего пользователя apache

/etc/php-fpm.d/www.conf 

** пользователь и группа должны быть одинаковыми в /etc/http/conf/http.conf

Затем выполните

chown -R user.user /run/php-fpm/www.conf

** изменить на своего пользователя

У меня была такая же проблема после обновления apache с 2.4.10 до 2.4.24. Со старым apache подключение к fcgi работало с сокетом в /tmp, в то время как новый apache выдал ошибку (2)No such file or directory. Перемещение сокета в /var/run решил проблему.

Глядя на исходный код для mod_proxy, Я обнаружил, что на новом apache путь должен быть относительно пути, указанного как DefaultRuntimeDir. В моей конфигурации это установлено в /etc/apache2/apache2.conf и он также использует некоторое определение из /etc/apache2/envvars.

Я решил эту проблему, когда использовал

/var/run/php5-fpm.sock

вместо того /tmp/ и его работа. Но почему нельзя использовать какую-то другую папку вместо /var/run/ ?