kbu*_*kbu 10 php linux nginx docker linux-containers
我正在尝试在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 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?
Geo*_*let 22
从docker 0.6.5开始,您不需要为这种情况使用管道,您可以使用新的容器链接功能.基本上,您告诉docker将容器中的端口设置为另一个容器.
它也很容易做到.
你想要做的是有一个容器与php5-fpm(让我们调用这个容器php5-fpm)配置为侦听端口9000并运行它如下所示:
docker run -d -p 9000 -name php php5-fpm /usr/sbin/php5-fpm -F
我们php5-fpm使用-F标志运行,以便它不会守护.如您所见,我们使用-name明确命名我们的容器.我们将使用此名称在我们将使用nginx容器创建的链接中引用它.
然后你可以运行你的nginx(被叫nginx)容器:
docker run -i -t -link php:php nginx /bin/bash
该-link选项告诉docker链接php别名下的容器php.别名是强制性的.
我们现在在我们的nginx容器中有一个shell,我们可以php5-fpm使用以下env命令检索容器的映射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
这里有许多有趣的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/
通过 nginx/php5-fpm 设置,当 php5-fpm 未运行时,我收到了错误的网关错误。那么,您确定 php-fpm 正在您的其他容器中运行吗?我注意到 php-fpm 会死在容器中,除非我从命令行使用 -D 选项运行它。所以
 ~$: php5-fpm -D
我还使用设置运行 nginx 服务器,daemon off;以确保 nginx 不会自行守护进程,否则 docker 将在 nginx 进程完成执行后立即终止容器。但是,由于您已经从 nginx 收到了 Bad Gateway 响应,这要么不是您的问题,要么您已经在 nginx 配置中考虑到了它。
| 归档时间: | 
 | 
| 查看次数: | 10079 次 | 
| 最近记录: |