Я пытаюсь создать соединения между контейнерами докеров. Один контейнер с php5-fpm и второй с nginx.
Конфигурация для php5-fpm по умолчанию, всего несколько изменений:
listen = 9000
listen.allowed_clients =
и nginx (/etc/nginx/sites-available/default):
server {
listen 80 default_server;
#listen [::]:80 default_server ipv6only=on;
root /var/www/testing;
index index.php
# Make site accessible from http://localhost/
server_name localhost;
location / {
try_files $uri $uri/ /index.php;
}
location ~ \.php$ {
fastcgi_split_path_info ^(.+\.php)(/.+)$;
# NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini
#fastcgi_pass unix:/var/run/php5-fpm.sock;
fastcgi_pass 192.168.1.2:9000;
fastcgi_index index.php;
include fastcgi_params;
}
}
Затем я попытался создать соединения с https://github.com/jpetazzo/pipework, поэтому fastcgi_pass 192.168.1.2:9000;
. Я пытался с IP-адресом прямо из контейнера, но ничего.
и когда я пытаюсь открыть страницу с lynx, у меня есть BadGateway.
Я пробовал почтовый порт MASTER_PORT = $(sudo docker port $MASTER_ID 9000), но ничего... ping идет без проблем. Telnet к порту 9000 из nginx остается открытым несколько секунд, а затем "Соединение закрыто..."
Кто может объяснить, что я делаю неправильно? спасибо!
/EDIT/ Я попробовал изменить fastcgi_pass на 172.17.42.1:9000; (адрес для docker0 на главной машине), а затем запустите tcpdump на хост-машине:
tcpdump -i docker0 port 9000
и у меня есть:
tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
listening on docker0, link-type EN10MB (Ethernet), capture size 65535 bytes
10:24:54.529572 IP 172.17.0.20.40932 > 172.17.42.1.9000: Flags [S], seq 141160046, win 14600, options [mss 1460,sackOK,TS val 1235770 ecr 0,nop,wscale 7], length 0
10:24:54.529594 IP 172.17.42.1.9000 > 172.17.0.20.40932: Flags [S.], seq 2944341886, ack 141160047, win 14480, options [mss 1460,sackOK,TS val 1235770 ecr 1235770,nop,wscale 7], length 0
10:24:54.529605 IP 172.17.0.20.40932 > 172.17.42.1.9000: Flags [.], ack 1, win 115, options [nop,nop,TS val 1235770 ecr 1235770], length 0
10:24:54.530324 IP 172.17.0.20.40932 > 172.17.42.1.9000: Flags [P.], seq 1:665, ack 1, win 115, options [nop,nop,TS val 1235771 ecr 1235770], length 664
10:24:54.530387 IP 172.17.42.1.9000 > 172.17.0.20.40932: Flags [.], ack 665, win 124, options [nop,nop,TS val 1235771 ecr 1235771], length 0
10:24:54.530534 IP 172.17.42.1.44233 > 172.17.0.12.9000: Flags [S], seq 1354597292, win 14600, options [mss 1460,sackOK,TS val 1235771 ecr 0,nop,wscale 7], length 0
10:24:54.530549 IP 172.17.0.12.9000 > 172.17.42.1.44233: Flags [R.], seq 0, ack 1354597293, win 0, length 0
10:24:54.531044 IP 172.17.42.1.9000 > 172.17.0.20.40932: Flags [R.], seq 1, ack 665, win 124, options [nop,nop,TS val 1235771 ecr 1235771], length 0
Таким образом, пакеты идут между контейнерами... но почему BadGateway?