我正在尝试在 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;
。我尝试直接从容器中使用 IP,但没有。
当我尝试使用 lynx 打开页面时,我有 BadGateway。
我尝试过发布端口 MASTER_PORT=$(sudo docker port $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, 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?
最佳答案
从 docker 0.6.5 开始,这种场景不需要管道,您可以使用新的容器链接功能。基本上,你告诉 docker 让一个容器的端口对另一个容器可用。
这也很容易做到。
你想要做的是有一个带有 php5-fpm 的容器(我们称之为容器 php5-fpm
)配置为监听端口 9000 并像这样运行它:
docker run -d -p 9000 -name php php5-fpm /usr/sbin/php5-fpm -F
我们使用 -F
标志运行 php5-fpm
,这样它就不会被守护。如您所见,我们使用 -name
来明确命名我们的容器。我们将使用此名称在我们将使用 nginx 容器创建的链接中引用它。
然后你就可以运行你的nginx(叫做nginx
)容器了:
docker run -i -t -link php:php nginx /bin/bash
-link
选项告诉 docker 链接别名 php
下的 php
容器。别名是强制性的。
现在我们的 nginx 容器中有一个 shell,我们可以使用 env
命令检索 php5-fpm
容器的映射 ip 和端口:
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
这里有许多有趣的环境变量。我们正在寻找的是 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/
关于php - Docker和容器之间的连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19806945/