docker — php-fpm Сброс соединения по пиру

Я пытаюсь настроить php-fpm на образе Docker.

Вот сервис в моем docker-compose.yml:

wordpress-service:
build:
context: .
dockerfile: Dockerfile-wordpress
image: riffsy-web-wordpress:latest
restart: always
links:
- wordpress-mysql
depends_on:
- wordpress-mysql
expose:
- "8000"environment:
- DB_NAME=wordpress
- DB_USER=wordpress
- DB_PASSWORD=password123
- DB_HOST=wordpress-mysql
- DB_PORT=3306
ports:
- "8000:8000"

Образ Docker использует эту команду:

CMD php-fpm7.0 --fpm-config /etc/php-fpm.conf

Вот мой php-fpm conf:

[global]

error_log = /dev/stderr
log_level = debug
daemonize = no

[www]
listen = 8000
listen.allowed_clients = 127.0.0.1
user = www-data
group = www-data
pm = dynamic
pm.max_children = 6
pm.start_servers = 2
pm.min_spare_servers = 1
pm.max_spare_servers = 4
pm.max_requests = 500
request_terminate_timeout = 120s
catch_workers_output = yes

Я поставил listen.allowed_clients = 127.0.0.1 потому что в противном случае я получил сообщения об отказе в соединении; в конечном итоге мне понадобится php-fpm, чтобы принимать подключения с любого IP, потому что я не знаю, какой IP будет у моего образа Nginx, и это не имеет значения, поскольку мое изображение php-fpm не будет публично подключено к Интернету ,

Я побежал docker exec авторизоваться на работающем образе и запустить wget проверить сервер:

root@428d78fd58df:/srv# wget 127.0.0.1:8000
--2016-09-12 07:55:13--  http://127.0.0.1:8000/
Connecting to 127.0.0.1:8000... connected.
HTTP request sent, awaiting response... Read error (Connection reset by peer) in headers.
Retrying.

--2016-09-12 07:55:14--  (try: 2)  http://127.0.0.1:8000/
Connecting to 127.0.0.1:8000... connected.
HTTP request sent, awaiting response... Read error (Connection reset by peer) in headers.
Retrying.

--2016-09-12 07:55:16--  (try: 3)  http://127.0.0.1:8000/
Connecting to 127.0.0.1:8000... connected.
HTTP request sent, awaiting response... Read error (Connection reset by peer) in headers.
Retrying.

^C

Консоль не выводит ничего, кроме:

wordpress-service_1  | [12-Sep-2016 08:01:09.757039] DEBUG: pid 5, fpm_pctl_perform_idle_server_maintenance(), line 379: [pool www] currently 0 active children, 2 spare children, 2 running children. Spawning rate 1

1

Решение

Проблема в том, что php-fpm не использует протокол http, он использует fastcgi. Единственный способ связаться с ним — настроить Nginx на использование fastcgi.

5

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]