我想进行完全 Docker 化的 Drupal 安装。我的第一步是让容器与 Nginx 和 php5-fpm 一起运行,两者都基于 Debian。我在 CoreOS alpha 频道(使用 Digital Ocean)。
我的 Dockerfile 如下:
Nginx:
FROM debian
MAINTAINER fvhemert
RUN apt-get update && apt-get install -y nginx && echo "\ndaemon off;" >> /etc/nginx/nginx.conf
CMD ["nginx"]
EXPOSE 80
这个容器构建并运行良好。我在我的服务器 IP 上看到默认的 Nginx 页面。
PHP5-fpm:
FROM debian
MAINTAINER fvhemert
RUN apt-get update && apt-get install -y \
php5-fpm \
&& sed 's/;daemonize = yes/daemonize = no/' -i /etc/php5/fpm/php-fpm.conf
CMD ["php5-fpm"]
EXPOSE 9000
该容器也可以毫无问题地构建,并且在启动时保持运行。
我首先启动 php5-fpm 容器:
docker run -d --name php5-fpm freek/php5-fpm:1
然后我启动 Nginx,链接到 php5-fpm:
docker run -d -p 80:80 --link php5-fpm:phpserver --name nginx freek/nginx-php:1
链接似乎有效,/etc/hosts 中有一个名为 phpserver 的条目。两个码头工人都运行:
core@dockertest ~ $ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
fd1a9ae0f1dd freek/nginx-php:4 "nginx" 38 minutes ago Up 38 minutes 0.0.0.0:80->80/tcp nginx
3bd12b3761b9 freek/php5-fpm:2 "php5-fpm" 38 minutes ago Up 38 minutes 9000/tcp php5-fpm
我调整了一些配置文件。对于 Nginx 容器,我编辑了 /etc/nginx/sites-enabled/default 并进行了更改:
server {
#listen 80; ## listen for ipv4; this line is default and implied
#listen [::]:80 default_server ipv6only=on; ## listen for ipv6
root /usr/share/nginx/www;
index index.html index.htm index.php;
(我添加了index.php)
并进一步:
location ~ \.php$ {
fastcgi_split_path_info ^(.+\.php)(/.+)$;
# # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini
#
# # With php5-cgi alone:
fastcgi_pass phpserver:9000;
# # With php5-fpm:
# fastcgi_pass unix:/var/run/php5-fpm.sock;
fastcgi_index index.php;
include fastcgi_params;
}
在 php5-fpm docker 中,我更改了 /etc/php5/fpm/php.ini:
cgi.fix_pathinfo=0
php5-fpm 运行:
[21-Nov-2014 06:15:29] NOTICE: fpm is running, pid 1
[21-Nov-2014 06:15:29] NOTICE: ready to handle connections
我还将index.html更改为index.php,它看起来像这样(/usr/share/nginx/www/index.php):
<html>
<head>
<title>Welcome to nginx!</title>
</head>
<body bgcolor="white" text="black">
<center><h1>Welcome to nginx!</h1></center>
<?php
phpinfo();
?>
</body>
</html>
我从 Nginx docker 扫描了 9000 端口,它显示为关闭。当然这不是一个好兆头:
root@fd1a9ae0f1dd:/# nmap -p 9000 phpserver
Starting Nmap 6.00 ( http://nmap.org ) at 2014-11-21 06:49 UTC
Nmap scan report for phpserver (172.17.0.94)
Host is up (0.00022s latency).
PORT STATE SERVICE
9000/tcp closed cslistener
MAC Address: 02:42:AC:11:00:5E (Unknown)
Nmap done: 1 IP address (1 host up) scanned in 0.13 seconds
Nginx 日志:
root@fd1a9ae0f1dd:/# vim /var/log/nginx/error.log
2014/11/20 14:43:46 [error] 13#0: *1 connect() failed (111: Connection refused) while connecting to upstream, client: 194.171.252.110, server: localhost, request: "GET / HTTP/1.1", upstream: "fastcgi://127.0.0.1:9000", host: "128.199.60.95"
2014/11/21 06:15:51 [error] 9#0: *1 connect() failed (111: Connection refused) while connecting to upstream, client: 145.15.244.119, server: localhost, request: "GET / HTTP/1.0", upstream: "fastcgi://172.17.0.94:9000", host: "128.199.60.95"
是的,这出了问题,当我浏览 Nginx 实例时,我不断收到 502 bad gateway 错误。
我的问题是:到底出了什么问题?我的猜测是我缺少 php 配置文件中的一些设置。
编辑更多详细信息:
这是结果(来自 php5-fpm 容器内部,在 apt-get install net-tools 之后):
root@3bd12b3761b9:/# netstat -tapen
活跃的互联网连接
(服务器和已建立)Proto Recv-Q Send-Q 本地地址
外部地址状态用户索引节点PID/程序名称
从 Nginx 容器内部:
root@fd1a9ae0f1dd:/# netstat -tapen
活跃的互联网连接
(服务器和已建立) Proto Recv-Q Send-Q 本地地址 外部地址 状态 用户 Inode PID/程序
名称 TCP 0 0 0.0.0.0:80 0.0.0.0:*
听0 1875387 -
编辑2:
进步!
在 php5-fpm 容器中的文件中:
/etc/php5/fpm/pool.d/www.conf
我将监听参数从某个套接字名称更改为:
listen = 9000
现在,当我访问我的网页时,出现错误:
“未指定输入文件。”
可能我在某处有尾随/错误。我会更仔细地研究一下!
EDIT3:
所以我用上面提到的改动重建了码头工人,看起来他们正在说话。但是,我的网页告诉我:“找不到文件。”
我非常确定它与 nginx 发送到 php-fpm 的文档有关,但我不知道它应该是什么样子。我在使用始终有效的套接字方法时使用了默认值。现在它不再起作用了。 /etc/nginx/sites-enabled/default 中的 location ~ .php$ { 下应该包含什么?