我正在尝试在Docker的容器之间建立连接.一个容器有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;.I尝试使用IP直接从容器,但没有.
当我尝试用lynx打开页面时,我有BadGateway.
我尝试发布端口MASTER_PORT = $(sudo docker端口$MASTER_ID 9000),但没有…
ping没有问题.从Nginx Telnet到端口9000保持打开几秒钟,然后“连接关闭…”
谁能解释我在做错什么?
谢谢!
/编辑/
我尝试将fastcgi_pass更改为172.17.42.1:9000; (主机上docker0的地址),然后在主机上启动tcpdump:
tcpdump -i docker0端口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,TS val 1235770 ecr 1235770,length 0
10:24:54.529605 IP 172.17.0.20.40932 > 172.17.42.1.9000: Flags [.],ack 1,win 115,options [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,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,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,TS val 1235771 ecr 0,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,length 0
因此,数据包在容器之间…但为什么BadGateway?
这也很容易做到.
你想做的是有一个容器,PHP5-fpm(让我们调用这个容器PHP5-fpm)配置为侦听端口9000并运行如下:
docker run -d -p 9000 -name PHP PHP5-fpm /usr/sbin/PHP5-fpm -F
我们使用-F标志运行PHP5-fpm,以便它不进行后台处理.如您所见,我们使用-name来明确命名我们的容器.我们将使用这个名称在我们将使用Nginx容器创建的链接中引用它.
docker run -i -t -link PHP:PHP Nginx /bin/bash
-link选项告诉docker链接别名PHP下的PHP容器.别名是强制性的.
我们现在在我们的Nginx容器中有一个shell,我们可以使用env命令来检索PHP5-fpm容器的映射ip和port:
root@061fe34bd07b:/# env
HOSTNAME=061fe34bd07b
TERM=xterm
PHP_PORT=tcp://172.17.0.44:9000
PHP_PORT_9000_TCP_PROTO=tcp
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
PWD=/etc/Nginx/sites-enabled
PHP_PORT_9000_TCP_PORT=9000
SHLVL=1
HOME=/
PHP_PORT_9000_TCP=tcp://172.17.0.44:9000
PHP_NAME=/crimson_squirrel9/PHP
DEBIAN_FRONTEND=noninteractive
PHP_PORT_9000_TCP_ADDR=172.17.0.44
container=lxc
OLDPWD=/
_=/usr/bin/env
这里有一些有趣的env vars.我们正在寻找的是PHP_PORT,因为它提供了关于链接容器的最完整的信息:
PHP_PORT=tcp://172.17.0.44:9000
您现在可以将Nginx的PHP5-fpm上游配置为172.17.0.44:9000,启动它,并检查它是否正常工作:
/etc/init.d/Nginx start
curl http://127.0.0.1/index.PHP
沃拉!我跳过了容器的配置和配置,因为你似乎已经拥有了这个权限)
链接到官方链接教程,使用redis:http://docs.docker.io/en/latest/examples/linking_into_redis/