Docker LNMP环境搭建

104.4k , , , 328评论

本文介绍如何使用Docker容器,快速部署LNMP环境。 最终完成的环境我们称为:DNMP(即 Docker + Nginx + MySQL + PHP)。 最终实现一键部署LNMP环境的目的,该环境特点:

  1. 完全开源
  2. 支持多版本PHP切换(PHP5.4、PHP5.6、PHP7.2…)
  3. 支持绑定任意多个域名
  4. 支持HTTPS和HTTP/2
  5. PHP源代码位于host
  6. MySQL data位于host
  7. 所有配置文件可在host中直接修改
  8. 所有日志文件可在host中直接查看
  9. 内置完整PHP扩展安装命令
  10. 本站实际使用,确保100%可用
  11. 实现一次配置,Windows、Linux、MacOs皆可用


github仓库地址https://github.com/yeszao/dnmpQQ群:572041090 (请备注dnmp交流)

1 快速使用

1、安装gitdockerdocker-compose
2、使用git下载完整代码:

$ git clone https://github.com/yeszao/dnmp.git

3、用docker-compose命令启动容器,首次使用需要下载镜像,会稍慢:

$ docker-compose up

4、然后在浏览器中访问localhost,就可以看到如下页面:

5、源代码在:./www/site1/ 目录下。

2 安装docker和docker-compose

具体安装步骤:

注意:Docker安装要求Linux 3.10以上版本,用uname -a命令可查看到。
安装之后,可查看版本:

$ docker -v
$ docker-compose -v

然后把当前用户加到docker用户组里面:

$ sudo gpasswd -a ${USER} docker

就不用每次启动Docker都得加sudo了。 注意,执行gpasswd命令之后要重新登陆才有效。

3 使用国内镜像仓库

在没有梯子的情况下,Docker默认从Docker Hub仓库下载镜像,完整的LNMP镜像估计需要一两天时间。 所以只能换个途径,比如使用阿里云的加速仓库。 首先注册一个阿里云账号,然后访问阿里云的Docker镜像仓库,能找到加速器地址。 对于Docker 1.10+,打开配置文件 /etc/docker/daemon.json(没有时新建该文件):

{
    registry-mirrors: https://6evg8u3r.mirror.aliyuncs.com
}

以上是我的加速地址。 然后重启Docker Daemon:

sudo systemctl daemon-reload
sudo systemctl restart docker

就可以了。 Docker 1.10以下请看:https://yq.aliyun.com/articles/29941

4 目录说明

大致框架如下:

(图片使用UMLet绘制,下载原文件

4.1 目录结构

目录结构如下:

.
├── docker-compose.yml          容器启动配置文件
├── Dockerfile                  PHP-FPM构建配置文件
├── conf                        配置目录
│   ├── mysql                   MySQL配置文件目录
│   │   └── my.cnf              MySQL配置文件
│   ├── nginx                   Nginx配置文件目录
│   │   ├── conf.d              站点配置文件目录
│   │   │   ├── certs           SSL认证文件、密钥和加密文件目录
│   │   │   │   └── site2       站点2的认证文件目录
│   │   │   ├── site1.conf      站点1 Nginx配置文件
│   │   │   └── site2.conf      站点2 Nginx配置文件
│   │   └── nginx.conf          Nginx通用配置文件
│   └── php                     PHP配置目录
│       ├── php-fpm.d           PHP-FPM配置目录
│       │   └── www.conf        PHP-FPM配置文件
│       └── php.ini             PHP配置文件
├── log                         日志目录
│   ├── mysql                   MySQL日志目录
│   ├── nginx                   Nginx日志目录
│   └── php-fpm                 PHP-FPM日志目录
├── mysql                       MySQL数据文件目录
└── www                         站点根目录
    ├── site1                   站点1根目录
    └── site2                   站点2根目录

4.2 站点部署

本文有默认加了两个站点:www.site1.com(同localhost)和www.site2.com。 要在本地访问这两个域名,需要修改你的hosts文件,添加以下两行:

127.0.0.1 www.site1.com
127.0.0.1 www.site2.com

其中,www.site2.com支持SSL/https和HTTP/2的示例站点。 因为站点2的SSL采用自签名方式,所以浏览器有安全提示,继续访问就可以了,自己的站点用第三方SSL认证证书替换即可。 如果只用到站点1,把站点2相关的目录和配置文件删除:

./conf/nginx/conf.d/certs/site2/
./conf/nginx/conf.d/site2.conf
./www/site2/

重启容器内的Nginx生效:

docker exec -it dlnmp_nginx_1 nginx -s reload

4.3 HTTPS使用

在容器中我们也是可以用HTTPS的,具体的配置请参考如下文件:

./conf/nginx/conf.d/site2.conf

如果是自签名,可以用廖雪峰提供的一个自动生成认证文件、私钥脚本:gencert.sh, 这个脚本已经放在项目中,在这个目录下:

./conf/nginx/conf.d/certs/site2/

在Bash中输入:

$ ./gencert.sh

输入一次域名,和几次密码(内容随意)后,就会生成几个认证文件。 其中自签名情况不需要.csr.origin.key后缀的文件。 然后修改Nginx配置文件,配置SSL支持就可以了。

5 docker-compose.yml文件

如下是docker容器的运行配置docker-compose.yml的内容:

nginx:
  image: nginx:alpine
  ports:
    - 80:80
    - 443:443
  volumes:
    - ./www/:/var/www/html/:rw
    - ./conf/nginx/conf.d:/etc/nginx/conf.d/:ro
    - ./conf/nginx/nginx.conf:/etc/nginx/nginx.conf:ro
    - ./log/nginx/:/var/log/nginx/:rw
  links:
    - php-fpm:fpm

php-fpm:
  build: .
  expose:
    - 9000
  volumes:
    - ./www/:/var/www/html/:rw
    - ./conf/php/php.ini:/usr/local/etc/php/php.ini:ro
    - ./conf/php/php-fpm.d/www.conf:/usr/local/etc/php-fpm.d/www.conf:rw
    - ./log/php-fpm/:/var/log/php-fpm/:rw
  links:
    - mysql:mysql
    - redis:redis

mysql:
  image: mysql:latest
  ports:
    - 3306:3306
  volumes:
    - ./conf/mysql/my.cnf:/etc/mysql/my.cnf:ro
    - ./mysql/:/var/lib/mysql/:rw
    - ./log/mysql/:/var/log/mysql/:rw
  environment:
    MYSQL_ROOT_PASSWORD: 123456

redis:
  image: redis:latest
  ports:
    - 6379:6379

这里我们用了nginx的alpine镜像,以及php-fpm和MySQL的最新镜像。 这里默认加了redis容器,不需要的话可以把文件的最后4以及php-fpm块下的- redis:redis删除。

5.1 为什么用nginx:alpine?

因为相比nginx:latestnginx:alpine有几点优势:

  1. 用的是最新版nginx镜像,功能与nginx:latest一模一样
  2. alpine镜像用的是Alpine Linux内核,比ubuntu内核要小很多。
  3. nginx:alpine默认支持http2。

Alpine的更多请看《Alpine Linux,一个只有5M的Docker镜像》。 如要进入alpine容器,命令是(后面的路径不是/bin/bash):

$ docker exec -it dnmp_nginx_1 /bin/sh

5.2 站点根目录挂载

为什么站点根目录在Nginx和PHP-FPM都这样挂载?

./www/:/var/www/html/

我们知道,Nginx配置都有这样一项:

fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

其中,$document_root就是server块下root所指的路径:

server {
    #...
    root /var/www/html;
    #...
}

这里$document_root就是/var/www/html。 如果Nginx和PHP-FPM在同一主机,Nginx会通过9000端口把这个目录值脚本URI传给PHP-FPM。 PHP-FPM再通过9000端口接收Nginx发过来的目录值和脚本URI,发给PHP解析。 PHP收到后,就到指定的目录下查找PHP文件并解析,完成后再通过9000端口返回给Nginx。 如果Nginx和PHP-FPM在同一个主机里面,PHP就总能找到Nginx指定的目录。但是,如果他们在不同的容器呢? 未做任何处理的情况,Nginx容器中的站点根目录,PHP-FPM容器肯定不存在。 所以,这里需要保证Nginx和PHP-FPM都挂载了Host的./www/,并且都挂载在容器的:/var/www/html。 (当然,你也可以指定别的目录,确保统一即可)

5.3 修改docker-compose.yml文件之后?

如果容器已经生成,回头再编辑docker-compose.yml,用

docker-compose up

命令会直接启动原来的容器,修改的内容不会体现在启动的容器里。 所以,要使修改的docker-compose.yml生效,需要以下4步:

$ docker stop dnmp_nginx_1                      # 第一步:停止容器
$ docker rm dnmp_nginx_1                        # 第二步:删除容器
# !!第三步:重启Docker服务!!
$ docker-compose up -d --no-deps --build mysql  # 第四步:重新启动容器

其中最后一条命令参数作用:

  • -d:后台执行
  • --no-deps:不启动link的容器
  • --build:启动容器前先构建镜像

6 Dockerfile文件

因为PHP-FPM构建稍微复杂,涉及到很多扩展。 所以单独用Dockerfile文件构建PHP-FPM:

FROM php:fpm

## Copy sources.list to container.
## Here we use 163.com sources list.
##     PHP 5.6.31+ should use jessie sources list
##     PHP 7.2.0+ should use stretch sources list
## For more please check:
## PHP official docker repository: https://hub.docker.com/r/library/php/
#COPY ./files/sources.list.stretch /etc/apt/sources.list
#COPY ./files/sources.list.jessie /etc/apt/sources.list

## Update Ubuntu
RUN apt-get update

## mcrypt
RUN apt-get install -y libmcrypt-dev
RUN docker-php-ext-install mcrypt

## GD
RUN apt-get install -y libfreetype6-dev libjpeg62-turbo-dev libpng12-dev
RUN docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/
RUN docker-php-ext-install -j$(nproc) gd

## Intl
RUN apt-get install -y libicu-dev
RUN docker-php-ext-install -j$(nproc) intl

## General
RUN docker-php-ext-install zip
RUN docker-php-ext-install pcntl
RUN docker-php-ext-install opcache
RUN docker-php-ext-install pdo_mysql
RUN docker-php-ext-install mysqli
RUN docker-php-ext-install mbstring

## ...

完整Dockerfile请移步本项目GitHub仓库

7 nginx配置文件

这里,我们还需要稍微修改nginx配置文件:

location ~ \.php$ {
    fastcgi_pass   fpm:9000;
    fastcgi_index  index.php;
    include        fastcgi_params;
    fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
}

这里,我们仅需把fastcgi_pass改成:fpm:9000。 也就是,PHP-FPM的侦听主机改成:Nginx links PHP-FPM容器的别名,在docker-compose.yml文件里面我们设置为fpm这样Nginx容器启动的时候,就会自动修改自己的/etc/hosts,让fpm指向php-fpm容器的IP。修改之后,重启容器中的nginx:

$ docker exec dlnmp_nginx_1 nginx -s reload

其中,dlnmp_nginx_1是容器的名称,也可以指定容器的ID。

8 站点根目录写权限

有时候,我们的PHP代码需要某个目录的写权限。 比如,Wordpress的wp-content/uploads目录,只有写权限我们才能正常上传文件。 默认的,容器中的/var/www/html目录属于root,我们需要修改为www-data,PHP才能正常写目录。 先进入到容器中:

$ docker exec -it dlnmp_php-fpm_1 /bin/bash

然后修改目录权限:

$ chown -R www-data:www-data /var/www/html

这样PHP就能正常读写目录了。

9 数据库

9.1 使用MySQL

在docker-compose.yml文件中,我们指定了MySQL数据库root用户的密码为123456。 所以,我们就可以在主机中通过:

$ mysql -h 127.0.0.1 -u root -p

输入密码,就可以进入MySQL命令行。 说明:这里MySQL的连接主机不能用localhost,因为MySQL客户端默认使用unix socket方式连接,应该直接用本地IP。在PHP代码中的使用方式与在主机中使用稍有不同,如下:

$pdo = new PDO('mysql:host=mysql;dbname=site1', 'root', '123456');

其中,host的值就是在docker-compose.yml里面指定的MySQL容器的名称。 这是因为PHP代码是在FPM容器中,FPM容器启动时会自动在/etc/hosts中加上:

172.17.0.2 mysql 11e55f91c4c3 dlnmp_mysql_1

就是说,mysql自动指向了MySQL容器动态生成的IP。

9.2 使用Redis

Redis使用和MySQL类似。 在主机和容器内部都通过地址127.0.0.1,端口6379访问。 PHP则是跨容器访问,host参数用redislinks指定的名称),端口用6379

10 让DNMP随系统启动

到这里我们用docker搭建的Docker (Linux) + Nginx + MySQL + PHP环境已经可以正常使用了。 但每次启动系统都得切换到项目目录,再执行compose up,就略显繁琐。 要是能在系统启动的时候自动启动容器,岂不是更好,下面是具体的方法。

10.1 Ubuntu系统Unity桌面

从Launcher中搜索Startup Applications(启动应用程序),

然后Add一项,名字:dnmp,命令填:

docker-compose -f /home/gary/dnmp/docker-compose.yml up -d

其中,-f 指定docker-compose.yml文件的位置。 然后保存即可。

10.2 其他Linux系统

其他命令行下的Linux系统,可以直接编辑 /etc/rc.local 文件,加上上面的命令。

Docker相关的有用文章:

  1. Docker 常用命令
  2. docker-compose中ports和expose的区别
  3. 手动用Docker一步步部署LNMP完整教程
  4. Docker容器使用十大注意事项

328 条评论

n
nirnava says: 回复

如何才能使用phpmyadmin访问mysql数据库呢? 希望大神解答。。

歪麦 says: 作者

安装个Navicat吧,这个管理更方便。

K
Kerwin says:

docker pull phpmyadmin/phpmyadmin

docker run –name myadmin -d –link dnmp_mysql_1:db -p 8080:80 phpmyadmin/phpmyadmin

phpmyadmin入口: http://domain.com:8080

L
Lii says: 回复

博主试过用docker搭建Apache和Nginx共存的开发环境吗。 因为我手头项目都是Apache,但是自己的项目想用Nginx。

歪麦 says: 作者

Apache应该也是差不多的,把Nginx容器的构建改成Apache,设置对应的conf配置就可以了

霍霍人 says: 回复

centos7不行呀

歪麦 says: 作者

有什么提示么?

1
123 says: 回复

W: Failed to fetch http://mirrors.163.com/debian-security/dists/jessie/updates/main/binary-amd64/Packages Hash Sum mismatch

E: Some index files failed to download. They have been ignored, or old ones used instead.

apt-get源还是有错误呢?

歪麦 says: 作者

那修改source.list.jesse,换一个源试试
不同网路的源不一定都是可用的

霍霍人 says:

都试过了。。。。。

霍霍人 says:

中科大的源可以

N
Nick_Cai says:

请问是用16.04还是14.04的源呢?

G
Geek Zoo says:

FROM php:7.0.26-fpm

RUN sed -i ‘/jessie-updates/d’ /etc/apt/sources.list

o
ocean says: 回复

你好,我已经sudo -s了,但好像有问题

Starting dnmp_nginx_1 … done
Attaching to dnmp_redis_1, dnmp_mysql_1, dnmp_php-fpm_1, dnmp_nginx_1
mysql_1 | chown: changing ownership of ‘/var/lib/mysql/.gitignore’: Operation not permitted
mysql_1 | chown: changing ownership of ‘/var/lib/mysql/’: Operation not permitted
nginx_1 | nginx: [alert] could not open error log file: open() “/var/log/nginx/error.log” failed (13: Permission denied)
nginx_1 | 2017/11/21 15:50:19 [emerg] 1#1: open() “/var/log/nginx/error.log” failed (13: Permission denied)
redis_1 | 1:C 21 Nov 15:45:27.963 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
redis_1 | 1:C 21 Nov 15:45:27.963 # Redis version=4.0.2, bits=64, commit=00000000, modified=0, pid=1, just started
redis_1 | 1:C 21 Nov 15:45:27.963 # Warning: no config file specified, using the default config. In order to specify a config file use redis-server /path/to/redis.conf
redis_1 | 1:M 21 Nov 15:45:27.966 * Running mode=standalone, port=6379.
redis_1 | 1:M 21 Nov 15:45:27.967 # WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128.
redis_1 | 1:M 21 Nov 15:45:27.967 # Server initialized
redis_1 | 1:M 21 Nov 15:45:27.968 # WARNING you have Transparent Huge Pages (THP) support enabled in your kernel. This will create latency and memory usage issues with Redis. To fix this issue run the command ‘echo never > /sys/kernel/mm/transparent_hugepage/enabled’ as root, and add it to your /etc/rc.local in order to retain the setting after a reboot. Redis must be restarted after THP is disabled.
redis_1 | 1:M 21 Nov 15:45:27.968 * Ready to accept connections
php-fpm_1 | [21-Nov-2017 15:45:28] NOTICE: fpm is running, pid 1
php-fpm_1 | [21-Nov-2017 15:45:28] NOTICE: ready to handle connections
dnmp_mysql_1 exited with code 1
dnmp_nginx_1 exited with code 1

歪麦 says: 作者

这里提示是权限问题,把当前用户添加到docker组再试

o
ocean says:

嗯嗯,晚上回家再试试,感谢

L
Louie says:

我也是这个问题,请问怎么解决啊

叶先生 says:

mysql_1 |
mysql_1 | ERROR: mysqld failed while attempting to check config
mysql_1 | command was: “mysqld –verbose –help”
mysql_1 |
mysql_1 | mysqld: [Warning] World-writable config file ‘/etc/mysql/my.cnf’ is ignored.
mysql_1 | mysqld: Error on realpath() on ‘/var/lib/mysql-files’ (Error 2 – No such file or directory)
mysql_1 | 2018-04-30T19:08:41.012004Z 0 [ERROR] [MY-010095] [Server] Failed to access directory for –secure-file-priv. Please make sure that directory exists and is accessible by MySQL Server. Supplied value : /var/lib/mysql-files
mysql_1 | 2018-04-30T19:08:41.013312Z 0 [ERROR] [MY-010119] [Server] Aborting
php72_1 | [30-Apr-2018 19:08:41] NOTICE: fpm is running, pid 1
php72_1 | [30-Apr-2018 19:08:41] NOTICE: ready to handle connections
php70_mysql_1 exited with code 1

win7上面报这个错,好像是少了mysql_files,这个在wind7下该怎么弄呢

o
ocean says: 回复

你好,bash: gpasswd: command not found,方便加下QQ吗?462091385

歪麦 says: 作者

什么系统,怎么操作的?

Y
Yfu says: 回复

你好,我docker-compose up的时候会有红字报:
debconf: delaying package configuration, since apt-utils is not installed,
然后最后报:
Recreating 1741073fe75c_1741073fe75c_1741073fe75c_1741073fe75c_dnmp_php-fpm_1 … error

ERROR: for 1741073fe75c_1741073fe75c_1741073fe75c_1741073fe75c_dnmp_php-fpm_1 No such image: sha256:d4e6db5b65a483588679aa3d53464616fcdd0a67960c7ef86c0f96f407538e65

ERROR: for php-fpm No such image: sha256:d4e6db5b65a483588679aa3d53464616fcdd0a67960c7ef86c0f96f407538e65
ERROR: Encountered errors while bringing up the project.

但是apt-utils如何安装呢?

歪麦 says: 作者

apt-utils包含了Ubuntu 16.04 LTS 的发布后的一些新命令,比如apt(Advanced Package Tool),它可以取代 apt-get、apt-cache 等功能。
这里我们用apt-get,可以忽略这个提示,不会影响。

第二个问题,
提示Recreating 1741073fe75c_1741073fe75c_1741073fe75c_1741073fe75c_dnmp_php-fpm_1 … error,说明之前有build失败过,
用docker images命令可以看到构建失败的镜像,再docker rmi删除掉,重新up

H
Henry says: 回复

你好,我docker-compose up的时候会有红字报:

error: /usr/src/php/ext/mcrypt does not exist

usage: /usr/local/bin/docker-php-ext-install [-jN] ext-name [ext-name …]
ie: /usr/local/bin/docker-php-ext-install gd mysqli
/usr/local/bin/docker-php-ext-install pdo pdo_mysql
/usr/local/bin/docker-php-ext-install -j5 gd mbstring mysqli pdo pdo_mysql shmop

if custom ./configure arguments are necessary, see docker-php-ext-configure

Possible values for ext-name:
bcmath bz2 calendar ctype curl dba dom enchant exif fileinfo filter ftp gd gettext gmp hash iconv imap interbase intl json ldap mbstring mysqli oci8 odbc opcache pcntl pdo pdo_dblib pdo_firebird pdo_mysql pdo_oci pdo_odbc pdo_pgsql pdo_sqlite pgsql phar posix pspell readline recode reflection session shmop simplexml snmp soap sockets sodium spl standard sysvmsg sysvsem sysvshm tidy tokenizer wddx xml xmlreader xmlrpc xmlwriter xsl zend_test zip

Some of the above modules are already compiled into PHP; please check
the output of “php -i” to see which modules are already loaded.
ERROR: Service ‘php-fpm’ failed to build: The command ‘/bin/sh -c docker-php-ext-install mcrypt’ returned a non-zero code: 1

歪麦 says: 作者

2017-11-30发布的PHP7.2.0已经移除了mcrypt了:http://php.net/manual/en/intro.mcrypt.php
如果Dockerfile里面是FROM php:fpm,默认就是PHP7.2.0,要把这两行删掉:

RUN apt-get install -y libmcrypt-dev
RUN docker-php-ext-install mcrypt

就可以了。
建议加密的地方用openssl或Sodium (PHP 7.2.0开始用)扩展代替。

d
dbquan says: 回复

“`
[root@dbquan01 dnmp]# docker-compose up
Building php-fpm
Step 1 : FROM php:fpm
—> e63a6cd92abc
Step 2 : COPY ./files/sources.list.jessie /etc/apt/sources.list

ERROR: Service ‘php-fpm’ failed to build: The command ‘/bin/sh -c docker-php-ext-install mcrypt’ returned a non-zero code: 1
“`
请问安装报错如何解决? “error: /usr/src/php/ext/mcrypt does not exist”

歪麦 says: 作者

请看给楼上 @Henry 的回复。

歪麦 says: 作者

对了,PHP7.2.0的docker image是基于Debian stretch版本的,所以需要source.list用stretch源。
以后的版本再做个兼容。

e
ec says: 回复

我的保存,请问怎么解决,mac上面运行的,可以加下我qq 1046373779 吗,交流下,谢谢

—> Running in 9f91a58a09cf

Notice: Undefined variable: proxy_host in PEAR/Proxy.php on line 163

Notice: Undefined variable: proxy_port in PEAR/Proxy.php on line 163
No releases available for package “pecl.php.net/redis”
install failed
ERROR: Service ‘php72’ failed to build: The command ‘/bin/sh -c pecl install redis-3.1.4 && docker-php-ext-enable redis && : && pecl install xdebug-2.6.0alpha1 && docker-php-ext-enable xdebug && : && apt-get install -y libmagickwand-dev && pecl install imagick-3.4.3 && docker-php-ext-enable imagick && : && apt-get install -y libmemcached-dev zlib1g-dev && pecl install memcached-3.0.4 && docker-php-ext-enable memcached’ returned a non-zero code: 1
yuxiMBP:dnmp zyx$

歪麦 says: 作者

因为pecl方式安装默认会用https方式,但是pecl.php.net的https通道已经被屏蔽了,所以必须走代理或者用源码方式安装,方法:https://github.com/yeszao/dnmp/issues/10

e
ec says:

这个错误呢?怎么解决

etting up libhashkit-dev (1.0.18-4.1) …
Setting up libmemcached-dev (1.0.18-4.1) …
Processing triggers for libc-bin (2.24-11+deb9u1) …

Warning: stream_socket_enable_crypto(): SSL: Success in PEAR/Proxy.php on line 101

Warning: stream_socket_enable_crypto(): SSL: Success in /usr/local/lib/php/PEAR/Proxy.php on line 101

Notice: Undefined variable: proxy_host in PEAR/Proxy.php on line 103

Notice: Undefined variable: proxy_port in PEAR/Proxy.php on line 103
No releases available for package “pecl.php.net/memcached”
install failed
ERROR: Service ‘php72’ failed to build: The command ‘/bin/sh -c pecl install redis-3.1.4 && docker-php-ext-enable redis && : && pecl install xdebug-2.6.0alpha1 && docker-php-ext-enable xdebug && : && apt-get install -y libmagickwand-dev && pecl install imagick-3.4.3 && docker-php-ext-enable imagick && : && apt-get install -y libmemcached-dev zlib1g-dev && pecl install memcached-3.0.4 && docker-php-ext-enable memcached’ returned a non-zero code: 1
yuxiMBP:dnmp zyx$

d
dnmp says: 回复

Notice: Undefined variable: proxy_port in PEAR/Proxy.php on line 163
No releases available for package “pecl.php.net/redis”
install failed
我看到dockerfile里面写了下面的
## pecl files
## Note: if get error
## `No releases available for package “pecl.php.net/xxx”`
## or
## `Package “xxx” does not have REST xml available`
## Please turn on proxy (the proxy IP may be docker host IP or others).
但是proxy怎么打开呢?

歪麦 says: 作者

这个proxy就是要走代理哦,没有的话就用源码方式安装,方法:https://github.com/yeszao/dnmp/issues/10

N
Nick says:

dockerfile里面设置了也没有用

N
Nick_Cai says:

好像在php72的dockerifle 中把#RUN pear config-set http_proxy http://10.0.75.1:1080 这一行注释掉这几个扩展不需要设置代理

歪麦 says: 作者

嗯,可以注释掉,我已经修正了,删了这一行。

y
yusher says:

我的是mac电脑,,,自己电脑装了个chales抓包工具,,这个工具可以设置代理地址,吧这个代理地址填到php/php72/Dockerfile 文件下的地方 如:RUN pear config-set http_proxy http://192.168.1.178:8888 就可以了

g
godaddy says: 回复

朋友 交换链接吗

d
dsf says: 回复

Step 3 : RUN apt-get update && apt-get install -y libfreetype6-dev libjpeg62-turbo-dev libpng-dev && docker-php-ext-configure gd –with-freetype-dir=/usr/include/ –with-jpeg-dir=/usr/include/ && docker-php-ext-install gd && : && apt-get install -y libicu-dev && docker-php-ext-install intl && : && apt-get install -y libxml2-dev && apt-get install -y libxslt-dev && docker-php-ext-install soap && docker-php-ext-install xsl && docker-php-ext-install xmlrpc && docker-php-ext-install wddx && : && apt-get install -y libbz2-dev && docker-php-ext-install bz2 && : && docker-php-ext-install zip && docker-php-ext-install pcntl && docker-php-ext-install pdo_mysql && docker-php-ext-install mysqli && docker-php-ext-install mbstring && docker-php-ext-install exif && docker-php-ext-install bcmath && docker-php-ext-install calendar && docker-php-ext-install sockets && docker-php-ext-install gettext && docker-php-ext-install shmop && docker-php-ext-install sysvmsg && docker-php-ext-install sysvsem && docker-php-ext-install sysvshm && docker-php-ext-install opcache
—> [Warning] IPv4 forwarding is disabled. Networking will not work.
—> Running in b4dc7af9e896

歪麦 says: 作者
z
zz的代码世界 says: 回复

nginx:
image: nginx:alpine
ports:
– “80:80”
– “443:443”
volumes:
– ./www/:/var/www/html/:rw
– ./conf/nginx/conf.d:/etc/nginx/conf.d/:ro
– ./conf/nginx/nginx.conf:/etc/nginx/nginx.conf.d:ro
– ./log/nginx/:/var/log/nginx/:rw
links:
– php72:fpm

php72:
build: ./php/php72/
expose:
– “9000”
volumes:
– ./www/:/var/www/html/:rw
– ./conf/php/php.ini:/usr/local/etc/php/php.ini:ro
– ./conf/php/php-fpm.d/www.conf:/usr/local/etc/php-fpm.d/www.conf.d:rw
– ./log/php-fpm/:/var/log/php-fpm/:rw
links:
– mysql:mysql
– redis:redis

mysql:
image: mysql:latest
ports:
– “3306:3306”
volumes:
– ./conf/mysql/my.cnf:/etc/mysql/my.cnf.d:ro
– ./mysql/:/var/lib/mysql/:rw
– ./log/mysql/:/var/log/mysql/:rw
environment:
MYSQL_ROOT_PASSWORD: “123456”

redis:
image: redis:latest
ports:
– “6379:6379”

说明:原yml文件的.cnf执行的话会报错not a directory。然后我统一改成了.cnf.d就可以了,这样修改可以么???

歪麦 says: 作者

文件目录能够mount进去就OK

2
278945129978 says: 回复

问一下,如果不想把localhost指向site1改怎么修改

歪麦 says: 作者

修改:conf/nginx/conf.d/site1.conf文件,
把:
root /var/www/html/site1;
改成:
root /var/www/html/;

d
dserers says: 回复

如果不把localhost指向site1,而是指向var/www/html目录改怎么改

s
samsnow says: 回复

修改宿主机的php.ini没有影响到容器里的phpinfo

歪麦 says: 作者

可能两种情况:1、宿主机的php.ini没有mount到容器里面;2.被php-fpm的配置覆盖。

i
iHero says:

怎么解决了 、

i
iHero says:

这个问题解决了,我重新启动了 php-fpm 容器 修改的php.ini 后,在容器中文件中有了

张鹏 says: 回复

RUN pear config-set http_proxy http://10.0.75.1:1080 这个在那里的呀,找不到这段,dockerfile没有呀

歪麦 says: 作者

有的哟,github完整版本有的

r
ruanzhq says: 回复

mysql_1 | mysqld: Table ‘mysql.plugin’ doesn’t exist
mysql_1 | 2018-01-28T03:57:00.902395Z 0 [ERROR] Can’t open the mysql.plugin table. Please run mysql_upgrade to create it.
mysql_1 | 2018-01-28T03:57:00.903005Z 0 [Note] InnoDB: Loading buffer pool(s) from /var/lib/mysql/ib_buffer_pool
mysql_1 | 2018-01-28T03:57:00.903265Z 0 [Note] InnoDB: Buffer pool(s) load completed at 180128 3:57:00
mysql_1 | 2018-01-28T03:57:00.904340Z 0 [Warning] Gtid table is not ready to be used. Table ‘mysql.gtid_executed’ cannot be opened.
mysql_1 | 2018-01-28T03:57:00.904430Z 0 [Warning] Failed to set up SSL because of the following SSL library error: SSL context is not usable without certificate and private key
mysql_1 | 2018-01-28T03:57:00.904441Z 0 [Note] Server hostname (bind-address): ‘*’; port: 3306
mysql_1 | 2018-01-28T03:57:00.904485Z 0 [Note] IPv6 is available.
mysql_1 | 2018-01-28T03:57:00.904494Z 0 [Note] – ‘::’ resolves to ‘::’;
mysql_1 | 2018-01-28T03:57:00.904517Z 0 [Note] Server socket created on IP: ‘::’.
mysql_1 | 2018-01-28T03:57:00.915660Z 0 [Warning] Failed to open optimizer cost constant tables
mysql_1 |
mysql_1 | 2018-01-28T03:57:00.915778Z 0 [ERROR] Fatal error: Can’t open and lock privilege tables: Table ‘mysql.user’ doesn’t exist
mysql_1 | 2018-01-28T03:57:00.915846Z 0 [ERROR] Aborting
mysql_1 |
mysql_1 | 2018-01-28T03:57:00.915882Z 0 [Note] Binlog end

dnmp_mysql_1 exited with code 1

mysql 一直无法正常启动 请问是什么原因

歪麦 says: 作者

应该是mysql配置的原因,查一下my.cnf文件,具体原因这个log的error已经注明出来了。

r
ruanzhq says:

找到原因了 我是之前用你的方法部署了一台机器,现在迁移的时候把mysql的数据直接拷贝过来了,我删掉备份数据就ok了

歪麦 says: 作者

OK

西
西点培训班 says: 回复

我去 要的就是这个资料,学习了

w
wufly says: 回复

安装好了之后composer怎么用呢

歪麦 says: 作者

进到容器里面用,也可以在主机上装composer,然后直接在主机更新组件

A
Aurora says:

本地没有装PHP怎么装composer啊,可以这样吗

歪麦 says: 作者

…需要本地也安装PHP的,composer依赖PHP,官网有段话可以说明:

Composer requires PHP 5.3.2+ to run.

所以建议到容器里面使用composer

h
hlx says: 回复

Error: Service ‘PHP72’ failed to build: The command ‘/bin/sh -c cd /tmp/ && tar -xf zendopcache xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx)
returned a non-zero code: 2

PHP72用了PHP54最后的7行就报上面的错了

歪麦 says: 作者

PHP72已经可以直接用opcache了,不需要像PHP54在容器中编译,直接把这些注释掉就可以了。

S
Shellic says: 回复

大神,win7下安装的docker toolbox,使用时是不是需要先创建ubuntu容器

歪麦 says: 作者

在win10里面用吧~

l
liaoyizhe says: 回复

作者你好,为什么装了redis之后php72容器里面还要再装一个redis呢?运行到后面直接报错了。
No releases available for package “pecl.php.net/redis”

歪麦 says: 作者

这里装的是PHP的redis扩展哦~

N
Nick_Cai says: 回复

大神您好,请问下面报错是因为啥? 我的环境win10, 安装过程中是有授权D盘的写的权限,但是我输入开机账号和密码后还是报错
ERROR: for dnmp_nginx_1 Cannot start service nginx: driver failed programming external connectivity on endpoint dnmp_nginx_1 (06c7228d3e1b10565c03b7edef8f620ba4b1abec8564fb81d1d7bc1391d64089): Error starting userland proxy: Bind for 0.0.0.0:80: unexpected error Permission denied

N
Nick_Cai says:

哦,原来是我的80端口被占用,在docker-compose.yml第四行80:80 改为8080:80 就好了,谢谢大神的分享

歪麦 says: 作者

OK~~

w
wufly says: 回复

我在.env文件里设置了redis_host=redis,但是会报以下的错误,这是为什么呢?

ConnectionException in AbstractConnection.php line 155:
Connection refused [tcp://redis:tcp://172.17.0.2:6379]

歪麦 says: 作者

检查下PHP容器里面的hosts文件

a
alan says:

环境变量REDIS_PORT不知道为什么被设置成tcp://172.17.0.2:6379,应该是6379的,在laravel中最终的redis链接变成了[tcp://redis:tcp://172.17.0.2:6379],所以报错,临时解决办法是在config/database.php中的redis配置中不要用env获取环境变量,直接写6379。

x
xhq says: 回复

我就想问问有没有系统要求,我用的是centos7,难道要ubuntu的吗?

N
Nick_Cai says: 回复

大神您好,为什么我修改权限不成功呢?然后一直报403,请帮忙看一下非常感谢!
PS D:\phpStudy\PHPTutorial\WWW\dnmp> docker container ls
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
6a6b8131dcab nginx:alpine “nginx -g ‘daemon of…” 2 hours ago Up 2 hours 0.0.0.0:443->443/tcp, 0.0.0.0:8080->80/tcp dnmp_nginx_1
94f32fce5f43 dnmp_php72 “docker-php-entrypoi…” 2 hours ago Up 2 hours 9000/tcp dnmp_php72_1
9fdb3cbfa5c3 mysql:latest “docker-entrypoint.s…” 2 hours ago Up 2 hours 0.0.0.0:3306->3306/tcp dnmp_mysql_1
447ec6dd634d redis:latest “docker-entrypoint.s…” 2 hours ago Up 2 hours 0.0.0.0:6379->6379/tcp dnmp_redis_1
PS D:\phpStudy\PHPTutorial\WWW\dnmp> docker exec -it dnmp_php-fpm_1 /bin/bash
Error: No such container: dnmp_php-fpm_1
PS D:\phpStudy\PHPTutorial\WWW\dnmp> docker exec -it dnmp_php72_1 /bin/bash
root@94f32fce5f43:/var/www/html# chown -R www-data:www-data /var/www/html
root@94f32fce5f43:/var/www/html# ls -all
total 4
drwxr-xr-x 2 root root 0 Mar 15 00:37 .
drwxr-xr-x 3 root root 4096 Mar 22 22:04 ..
drwxr-xr-x 2 root root 0 Mar 26 02:45 site1
drwxr-xr-x 2 root root 0 Mar 15 00:37 site2
root@94f32fce5f43:/var/www/html# chown -R 777 /var/www/html
root@94f32fce5f43:/var/www/html# ls all
ls: cannot access ‘all’: No such file or directory
root@94f32fce5f43:/var/www/html# ls -all
total 4
drwxr-xr-x 2 root root 0 Mar 15 00:37 .
drwxr-xr-x 3 root root 4096 Mar 22 22:04 ..
drwxr-xr-x 2 root root 0 Mar 26 02:45 site1
drwxr-xr-x 2 root root 0 Mar 15 00:37 site2
root@94f32fce5f43:/var/www/html#

N
Nick_Cai says:

我是win10 上面的docker ,win10里的权限都是可读可写可执行

N
Nick_Cai says:

郁闷laravel安装的时候nginx 要指定到public文件夹下面

歪麦 says: 作者

那就修改nginx配置就可以了的

g
gaoyf says: 回复

您好,执行 docker-compose up 之后 出现如下红色字体,想请教下是什么问题呢?

config.m4:82: warning: AC_REQUIRE: `AC_HEADER_STDC’ was expanded before it was required
config.m4:82: http://www.gnu.org/software/autoconf/manual/autoconf.html#Expanded-Before-Required
../../lib/autoconf/headers.m4:297: _AC_INCLUDES_DEFAULT_REQUIREMENTS is expanded from…
../../lib/autoconf/headers.m4:353: AC_INCLUDES_DEFAULT is expanded from…
../../lib/autoconf/headers.m4:129: _AC_CHECK_HEADER_MONGREL is expanded from…
../../lib/autoconf/headers.m4:67: AC_CHECK_HEADER is expanded from…
../../lib/m4sugar/m4sh.m4:607: AS_FOR is expanded from…
../../lib/autoconf/headers.m4:249: AC_CHECK_HEADERS is expanded from…
libxmlrpc/acinclude.m4:13: XMLRPC_HEADER_CHECKS is expanded from…
libxmlrpc/xmlrpc.m4:1: XMLRPC_CHECKS is expanded from…
config.m4:82: the top level
config.m4:82: warning: AC_REQUIRE: `AC_HEADER_STDC’ was expanded before it was required
config.m4:82: http://www.gnu.org/software/autoconf/manual/autoconf.html#Expanded-Before-Required
../../lib/autoconf/headers.m4:297: _AC_INCLUDES_DEFAULT_REQUIREMENTS is expanded from…
../../lib/autoconf/headers.m4:353: AC_INCLUDES_DEFAULT is expanded from…
../../lib/autoconf/headers.m4:129: _AC_CHECK_HEADER_MONGREL is expanded from…
../../lib/autoconf/headers.m4:67: AC_CHECK_HEADER is expanded from…
../../lib/m4sugar/m4sh.m4:607: AS_FOR is expanded from…
../../lib/autoconf/headers.m4:249: AC_CHECK_HEADERS is expanded from…
libxmlrpc/acinclude.m4:13: XMLRPC_HEADER_CHECKS is expanded from…
libxmlrpc/xmlrpc.m4:1: XMLRPC_CHECKS is expanded from…
config.m4:82: the top level

歪麦 says: 作者

容器中编译扩展的提示,如果不是error,可以略过~如果要深究的话,需呀看看上下文的信息。

J
Jason says: 回复

博主,您好,非常感谢您的教程,我个人受益匪浅,不过我有个小疑问,为什么不将操作系统也docker 化呢?基于云基础,依赖一个ubuntu 系统会受限。

歪麦 says: 作者

毕竟嘛,已经有那么多系统了,windows、linux、macos,linux又有ubuntu、centos、fedora。。。,要是做成系统,那docker不就是再做一个ubuntu了吗?
docker的目的是尽量利用宿主机的资源,兼容这些系统,再任何平台提供一个统一的环境~

s
summer says: 回复

你好,你说的php版本随意切换,应该怎么切换?欢迎你给我回信!

歪麦 says: 作者

这样来:

$ docker-compose -f docker-compose54.yml up
$ docker-compose -f docker-compose56.yml up
z
zhangfei says:

docker-compose -f docker-compose54.yml up
这样不行啊,还是直接运行已经安装的php7.2

歪麦 says: 作者

如果现在用的是php72,但是没用过php54,要加个–build:
docker-compose -f docker-compose54.yml up –build

兔子 says:

不行的话 就先执行 docker-compose stop 吧

是否 says: 回复

博主您好,我的报错也是Notice: Undefined variable: proxy_host in PEAR/Proxy.php on line 163

Notice: Undefined variable: proxy_port in PEAR/Proxy.php on line 163
No releases available for package “pecl.php.net/redis”
install failed
ERROR: Service ‘php72’ failed to build: The command ‘/bin/sh -c pecl install redis-3.1.4 && docker-php-ext-enable redis && : && pecl install xdebug-2.6.0alpha1 && docker-php-ext-enable xdebug && : && apt-get install -y libmagickwand-dev && pecl install imagick-3.4.3 && docker-php-ext-enable imagick && : && apt-get install -y libmemcached-dev zlib1g-dev && pecl install memcached-3.0.4 && docker-php-ext-enable memcached’ returned a non-zero code: 1
看了您之前的回答,我也找不到RUN pear config-set http_proxy http://10.0.75.1:1080这个代码。。。而且也不知道怎么解决这个报错,能麻烦详细点说下如何处理吗,期待中。。。。

是否 says: 回复

看到博主已经把那个删除了,git再拉一遍就好了

张磊 says: 回复

博主 刚刚拉取你的代码。执行docker-compose up

到这一步就停了
mysql_1 | 2018-04-12T05:34:24.662022Z 0 [Warning] ‘user’ entry ‘mysql.sys@localhost’ ignored in –skip-name-resolve mode.
mysql_1 | 2018-04-12T05:34:24.662624Z 0 [Warning] ‘db’ entry ‘performance_schema mysql.session@localhost’ ignored in –skip-name-resolve mode.
mysql_1 | 2018-04-12T05:34:24.662664Z 0 [Warning] ‘db’ entry ‘sys mysql.sys@localhost’ ignored in –skip-name-resolve mode.
mysql_1 | 2018-04-12T05:34:24.663223Z 0 [Warning] ‘proxies_priv’ entry ‘@ root@localhost’ ignored in –skip-name-resolve mode.
mysql_1 | 2018-04-12T05:34:24.692841Z 0 [Warning] ‘tables_priv’ entry ‘user mysql.session@localhost’ ignored in –skip-name-resolve mode.
mysql_1 | 2018-04-12T05:34:24.692865Z 0 [Warning] ‘tables_priv’ entry ‘sys_config mysql.sys@localhost’ ignored in –skip-name-resolve mode.
mysql_1 | 2018-04-12T05:34:24.820424Z 0 [Note] Event Scheduler: Loaded 0 events
mysql_1 | 2018-04-12T05:34:24.821021Z 0 [Note] mysqld: ready for connections.
mysql_1 | Version: ‘5.7.21-log’ socket: ‘/var/run/mysqld/mysqld.sock’ port: 3306 MySQL Community Server (GPL)
mysql_1 | 2018-04-12T06:01:19.000392Z 0 [Note] InnoDB: page_cleaner: 1000ms intended loop took 1343534ms. The settings might not be optimal. (flushed=0 and evicted=0, during the time.)

歪麦 says: 作者

并木有错呀,mysql已经可以用了的。

i
ihero says: 回复

#16: *9 FastCGI sent in stderr: “Primary script unknown” while reading response header from upstream, client: 172.17.0.1, server: localhost, request: “GET /index.php HTTP/1.1”, upstream: “fastcgi://172.17.0.5:9000”, host: “localhost”

不知知道什么原因

歪麦 says: 作者

在PHP容器里面,localhost就是容器本身。

l
larlence says: 回复

我window 的虚拟机里面装docker 部署好项目使用curl会报这个错误怎么解决呢?

cURL error 6: Could not resolve host

歪麦 says: 作者

在docker-compose的PHP容器下加个:extra_hosts

p
pmls63 says: 回复

socket: ‘/var/run/mysqld/mysqld.sock’ port: 3306 MySQL Community Server (GPL)
同样出现这个问题,将数据库host修改为mysql使用原生new pdo可以使用,但是像wordpress的框架无法使用

p
pmls63 says:

请教下博主怎么处理这个问题呢

歪麦 says: 作者

宿主机改用“127.0.0.1:3306”连接(不要用localhost,原因正文有说明),PHP代码用“mysql:3306”连接

p
pmls63 says:

好的谢谢

s
sowhy says: 回复

你好,Mac环境下出现这个:
ERROR: for mysql Cannot start service mysql: b’Mounts denied: \r\nThe paths /dnmp/log/mysql and /dnmp/conf/mysql/my.cnf and /dnmp/mysql\r\nare not shared from OS X and are not known to Docker.\r\nYou can configure shared paths from Docker -> Preferences… -> File Sharing.\r\nSee https://docs.docker.com/docker-for-mac/osxfs/#namespaces for more info.\r\n.’
ERROR: Encountered errors while bringing up the project.

请问怎么处理

歪麦 says: 作者

目录权限问题,修改下权限。

c
chao says: 回复

E:\php\doker\dnmp\dnmp>docker-compose up
Starting dnmp_mysql_1
Starting dnmp_redis_1
Starting dnmp_php72_1
Starting dnmp_nginx_1
Attaching to dnmp_mysql_1, dnmp_redis_1, dnmp_php72_1, dnmp_nginx_1
[36mmysql_1 |[0m
[36mmysql_1 |[0m ERROR: mysqld failed while attempting to check config
[36mmysql_1 |[0m command was: “mysqld –verbose –help”
[33mredis_1 |[0m 1:C 25 Apr 15:16:31.068 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
[36mmysql_1 |[0m
[33mredis_1 |[0m 1:C 25 Apr 15:16:31.068 # Redis version=4.0.9, bits=64, commit=00000000, modified=0, pid=1, just started
[36mmysql_1 |[0m mysqld: Error on realpath() on ‘/var/lib/mysql-files’ (Error 2 – No such file or directory)
[32mphp72_1 |[0m [25-Apr-2018 15:16:34] NOTICE: fpm is running, pid 1
[33mredis_1 |[0m 1:C 25 Apr 15:16:31.068 # Warning: no config file specified, using the default config. In order to specify a config file use redis-server /path/to/redis.conf
[36mmysql_1 |[0m 2018-04-25T15:16:30.894888Z 0 [ERROR] [MY-010095] [Server] Failed to access directory for –secure-file-priv. Please make sure that directory exists and is accessible by MySQL Server. Supplied value : /var/lib/mysql-files
[32mphp72_1 |[0m [25-Apr-2018 15:16:34] NOTICE: ready to handle connections
[36mmysql_1 |[0m 2018-04-25T15:16:30.896234Z 0 [ERROR] [MY-010119] [Server] Aborting
[33mredis_1 |[0m 1:M 25 Apr 15:16:31.070 * Running mode=standalone, port=6379.
[33mredis_1 |[0m 1:M 25 Apr 15:16:31.070 # WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128.
[33mredis_1 |[0m 1:M 25 Apr 15:16:31.070 # Server initialized
[33mredis_1 |[0m 1:M 25 Apr 15:16:31.070 # WARNING you have Transparent Huge Pages (THP) support enabled in your kernel. This will create latency and memory usage issues with Redis. To fix this issue run the command ‘echo never > /sys/kernel/mm/transparent_hugepage/enabled’ as root, and add it to your /etc/rc.local in order to retain the setting after a reboot. Redis must be restarted after THP is disabled.
[33mredis_1 |[0m 1:M 25 Apr 15:16:31.070 * Ready to accept connections
[36mdnmp_mysql_1 exited with code 1
[0m

你好 大神,为什么mysql这里会报错,没有找到原因,请指点

歪麦 says: 作者

可以搜下你贴出来的日志的error,是不是有配置了个:/var/lib/mysql-files,确保这个目录存在并且可访问哦~

p
pmls63 says: 回复

请问下,我在centos中部署了一个dnmp,但是我想在本地mac主机上面想访问数据库,或者用navicate连接数据库,会报错
ERROR 2059 (HY000): Authentication plugin ‘caching_sha2_password’ cannot be loaded: dlopen(/usr/local/Cellar/mysql/5.7.21/lib/plugin/caching_sha2_password.so, 2): image not found
麻烦作者帮忙看看

没有做任何改动,mysql始终不能启动,也没找到对应的错误问题 says: 回复

mysql_1 |
mysql_1 | ERROR: mysqld failed while attempting to check config
mysql_1 | command was: “mysqld –verbose –help”
mysql_1 |
mysql_1 | mysqld: [Warning] World-writable config file ‘/etc/mysql/my.cnf’ is ignored.
mysql_1 | mysqld: Error on realpath() on ‘/var/lib/mysql-files’ (Error 2 – No such file or directory)
mysql_1 | 2018-04-30T19:08:41.012004Z 0 [ERROR] [MY-010095] [Server] Failed to access directory for –secure-file-priv. Please make sure that directory exists and is accessible by MySQL Server. Supplied value : /var/lib/mysql-files
mysql_1 | 2018-04-30T19:08:41.013312Z 0 [ERROR] [MY-010119] [Server] Aborting
php72_1 | [30-Apr-2018 19:08:41] NOTICE: fpm is running, pid 1
php72_1 | [30-Apr-2018 19:08:41] NOTICE: ready to handle connections
php70_mysql_1 exited with code 1

1
123 says:

我把mysql换成5.6版本了

C
Cwift says:

应该是mysql的镜像版本更新了,我是这么做的:创建 /var/lib/mysql-files/ 目录,修改docker-compose.yml中的mysql的配置文件,增加下面这行:
– ./mysql-files/:/var/lib/mysql-files/:rw
然后重启mysql:
docker-compose up -d –no-deps –build mysql

歪麦 says: 作者

确实是,mysql有更新了最新版本,也可以调整my.cnf配置:
secure_file_priv=""

C
Cwift says:

貌似还是不行,又报别的错误了…

m
marion says: 回复

ERROR: for php72 Cannot start service php72: Cannot link to a non running container: /dnmp_mysql_1 AS /dnmp_php72_1/dnmp_mysql_1
ERROR: Encountered errors while bringing up the project.

d
docker-compose mysql报错 says: 回复

ERROR: for dnmp_mysql_1 Cannot start service mysql: b’OCI runtime create failed: container_linux.go:348: starting container process caused “process_linux.go:402: container init caused \\”rootfs_linux.go:58: mounting \\\\\\”/Users/rainsen/dnmp/conf/mysql/my.cnf\\\\\\” to rootfs \\\\\\”/var/lib/docker/overlay2/a5217b43bbf51778f959777f8577292e66709dce4a60fb99e83d9c0dc80cfd5b/merged\\\\\\” at \\\\\\”/var/lib/docker/overlay2/a5217b43bbf51778f959777f8577292e66709dce4a60fb99e83d9c0dc80cfd5b/merged/etc/mysql/my.cnf\\\\\\” caused \\\\\\”not a directory\\\\\\”\\””: unknown: Are you trying to mount a directory onto a file (or vice-versa)? Check if the specified host path exists and is the expected type’

m
mystte says:

我也遇到了类似的错误,不过你报错信息里面有好多“\\\\\\”,而我的是“\\\”,我是在win10家庭版下的Docker Toolbox里面安装dnmp报的错,不知道为什么挂载源目录和挂载目标目录上会加上“\\\”字符

ERROR: for php56 Cannot start service php56: OCI runtime create failed: container_linux.go:345: starting container process caused “process_linux.go:424: container init caused \”rootfs_linux.go:58: mounting \\\”/e/program/Docker Toolbox/dnmp/conf/php-fpm.conf\\\” to rootfs \\\”/mnt/sda1/var/lib/docker/overlay2/5977a826bee8b96d081b3c59e62e22e8ffb573925cf49dda293bdbc3149d8153/merged\\\” at \\\”/mnt/sda1/var/lib/docker/overlay2/5977a826bee8b96d081b3c59e62e22e8ffb573925cf49dda293bdbc3149d8153/merged/usr/local/etc/php-fpm.d/www.conf\\\” caused \\\”not a directory\\\”\””: unknown: Are you trying to mount a directory onto a file (or vice-versa)? Check if the specified host path exists and is the expected type

壹枝雪糕 says: 回复

Starting dnmp_mysql_1 …
Starting dnmp_mysql_1 … done
Starting dnmp_php72_1 … error

ERROR: for dnmp_php72_1 Cannot start service php72: b’Cannot link to a non running container: /dnmp_mysql_1 AS /dnmp_php72_1/mysql’

ERROR: for php72 Cannot start service php72: b’Cannot link to a non running container: /dnmp_mysql_1 AS /dnmp_php72_1/mysql’
ERROR: Encountered errors while bringing up the project.
请问这是什么错误呢?

歪麦 says: 作者

重新去github拉一份吧,mysql有更新了最新版本,调整my.cnf配置就可以了:
secure_file_priv=""

小欧 says: 回复

你好 我本机是win10 安装了virtual box,virtual box 安装了centos7 ,然后centos7里安装docker docker-composer ;
我把代码clone在win10中文件夹,然后文件夹通过virtual box 共享到centos7,在运行up后,访问返回 403 Forbidden。
但是如果我把代码clone到centos7中,然后再运行up后,就可以正常访问,请问怎么解决这个权限问题呢?

歪麦 says: 作者

在Win10里面,打开docker界面,把docker-compose.yml所在的盘符共享给docker。

小欧 says:

我的docker是安装在virtual box里的centos7虚拟机的,win10中代码所在的code文件已经通过virtual box共享给了centos7了。

b
bill says: 回复

你好,我第一次执行:docker-compose up
退出后,停止容器,
第二次执行:docker-compose -f docker-compose56.yml up

发现就不构建了,直接用php7的那个了

请问一下这是为什么呢

歪麦 says: 作者

已经构建的话,就会直接使用了的。
在后面加个–build就会根据yml重新构建,下次直接up就可以了。

b
bill says:

就是我第一次用docker-compose.yml构建php7版本,也想构建个php5.6的版本,就是执行这样的命令就可以了?
docker-compose -f docker-compose56.yml –build up

歪麦 says: 作者

可以的。

天蓝 says: 回复

请问容器启动后,怎么让8.0.11 MySQL 配置远程登录呢? 以前常惯的 grant all privileges on *.* to root@”%” identified by “123456” with grant option; 发现不好使了,会报错

歪麦 says: 作者

这个命令执行之后,有FLUSH PRIVILEGES;么?
或者my.conf是否已经配置了bind-address = 127.0.0.1

b
bill says:

请问,怎么让8.0.11 MySQL 配置远程登录呢?我docker加载了phpmyadmin后,一直都不能登录上,提示如下:

mysqli_real_connect(): php_network_getaddresses: getaddrinfo failed: Name does not resolve

mysqli_real_connect(): (HY000/2002): php_network_getaddresses: getaddrinfo failed: Name does not resolve

天蓝 says:

有FLUSH PRIVILEGES; 不过还是直接语法错误,应该是8.0版本跟5.版本有区别吧。 后面我是根据网上的来执行,稀里糊涂解决了:

user mysql;
delete from user where Host = ‘%’ and User = ‘root’;
update user set Host=’%’ where User=’root’;
select Host, User from user;

ALTER USER ‘root’@’%’ IDENTIFIED WITH mysql_native_password BY ‘root’;

ALTER USER ‘root’@’%’ IDENTIFIED BY ‘新密码’;
flush privileges;

b
bill says:

你的php版本是5.6?

依然灬灰 says: 回复

Attaching to dnmp_redis_1, dnmp_php72_1, dnmp_nginx_1
redis_1 | 1:C 17 May 12:32:34.474 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
redis_1 | 1:C 17 May 12:32:34.474 # Redis version=4.0.9, bits=64, commit=00000000, modified=0, pid=1, just started
redis_1 | 1:C 17 May 12:32:34.474 # Warning: no config file specified, using the default config. In order to specify a config file use redis-server /path/to/redis.conf
redis_1 | 1:M 17 May 12:32:34.476 * Running mode=standalone, port=6379.
redis_1 | 1:M 17 May 12:32:34.476 # WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128.
redis_1 | 1:M 17 May 12:32:34.476 # Server initialized
redis_1 | 1:M 17 May 12:32:34.476 # WARNING you have Transparent Huge Pages (THP) support enabled in your kernel. This will create latency and memory usage issues with Redis. To fix this issue run the command ‘echo never > /sys/kernel/mm/transparent_hugepage/enabled’ as root, and add it to your /etc/rc.local in order to retain the setting after a reboot. Redis must be restarted after THP is disabled.
redis_1 | 1:M 17 May 12:32:34.477 * Ready to accept connections
php72_1 | [17-May-2018 12:32:48] NOTICE: fpm is running, pid 1
php72_1 | [17-May-2018 12:32:48] NOTICE: ready to handle connections
这个问题需要如何解决

s
shell says: 回复

你好,我用你的这个成功搭建好了环境
但是发现当挂载的是文件的时候,比如my.cnf 在宿主机修改后,docker里面并没有变化
我现在只能是删除重新生成容器,大神有别的方法吗?

歪麦 says: 作者

改了my.cnf之后,要重启容器:docker-compose restart mysql

s
shell says:

谢谢博主^_^

用“mysql”链接数据库 says: 回复

博主: 在centos7中使用最新的dnmp搭建环境,数据库使用“mysql”链接不上,什么原因呢?还是有别的操作方法?求解!

歪麦 says: 作者

有具体的日志吗?进入php容器,ping mysql的结果是什么呢?

木木 says: 回复

php容器与数据库mysql无法通讯,提示报错:
SQLSTATE[HY000] [2002] Connection refused

歪麦 says: 作者

首先,用docker ps看看mysql容器是否启动,以及端口映射是否正确。
然后检查是否是连接ip、端口、密码的问题。

青波 says:

地址一栏为mysql,不是127.0.0.1

史莱姆 says: 回复

楼主你好,启动的时候报错:dnmp-php | [31-May-2018 09:48:53] ERROR: failed to open configuration file ‘/usr/local/etc/php-fpm.d/www.conf’: Permission denied (13) 有什么解决办法吗

歪麦 says: 作者

权限原因,修改下权限:chmod a+r conf/php-fpm/www.conf

m
marion says: 回复

请问如何你能重启php-fpm

歪麦 says: 作者

一般我重启容器连带一起重启PHP-FPM

p
phper says: 回复

怎么安装swoole 扩展,通过peal 安装老报错,希望博主帮忙解决一下

歪麦 says: 作者

那通过源码来安装把,最稳妥了,具体可参考文件:dnmp/php/php54/Dockerfile

这个文件最后有通过源码安装zendopcache的方式,swoole惨照这个步骤就可以了。

p
phper says: 回复

5.6 build 提示问题
The following packages have unmet dependencies:
libfreetype6-dev : Depends: zlib1g-dev but it is not going to be installed or
libz-dev
libpng12-dev : Depends: zlib1g-dev but it is not going to be installed
E: Unable to correct problems, you have held broken packages.
ERROR: Service ‘php5.6’ failed to build: The command ‘/bin/sh -c apt-get update && apt-get install -y libfreetype6-dev libjpeg62-turbo-dev libpng-dev && docker-php-ext-configure gd –with-freetype-dir=/usr/include/ –with-jpeg-dir=/usr/include/ && docker-php-ext-install gd && : && apt-get install -y libicu-dev && docker-php-ext-install intl && : && apt-get install -y libxml2-dev && apt-get install -y libxslt-dev && docker-php-ext-install soap && docker-php-ext-install xsl && docker-php-ext-install xmlrpc && docker-php-ext-install wddx && : && apt-get install -y libbz2-dev && docker-php-ext-install bz2 && : && docker-php-ext-install zip && docker-php-ext-install pcntl && docker-php-ext-install pdo_mysql && docker-php-ext-install mysqli && docker-php-ext-install mbstring && docker-php-ext-install exif && docker-php-ext-install bcmath && docker-php-ext-install calendar && docker-php-ext-install sockets && docker-php-ext-install gettext && docker-php-ext-install shmop && docker-php-ext-install sysvmsg && docker-php-ext-install sysvsem && docker-php-ext-install sysvshm && docker-php-ext-install opcache && : && apt-get install -y libmcrypt-dev && docker-php-ext-install mcrypt && : && apt-get install -y curl && apt-get install -y libcurl3 && apt-get install -y libcurl4-openssl-dev && docker-php-ext-install curl && : && apt-get install -y inetutils-ping && apt-get install -y net-tools && : && curl -sS https://getcomposer.org/installer | php — –install-dir=/usr/bin/ –filename=composer && :RUN pecl install redis-3.1.4 && docker-php-ext-enable redis && : && pecl install xdebug-2.5.5 && docker-php-ext-enable xdebug && : && apt-get install -y libmagickwand-dev && pecl install imagick-3.4.3 && docker-php-ext-enable imagick && : && apt-get install -y libmemcached-dev zlib1g-dev && pecl install memcached-2.2.0 && docker-php-ext-enable memcached’ returned a non-zero code: 100

歪麦 says: 作者

apt-get install update后面加一条命令:

&& apt-get install -y zlib1g-dev
羊毛先生 says:

5.6的docker启动时报错,按照你说的加了&& apt-get install -y zlib1g-dev
后报错变成了
The following packages have unmet dependencies:
zlib1g-dev : Depends: zlib1g (= 1:1.2.8.dfsg-2+b1) but 1:1.2.8.dfsg-5 is to be installed
E: Unable to correct problems, you have held broken packages.

歪麦 says: 作者

有另外两个解决方法:
1、删除php/php56/Dockerfile中这一行:

COPY ./sources.list.jessie /etc/apt/sources.list

容器里面直接使用官方源,这样就是build的时候慢一些。
2、把php/php56/source.list.jesse的内容改为中科大的源:

deb http://mirrors.ustc.edu.cn/debian stable main contrib non-free
deb-src http://mirrors.ustc.edu.cn/debian stable main contrib non-free
deb http://mirrors.ustc.edu.cn/debian stable-proposed-updates main contrib non-free
deb-src http://mirrors.ustc.edu.cn/debian stable-proposed-updates main contrib non-free

这样速度会快很多。
试过163、阿里云、腾讯云、清华的源,都会报类似的错误,国内目前测试了这几个,只有中科大的源正常。

小帅 says: 回复

dnmp-mysql | mbind: Operation not permitted
dnmp-mysql | mysqld: File ‘/var/log/dnmp/mysql.slow.log’ not found (OS errno 13 – Permission denied)
dnmp-mysql | 2018-06-09T17:53:23.111890Z 0 [ERROR] [MY-011263] [Server] Could not use /var/log/dnmp/mysql.slow.log for logging (error 13 – Permission denied). Turning logging off for the server process. To turn it on again: fix the cause, then either restart the query logging by using “SET GLOBAL SLOW_QUERY_LOG=ON” or restart the MySQL server.

1,mbind错误是docker跑mysql的正常现象对吧?
2,mysql.slow.log一直无法加载,已经修改宿主config关闭selinux了,并且chmod 755 log设定好了目录权限

歪麦 says: 作者

1. mbind正常现象
2. 在my.cnf里面把手动指定的mysql.slow.log那一行注释,让MySQL自动生成。

小帅 says:

宿主# mysql -h127.0.0.1 -uroot -p
Enter password:
ERROR 2059 (HY000): Authentication plugin ‘caching_sha2_password’ cannot be loaded: /usr/lib64/mysql/plugin/caching_sha2_password.so: cannot open shared object file: No such file or directory
似乎是mysql8默认采用caching_sha2_password导致的

但更奇怪的事情是3天前在另一台服务器上建立的dnmp就可以连接,一样的宿主环境,都是centos7.5,一样版本的docker和docker-composer,检查过mysql镜像也都是最新的8.0,有点懵逼了。。。

加加笔记 says:

我也是遇到同样的问题,请问,解决了吗?我用的centos7.2

歪麦 says: 作者

如果是已经启动了的MySQL,不想重新生成mysql/下的文件,用这个改掉密码的加密方式:

ALTER USER 'username'@'ip_address' IDENTIFIED WITH mysql_native_password BY 'password';

如果是可以重新生成MySQL Data文件,这里就是我们项目的mysql/目录下,那么删除mysql/下的所有文件,然后在my.cnf文件加上这样一样:

[mysqld]
default-authentication-plugin=mysql_native_password

再重新启动mysql就可以了。

a
ak says: 回复

docker-compose up
ERROR: Couldn’t connect to Docker daemon at http+docker://localhost – is it running?

If it’s at a non-standard location, specify the URL with the DOCKER_HOST environment variable.

“DOCKER_HOST “是需要把它弄成环境变量吗?使用的是centos7.5

歪麦 says: 作者

1. 确定当前用户已经加入docker用户组
2. 停止所有容器,重启docker进程,再启动容器。

V
Vincent says: 回复

你好在 docker-compose up 这一步报错
ERROR: for dnmp-nginx Cannot start service nginx: driver failed programming external connectivity on endpoint dnmp-nginx (ca6d71aad83570cd058dfcf89502875516349a432f7353341bfdf8b8b900b671): Error starting userland proxy: Bind for 0.0.0.0:80: unexpected error (Failure EADDRINUSE)

ERROR: for nginx Cannot start service nginx: driver failed programming external connectivity on endpoint dnmp-nginx (ca6d71aad83570cd058dfcf89502875516349a432f7353341bfdf8b8b900b671): Error starting userland proxy: Bind for 0.0.0.0:80: unexpected error (Failure EADDRINUSE)

歪麦 says: 作者

主机80端口被占用了吧

T
Turandot says: 回复

你好!新手请教几个问题
1、安装完毕后提示如下:
$ docker-compose up
Starting dnmp-redis … done
Starting dnmp-nginx … done
Starting dnmp-mysql … done
Starting dnmp-php … done
Attaching to dnmp-redis, dnmp-php, dnmp-nginx, dnmp-mysql
dnmp-redis | 1:C 16 Jun 03:03:00.657 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
dnmp-redis | 1:C 16 Jun 03:03:00.657 # Redis version=4.0.9, bits=64, commit=00000000, modified=0, pid=1, just started
dnmp-redis | 1:C 16 Jun 03:03:00.657 # Warning: no config file specified, using the default config. In order to specify a config file use redis-server /path/to/redis.conf
dnmp-redis | 1:M 16 Jun 03:03:00.658 * Running mode=standalone, port=6379.

这算成功部署了吗?这么多警告正常吗?还有怎么再进入命令行模式呢?这段信息之后似乎没有结束,除了ctrl c停止之外没法进行其他操作。。

2、在Mac上,用dnmp的模式和mamp有什么区别呢?开发网站的话,文件操作是在shell中进行还是直接在挂载的host上操作?和生产环境怎么同步呢?我以前都是xampp或者mamp然后ftp上传的。。。

新手,见笑了

歪麦 says: 作者

1、没啥问题啊,正常的,打印出来的都是日志,有一些是warning级别的,不会影响使用,一般情况下都会有的
2、要进入命令行,重新打开一个终端不就可以了?不想用ctrl + c,在后面加个-d,让容器后台运行。
3、木有dnmp和mamp模式之分哦,dnmp只是一个名称而已,我们这里不存在mamp的概念
4、开发所用到的文件都在host上了,直接在host上改就行了
5、同步用ftp、git啥的都可以,能同步php文件就行

T
Turandot says:

# Ben @ Bens-MacBook-Pro in ~/dnmp on git:master x [21:11:33]
$ docker-compose ps
Name Command State Ports
———————————————————————————————-
dnmp-mysql docker-entrypoint.sh mysqld Up 0.0.0.0:3306->3306/tcp
dnmp-nginx nginx -g daemon off; Up 0.0.0.0:443->443/tcp, 0.0.0.0:80->80/tcp
dnmp-php docker-php-entrypoint php-fpm Up 9000/tcp
dnmp-redis docker-entrypoint.sh redis … Up 0.0.0.0:6379->6379/tcp

如上,服务都算成功启动了对吧?然后测试页面也能正常打开,于是准备安装typecho程序,卡在第一步数据库连接失败。填写的参数都是typecho程序默认的,数据库名称typecho、用户名root、密码123456,但是无法连接数据库。这是什么原因呢?权限问题还是什么?

试图连接数据库也是失败,信息如下:
# Ben @ Bens-MacBook-Pro in ~/dnmp on git:master x [21:11:46]
$ mysql -h 127.0.0.1 -u root -p
zsh: command not found: mysql

于是试图配置环境变量,还是没有成功,是因为我本地没有安装mysql吗?
zshrc文件信息:
# User configuration
export PATH=”/usr/local/bin:/usr/local/sbin:/usr/bin:/bin:/usr/sbin:/sbin”

请大神指教!

另外,对于docker的开发模式我还是有点懵,比如我要装phpmyadmin的话,是要进入容器安装对吧?不能装在host上吧?那怎么进入容器安装呢?执行docker-compose up如果不加-d运行在后台,运行完毕后不返回到$命令行输入模式。表述的有点混乱,抱歉了

歪麦 says: 作者

mysql命令连不上,说明MySQL客户端没安装,要区别客户端和服务器哦,不是同一个东西。

对于容器,你就当成每个容器就是一台pc就行了,有自己的ip、hosts等资源

T
Turandot says:

MySQL客户端没安装的意思是host没有安装客户端吗?那就brew install mysql就行了对吧?

歪麦 says: 作者

可以的

T
Turandot says:

docker-compose up 之后,sequel pro也是无法连接,host我填的是yml中的dnmp-mysql。尝试了各种办法都不行,实在没招了。就想本地调试Wordpress和Typecho程序,install页面可以打开,说明PHP正常,但是数据库配置步骤一直失败。请教大神,你这个版本的安装成功后不能直接测试cms程序吗?

歪麦 says: 作者

当然可以测试cms啦,不然这个工具还有啥用,是吧。
是不是你的MySQL没有启动起来?用docker ps看看,再在host用mysql客户端连接看是否正常。
正常情况下,我们进入到容器之后,用ping命令是能ping得痛MySQL服务器的,如下是我的测试:

$ docker exec -it dnmp-php /bin/bash

root@654c70cc3bf5:/var/www/html# ping mysql
PING mysql (172.29.0.2): 56 data bytes
64 bytes from 172.29.0.2: icmp_seq=0 ttl=64 time=0.065 ms
64 bytes from 172.29.0.2: icmp_seq=1 ttl=64 time=0.059 ms

root@654c70cc3bf5:/var/www/html# ping dnmp-mysql
PING dnmp-mysql (172.29.0.2): 56 data bytes
64 bytes from 172.29.0.2: icmp_seq=0 ttl=64 time=0.055 ms
64 bytes from 172.29.0.2: icmp_seq=1 ttl=64 time=0.057 ms

root@654c70cc3bf5:/var/www/html# ping net-mysql
ping: unknown host

也就是说,在PHP程序中连接MySQL时,host用mysql(docker-compose.yml中的服务名称)或者dnmp-mysql(容器名称)都可以。

a
acisto says: 回复

docker-compose up 直接报错
ERROR: Version in “./docker-compose.yml” is unsupported. You might be seeing this error because you’re using the wrong Compose file version. Either specify a version of “2” (or “2.0”) and place your service definitions under the `services` key, or omit the `version` key and place your service definitions at the root of the file to use version 1.
For more on the Compose file format versions, see https://docs.docker.com/compose/compose-file/

歪麦 says: 作者

是否改过docker-compose.yml文件?

兔子 says:

我也遇到同样错误了
version: “2.0” 成功 version: “3”失败

兔子 says:

我也遇到了这个问题,
把文件第一行换成 version: “2.0” 成功 (3 1 都失败)
另外 ./www/ 代表自己电脑的项目路径, 可以换成自己的相对路径即可, 不过要修改配置localhost的 site指向,否则需要建site1目录
我的运行环境 win10
另外 我运行 docker-compose up 第一次后localhost访问失败 docker-compose stop 之后 重新 docker-compose up 就访问成功了
非常您的感谢分享

K
Kris says: 回复

请问一下,为什么使用 fopen(url) 的时候报错: failed to open stream: Connection refused。
情况是这样的,我通过docker 搭建的环境,有一个api接口,然后前端访问api的时候直接报这个错,但是我把接口地址改成在线地址,却没有报错。

歪麦 says: 作者

因为容器之间是隔离的,要在PHP容器中访问Nginx的80端口,必须使用某种方式达到这种访问功能,docker提供的就是在docker-compose.yml中加一个选项:extra_hosts

s
summer says: 回复

你好,请问https站点配置,查看日志报的是200成功了,但是域名访问时无法访问此网站,这是什么原因?

歪麦 says: 作者

那应该是PHP代码的问题

羊毛先生 says: 回复

作者您好,感谢提供这样一个开源工具
我在mac以及centos上运行5.6的环境均出现报错
The following packages have unmet dependencies:
libfreetype6-dev : Depends: zlib1g-dev but it is not going to be installed or
libz-dev
libpng12-dev : Depends: zlib1g-dev but it is not going to be installed
E: Unable to correct problems, you have held broken packages.

详情见 https://github.com/yeszao/dnmp/issues/39
希望能帮忙解答下。
Version 17.06.2-ce-mac27 (19124)
Channel: stable
428bd6ceae

小明 says: 回复

请问如何在php中增加swoole扩展呢,修改php的dockerfile吗

歪麦 says: 作者

恩,要修改dockerfile文件,具体步骤可参考php54的dockerfile文件,里面有安装opcache为范例。

小王子 says: 回复

今天使用给你php72跑容器,php72中的redis3.1和memcached都报错,告知php版本过高;memcached版本调高不行,只能注释;redis设置成了4.0;然后跑成功了,我也不知道这样做对不对,折腾了好几个小时,太菜了

歪麦 says: 作者

做得对的,PHP版本最近更新也比较频繁,对应的扩展版本很快可能会失效,最新PHP用最新扩展是正确的做法的。

m
monster says: 回复

构建php7.2-fpm镜像时,一直报Err:1 http://mirrors.aliyun.com/debian stretch InRelease Temporary failure resolving ‘mirrors.aliyun.com’之类的错,把docker所有的container换了阿里DNS,还是同样的错,没任何作用。把该Dockerfile里COPY的sources.list换成debian中国官方源,就变成找不到debian的域名,还是该错误。有其他解决方法吗?

歪麦 says: 作者

多试几次,不行换个别的源,或者重启docker

m
monster says:

proxy

S
Sarcasme says: 回复

Creating redis … done
Creating mysql … done
Creating php-fpm … done
Creating nginx … done
Attaching to redis, mysql, php-fpm, nginx
mysql | Initializing database
mysql | 2018-08-09T03:22:50.489349Z 0 [ERROR] –initialize specified but the data directory has files in it. Aborting.
mysql | 2018-08-09T03:22:50.489823Z 0 [ERROR] Aborting
大神 这里我是用的是5.7

歪麦 says: 作者

错误提示说 --initialize specified but the data directory has files in it,说明/mysql目录下面有文件了,把下面的文件全部删除掉,再启动

t
tpingzhang says:

你好,请问解决了没有,我也遇到这个问题。

华哥 says: 回复

按照文章安装环境 虽然中间有些小插曲但不影响使用 感谢楼主
有个问题 redis的配置文件在哪。。。。

歪麦 says: 作者

在redis容器里面,要单独配置的话,可以跟mysql一样抽离出来

胡老大 says: 回复

PHP容器无法连接mysql啊,已经将地址换成mysql了,另外我在fpm容器中看了hosts文件,没有自动映射mysql呀。

歪麦 says: 作者

如果是从github上拉的代码,那hosts中已经没有了,使用了network方式了,请参看github上面的readme文件

天外飞仙 says: 回复

楼主 你好 我想在php的dockerfile里加php拓展 这个是pecl.net里面没有的 只能通过git clone 一个.git文件 请问应该怎么弄

歪麦 says: 作者

可以参看github上最新的php72/Dockerfile文件,文件最后几个扩展是从源码安装的,跟你这种方式是类似的。

清雨 says: 回复

博主请问DNMP环境,怎么重新编译配置第三方 Nginx 模块 Module ,例如谷歌的 Brotli 和 PageSpeed 。

歪麦 says: 作者

写bash脚本来编译把~

N
Nocturne says: 回复

楼主,请问我在我的虚拟机中安装的dnmp,我如何在主机中访问到虚拟机中的站点

歪麦 says: 作者

端口开放了就可以访问的~

小黑 says: 回复

我想在里边拓展个swoole,可以放在那里?

歪麦 says: 作者

下载swoole源码包,放到 php/php72 目录下,在dockerfile 文件最后加上这几行:

COPY ./swoole-4.0.4.tgz /tmp/swoole.tgz

RUN mkdir -p /tmp/swoole \
&& tar -xf /tmp/swoole.tgz -C /tmp/swoole –strip-components=1 \
&& rm /tmp/swoole.tgz \
&& docker-php-ext-configure /tmp/swoole –enable-redis \
&& docker-php-ext-install /tmp/swoole \
&& rm -r /tmp/swoole

然后重新build容器:

$ docker-compose up --build php
小黑 says: 回复

系统用的是阿里云上免费的centos7.4 ,里边自带的有一个低版本的php 环境, 导致环境安装之后 出现php -v 与phpinfo(); 显示的php版本不一致,现在已经将自带的低版本的环境删除,如何将镜像里边的php放到系统的环境变量里边,使php -v 与phpinfo();两者显示的php版本一致,求解答,谢谢楼主。

歪麦 says: 作者

按理来说,主机pc里面的php版本不会影响到容器里面的php版本的,docker容器与主机的环境基本是隔离的

兔子 says: 回复

我是Windows10系统, 把项目放到本地的对应映射的www目录中的, 发现连接 数据库的时候连接不了, 一直是 Connection timed out(2002) ,
但是我使用 cmd , navicate, 都能够连接, 而且 localhost, 172.0.0.1, 和对应的docker ip 都是可以连接的, 就是php项目中无法连接 一直提示 连接超时. 求解原因是啥???
项目运行正常, 我的其他项目连接的其他服务器的数据库也是访问正常的.

歪麦 says: 作者

需要注意的是,MySQL和PHP是分别是两个容器,也就相当于两台独立的电脑,在主机中能用127.0.0.1连接是因为开放了端口给主机。

PHP要连接MySQL,比较常规的方法是在docker-compose.yml文件中使用links或者networks
这两种方法使用任意一种,都能在PHP容器中通过:mysql(服务名称)来访问MySQL,代码来表示就是:$pdo = new PDO('mysql:host=mysql;dbname=site1', 'root', '123456');

其中links是老的方法,不太建议使用,新版的使用networks在github上面已经更新了的。

兔子 says:

非常感谢 项目连接数据库成功了 使用如下 注意数据库主机用 host=mysql
$pdo = new PDO(‘mysql:host=mysql;dbname=site1’, ‘root’, ‘123456’);。
或者使用 $connect = mysqli_connect(‘mysql’,’root’,’123456′,’wordpress’,’3306′);

兔子 says: 回复

设置目录写权限出错(原文中容器名有误??)
1.执行 docker exec -it dnmp_php-fpm_1 /bin/bash 注意 原文 dlnmp_php-fpm_1 第二个字母是多余 的??
提示没有 No such container: dlnmp_php-fpm_1 , docker ps 确实没有这个容器. 但是项目运行正常

q
qqqqqqian says: 回复

Step 13/14 : RUN chmod +x /tmp/extensions/install.sh && /tmp/extensions/install.sh && rm -rf /tmp/extensions
—> Running in 2e456ff1693b
/bin/sh: 1: /tmp/extensions/install.sh: not found
ERROR: Service ‘php72’ failed to build: The command ‘/bin/sh -c chmod +x /tmp/extensions/install.sh && /tmp/extensions/install.sh && rm -rf /tmp/extensions’ returned a non-zero code: 127
求教 这个错误是怎么回事呢???

E
Elliot says:

请问下您这个问题解决了吗 我也遇到了这个问题

大孟 says: 回复

你好,我用的https://github.com/yeszao/dnmp 这个 docker-compose搭建的环境,我通过php的$_SERVER[‘REMOTE_ADDR’]获取到的访问者ip 是docker网关的ip:192.168.75.1,我怎么修改docker-compose.yml配置能获取到真实的访问者的ip,谢谢。

兔子 says:

可以考虑另一种方案,就是nginx的是里面的虚拟机真实IP的获取方式。搜索一下虚拟机获取访问者真实IP,以前好像看到过是修改nginx的配置,感觉有点相似。.上面你所使用的这个配置里面有一个文件是配置的,你可以做适当修改看看。
原理就是把访问者的真实ip重新用来访问我们的真实服务器。

T
Tuzisir says: 回复

MySQL服务器版本:SQLSTATE[HY000] [2006] MySQL server has gone away

额,访问之后提示这个是怎么回事啊。

路人 says:

github里的docker-compose.yml中已经用networks 代替 links了 文档没更新啊..
现在就困惑在networks是如何通信起来的

残眉 says: 回复

dnmp/Dockerfile 文件第16行是空行

残眉 says: 回复

└── source.list Debian源目录 ,我用 CentOS 可以吗?

歪麦 says: 作者

这是容器用的源,docker容器用的都是debian,与主机无关

i
iHero says:

可以使用centos

g
goodcat says: 回复

Service ‘php56’ failed to build: Please provide a source image with `from` prior to commit

x
xiayin says:

我也是这个问题,请问你解决了吗?

x
xiayin says: 回复

我执行 docker-compose up 的时候会报错 Service ‘php56’ failed to build: Please provide a source image with `from` prior to commit

然后我就修改了 docker-compose.yml 只留下 php72 的但是还是会报错 :

version: “2”
services:
nginx:
image: nginx:alpine
ports:
– “80:80”
– “443:443”
volumes:
– ./www/:/var/www/html/:rw
– ./conf/conf.d:/etc/nginx/conf.d/:rw
– ./conf/nginx.conf:/etc/nginx/nginx.conf:ro
– ./log/:/var/log/dnmp/:rw
restart: always
networks:
– net-php72

php72:
build:
context: .
args:
PHP_VERSION: 7.2
SOURCE_LIST: stretch
XDEBUG_VERSION: 2.6.1
SWOOLE_VERSION: 4.2.1
SUPPORT_MCRYPT: “false”
BUILT_IN_OPCACHE: “true”
expose:
– “9000”
volumes:
– ./www/:/var/www/html/:rw
– ./conf/php.ini:/usr/local/etc/php/php.ini:ro
– ./conf/php-fpm.conf:/usr/local/etc/php-fpm.d/www.conf:rw
– ./log/:/var/log/dnmp/:rw
restart: always
cap_add:
– SYS_PTRACE
networks:
– net-php72

mysql:
image: mysql:8.0
ports:
– “3306:3306”
volumes:
– ./conf/mysql.cnf:/etc/mysql/conf.d/mysql.cnf:ro
– ./mysql/:/var/lib/mysql/:rw
restart: always
networks:
– net-mysql
environment:
MYSQL_ROOT_PASSWORD: “123456”

redis:
image: redis:4.0
restart: always
networks:
– net-redis
ports:
– “6379:6379”

phpmyadmin:
image: phpmyadmin/phpmyadmin:latest
ports:
– “8080:80”
networks:
– net-mysql
environment:
– PMA_HOST=mysql
– PMA_PORT=3306

phpredisadmin:
image: erikdubbelboer/phpredisadmin:latest
ports:
– “8081:80”
networks:
– net-redis
environment:
– REDIS_1_HOST=redis
– REDIS_1_PORT=6379

networks:
net-php72:
net-mysql:
net-redis:

怎么才能解决啊?

歪麦 says: 作者

用version: “3”吧
具体是什么错误?

t
tuzisir says: 回复

我qq,2788828128 我装好了,周六日可以问我。

风中叶子 says: 回复

win10 版的docker下报错是什么情况,不支持吗

歪麦 says: 作者

得是Windows Server 2016或者Windows 10的Anniversary更新(14393)及以上
参看这:https://docs.microsoft.com/en-us/virtualization/windowscontainers/deploy-containers/version-compatibility

风中叶子 says: 回复

我的win10版本是Microsoft Windows [版本 10.0.17134.345]

周捌 says: 回复

[root@VM_81_57_centos dnmp]# docker-compose up
Building php72
Step 1/14 : ARG PHP_VERSION
ERROR: Service ‘php72’ failed to build: Please provide a source image with `from` prior to commit
博主老哥,不停报这个错误,怎么解决?

F
FK says:

同这个问题,怎么解决啊?

歪麦 says: 作者

更新一下docker版本,国内Windows版可以从这里下:https://oomake.com/download/docker-windows

x
xx says:

找到原因了,要更新到最新版docker才行

o
ocean says: 回复

博主,这个是啥错误呀
ERROR: Service ‘php72’ failed to build: Get https://registry-1.docker.io/v2/: dial tcp: lookup registry-1.docker.io on 192.168.65.1:53: too many redirects

o
ocean says: 回复

ERROR: Get https://registry-1.docker.io/v2/: net/http: TLS handshake timeout
博主,为啥每次报的错还不一样呀

歪麦 says: 作者

是不是网络不好,换个国内的docker镜像

F
FK says: 回复

windows下使用docker-compose up 命令时,第14步:
Step 14/15 : RUN chmod +x /tmp/extensions/install.sh && /tmp/extensions/install.sh && rm -rf /tmp/extensions
—> Running in 25a261e63ad9
/bin/sh: 1: /tmp/extensions/install.sh: not found
ERROR: Service ‘php72’ failed to build: The command ‘/bin/sh -c chmod +x /tmp/extensions/install.sh && /tmp/extensions/install.sh && rm -rf /tmp/extensions’ returned a non-zero code: 127

E
Elliot says:

请问下您这个问题解决了吗

乌索普 says:

这个问题解决了嘛?我也遇到了。

歪麦 says: 作者

到github上面重新拉一份吧,是编码的问题,已经加.gitattribute解决了

3
3533 says: 回复

没有Q群什么的么?

李寻欢 says: 回复

mysql 依然出错:
mysql_1 | Initializing database
mysql_1 | Initializing database
mysql_1 | Initializing database
mysql_1 | Initializing database
mysql_1 | Initializing database
mysql_1 | Initializing database
mysql_1 | Initializing database
mysql_1 | Initializing database
mysql_1 | Initializing database
mysql_1 | Initializing database
mysql_1 | Initializing database
dnmp_mysql_1 exited with code 1

w
wendy says: 回复

博主,你好!根据你的dockerfile文件,我已经构建成功了,但是现在有个问题就是在docker环境下使用php-cli命令来执行php文件需要进入到php容器里面,有什么办法能够像原来的在主机直接能够使用php-cli命令,不要进入到php容器里面?

歪麦 says: 作者

可以用shell的alias制作快键键,比如:

alias phpx=docker exec -it dnmp_php72_1 php

下次要执行的时候,就这样:

phpx /var/www/html/localhost/index.php

注意,这里的index.php是容器里面的相对目录。
因为默认目录是:/var/www/html,所以可以简化为:

phpx localhost/index.php
d
docker 小白 says: 回复

你好请问为什么,安装完后,会有很多none的镜像,还删除不了,好像是跟php-fpm72有关的。

心了然 says: 回复

你好请问一下,在安装以后 PHP都不支持mysql的扩展,在网站访问数据库出问题。是不是给指点一下。
数据库支持
MySQL 数据库: × ODBC 数据库: ×
Oracle 数据库: × SQL Server 数据库: ×
dBASE 数据库: × mSQL 数据库: ×
SQLite 数据库: √ SQLite3 Ver 3.8.10.2 Hyperwave 数据库: ×
Postgre SQL 数据库: × Informix 数据库: ×
DBA 数据库: × DBM 数据库: ×
FilePro 数据库: × SyBase 数据库: ×

歪麦 says: 作者

这些扩展是需要自己去打开的哦,在Dockerfile里面,去掉前面的#号注释,再重新build

s
shell says: 回复

博主你好,我用你的代码成功搭建好了环境。但是最近发现了一个比较奇怪的问题,就是mysql没有.frm文件只有.ibd文件。博主知道这是什么情况吗^_^

s
shell says:

知道什么原因了,MySQL8以后没有.frm了,元数据都存在系统表空间里

九爷 says: 回复

我们建议在主机HOST中使用composer而不是在容器中使用

github 里面建议在宿主机器使用composer 但是composer 需要php,php 又在容器里面,而且还是多版本的,这个有什么好的解决办法吗?

求解答!

z
zzhpeng says:

composer update并不需要php哇?

歪麦 says: 作者

参照这里的方法,用一个composer容器:https://github.com/yeszao/dnmp#6%E4%BD%BF%E7%94%A8composer

V
Vincent says: 回复

nginx PATH_INFO 怎么引进来 还有好像并没有安装swoole

歪麦 says: 作者

Nginx的location加上:

location ~ .*\.(php|php5)?$ {
        #...
        fastcgi_param PATH_INFO $fastcgi_path_info;
        #...
    }

PHP5.4 默认不支持swoole

s
sy says: 回复

扩展Php其他库 我在install.sh添加
# xhprof require PHP version 7.2 or later.
if [ ${version} -ge 70200 ]; then
mkdir xhprof \
&& tar -xf xhprof-0.9.4.tgz -C xhprof –strip-components=1 \
&& ( cd xhprof && phpize && ./configure && make $mc && make install ) \
&& docker-php-ext-enable xhprof
fi
怎么还是报错

歪麦 says: 作者

报什么错呢?

星宇 says: 回复

Err http://mirrors.ustc.edu.cn/debian/ stable/main libicu57 amd64 57.1-6+deb9u2
Connection failed [IP: 218.104.71.170 80]
Err http://mirrors.ustc.edu.cn/debian/ stable/main icu-devtools amd64 57.1-6+deb9u2
Could not connect to mirrors.ustc.edu.cn:80 (202.141.176.110). – connect (101: Network is unreachable) [IP: 202.141.176.110 80]
Err http://mirrors.ustc.edu.cn/debian/ stable/main libicu-dev amd64 57.1-6+deb9u2
Unable to connect to mirrors.ustc.edu.cn:http: [IP: 202.141.176.110 80]
Fetched 576 kB in 1min 47s (5382 B/s)
E: Failed to fetch http://mirrors.ustc.edu.cn/debian/pool/main/i/icu/libicu57_57.1-6+deb9u2_amd64.deb Connection failed [IP: 218.104.71.170 80]

E: Failed to fetch http://mirrors.ustc.edu.cn/debian/pool/main/i/icu/icu-devtools_57.1-6+deb9u2_amd64.deb Could not connect to mirrors.ustc.edu.cn:80 (202.141.176.110). – connect (101: Network is unreachable) [IP: 202.141.176.110 80]

E: Failed to fetch http://mirrors.ustc.edu.cn/debian/pool/main/i/icu/libicu-dev_57.1-6+deb9u2_amd64.deb Unable to connect to mirrors.ustc.edu.cn:http: [IP: 202.141.176.110 80]

E: Unable to fetch some archives, maybe run apt-get update or try with –fix-missing?
ERROR: Service ‘php54’ failed to build: The command ‘/bin/sh -c apt install -y libfreetype6-dev libjpeg62-turbo-dev libpng-dev && docker-php-ext-configure gd –with-freetype-dir=/usr/include/ –with-jpeg-dir=/usr/include/ && docker-php-ext-install $mc gd && : && apt install -y libicu-dev && docker-php-ext-install $mc intl && : && apt install -y libbz2-dev && docker-php-ext-install $mc bz2 && : && docker-php-ext-install $mc zip && docker-php-ext-install $mc pcntl && docker-php-ext-install $mc pdo_mysql && docker-php-ext-install $mc mysqli && docker-php-ext-install $mc mbstring && docker-php-ext-install $mc exif’ returned a non-zero code: 100
安装到最后报这个错

歪麦 says: 作者

换个源吧

l
lpb says: 回复

博主你好请问一下 安装完后 使用laravel项目 需要怎么做才能在容器外部使用php容器内部的php脚本呢

l
lpb says:

docker exec -it dnmp_php72_1 php artisan
报 Could not open input file: artisan
也就是怎么让他能识别artisan呢 -。-

l
lpb says:

知道了 指定下容器内映射的项目目录的文件的我位置就行了 看了前人的提问突然明白了 ……

苏大强 says:

最后咋解决的

阿斯玛 says: 回复

为什么装了之后docker image ls -a 显示镜像后,里面一堆的虚悬镜像。删干净重装也是。

n
nini says: 回复

ERROR: The Compose file ‘./docker-compose.yml’ is invalid because:
services.mysql.ports is invalid: Port ranges don’t match in length
services.nginx.ports is invalid: Port ranges don’t match in length
services.redis.ports is invalid: Port ranges don’t match in length
services.nginx.ports is invalid: Port ranges don’t match in length
services.phpmyadmin.ports is invalid: Port ranges don’t match in length
services.phpredisadmin.ports is invalid: Port ranges don’t match in length
楼猪还在吗? 请问下这报错怎么解决

歪麦 says: 作者

在github上下载后,把env.sample改成.env

L
LinHe says: 回复

可以考虑加入let‘s encrypt的脚本,来生成签名证书

青菜 says: 回复

博主,我在mac下装了,很好用

逻辑 says:

你好能加个qq吗

青菜 says: 回复

在此基础上如何加个ice扩展

t
tsfh says: 回复

感谢楼主我这几天弄下来 其他没什么问题但是 遇到 用composer的时候 报
mmap() failed: [12] Out of memory
mmap() failed: [12] Out of memory
这是我机器内存太小了吗?

t
tshf says: 回复

还有个问题 php-fpm 用Unix socket 如何配置nginx 大神求指教!!!

小宇 says: 回复

博主,你好,我是通过windows 挂载在Linux 上面做开发。然后如果mysql 目录完全可写的话是会被忽略 容器起不起来的
通过努力总算把这些东西都弄好了,另外我有个疑问想请教一下,比如我想再在这里面扩充自己的容器比如elasticsearch 等等之类的,是不是继续通过docker-compose来扩展,而不是修改你提供的这个 Dockerfile 来build 自己的镜像?谢谢

j
jason says:

另外:我想说的是如果脚本是PHP-CLI 模式运行的话有点不方便,每次都要进入容器里面执行

小志 says: 回复

Service ‘php72’ failed to build: failed to start service utility VM (createreadwrite): CreateComputeSystem 8818cbe4a6960e0d82f619084c62b51e381a7b888c729f4e4a98466a52df9c00_svm: An address incompatible with the requested protocol was used.
(extra info: {“SystemType”:”container”,”Name”:”8818cbe4a6960e0d82f619084c62b51e381a7b888c729f4e4a98466a52df9c00_svm”,”Layers”:null,”HvPartition”:true,”HvRuntime”:{“ImagePath”:”C:\\Program Files\\Linux Containers”,”LinuxInitrdFile”:”initrd.img”,”LinuxKernelFile”:”kernel”},”ContainerType”:”linux”,”TerminateOnLastHandleClosed”:true})
请问这个错怎么解决呢??

洗衣机 says: 回复

我的本机80端口被占用了 up docker-compose up 不成功 怎么修改端口啊 为什么 ym端口修改了还不成功

歪麦 says: 作者

github上下载的话,改.env文件

d
draonfly429 says: 回复

重启nginx 写错了 docker exec -it dlnmp_nginx_1 nginx -s reload 应该是dnmp_nginx_1 多打了一个l

歪麦 says: 作者

确实是

v
vivian says: 回复

博主我win10 docker git clone后直接运行docker-compose up报错怎么解决呢,配置文件都没改过

v
vivian says:

类似这样的错误WARNING: The NGINX_VERSION variable is not set. Defaulting to a blank string.
貌似所有变量都读取不到
ERROR: The Compose file ‘.\docker-compose.yml’ is invalid because:
services.mysql.ports is invalid: Port ranges don’t match in length
services.nginx.ports is invalid: Port ranges don’t match in length
services.redis.ports is invalid: Port ranges don’t match in length
services.nginx.ports is invalid: Port ranges don’t match in length
services.phpmyadmin.ports is invalid: Port ranges don’t match in length
services.phpredisadmin.ports is invalid: Port ranges don’t match in length

v
vivian says:

呜呜 我看到了处理方法 不好意思

a
acisto says: 回复

我想知道默认的mysql密码会不会不安全,如何修改密码,当我已经docker-compose up过之后,修改.env中的密码,
根据要使修改的docker-compose.yml生效,需要以下4步:

$ docker stop dnmp_nginx_1 # 第一步:停止容器
$ docker rm dnmp_nginx_1 # 第二步:删除容器
# !!第三步:重启Docker服务!!
$ docker-compose up -d –no-deps –build mysql # 第四步:重新启动容器

可是并不能用新密码连上mysql

歪麦 says: 作者

要把镜像也删除掉,docker images命令可看到所有镜像

苏大强 says: 回复

已经装上了,很好很强大。
swoole咋启动呢,有没有大佬讲一下具体的步骤

逻辑 says:

你好能加个qq吗

a
acisto says: 回复

改不了端口号和密码,git源码中已经有my.cnf指定端口3306,不知道改.env中的端口号有什么用,改了似乎没起到作用。

小宇 says:

我就改成了3307 端口,自己再摸索一下,可以改的。my.ini的配置文件好像也要改

歪麦 says: 作者

.env文件时第一次up之前就要改好,它是容器暴露给主机的端口。MySQL配置文件里面的端口是MySQL服务的端口,一般来说不需要改的,用3306就行了。

头条新闻 says: 回复

文章不错非常喜欢

逻辑 says: 回复

一直在循环这个错误!是macOS中安装的 好尴尬啊,谁能帮忙解决????
dnmp_mysql_1 exited with code 1
dnmp_nginx_1 exited with code 1
mysql_1 | chown: changing ownership of ‘/var/lib/mysql/.gitignore’: Operation not permitted
mysql_1 | chown: changing ownership of ‘/var/lib/mysql/’: Operation not permitted
dnmp_mysql_1 exited with code 1
dnmp_nginx_1 exited with code 1
mysql_1 | chown: changing ownership of ‘/var/lib/mysql/.gitignore’: Operation not permitted
mysql_1 | chown: changing ownership of ‘/var/lib/mysql/’: Operation not permitted
dnmp_mysql_1 exited with code 1
dnmp_nginx_1 exited with code 1

脚本叔叔 says: 回复

作者你的前端水平怎么样 还是主后端的

r
riven says: 回复

环境:CentOS Linux release 7.6.1810 (Core)

执行命令docker-compose up后,一直报
dnmp_nginx_1 exited with code 1

怎么处理呢?

r
riven says:

nginx: [emerg] BIO_new_file(“/etc/nginx/conf.d/certs/localhost/localhost.crt”) failed (SSL: error:02001002:system library:fopen:No such file or directory:fopen(‘/etc/nginx/conf.d/certs/localhost/localhost.crt’,’r’) error:2006D080:BIO routines:BIO_new_file:no such file)

歪麦 says: 作者

是不是目录没有读/执行权限?

x
xiaobao says: 回复

出现红色字眼报错:

WARNING: apt does not have a stable CLI interface. Use with caution in scripts.

这个Dockerfile文件应该使用 “apt-get” 而不是 “apt” 吧

歪麦 says: 作者

可以用apt,不过用apt-get更好

淘宝优惠券 says: 回复

谢谢,测试一下

风中叶子 says: 回复

请问楼主怎么安装其他扩展,比如amqp

歪麦 says: 作者

通过pecl或者源码安装都可以的,从github下载最新代码,pecl方式安装请参考 extensions/install.sh 的imagick安装方式,源码方式请参考 php72.sh 的redis、swoole 等安装方式。

乐哥哥 says: 回复

博主 修改nginx配置后重启nginx 是直接重启nginx容器吗?

歪麦 says: 作者

nginx直接重启容器中的nginx就可以了

says: 回复

有群吗?或者可以加q吗?1073929231

冷月 says: 回复

你好 新手请教下 怎么调用docker里的php环境变量到本机啊?还是本机要单独安装php?

神侯长官 says: 回复

windows10如何使用xdebug?
IDE:phpstorm

c
chrisdowson says: 回复

mac遇到这样的错

c
chrisdowson says:

mac遇到这样的错
Starting dnmp_php56_1 …
dnmp_adminmongo_1 is up-to-date
dnmp_rabbitmq_1 is up-to-date
dnmp_phpredisadmin_1 is up-to-date
Starting dnmp_php56_1 … error
Starting elasticsearch7.1.1 …
Starting dnmp_phpmyadmin_1 …
Starting dnmp_mongodb_1 …
Starting dnmp_nginx_1 …
Starting dnmp_php72_1 …
Starting dnmp_mysql_1 …
Starting dnmp_mongodb_1 … error
ERROR: for dnmp_php56_1 Cannot start service php56: error while creating mount source path ‘/Users/duanxiaoqiang/www/dnmp/conf/localtime’: mkdir /Users/duanxiaoqiang/www/dnmp/conf/localtime: file exists

ERROR: for dnmp_mongodb_1 Cannot start service mongodb: error while creating moStarting elasticsearch7.1.1 … error
nxiaoqiang/www/dnmp/conf/localtime: file exists

N
Neemo says:

修改Docfile吧直接把城市写上

14 RUN apk –no-cache add tzdata \
15 && cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
16 && echo ‘Asia/Shanghai’ >/etc/timezone

我也是Mac Build也遇到各种问题, 现在都一一自行解决了

高鹏 says: 回复

Memcached 扩展安装了
为什么 wp 就是认不到呢?

p
pm123 says: 回复

博主,请问运行稳定的镜像 跟 容器,我如何打包 放到另外一台服务器上使用呢?
可以说下打包跟 导入 使用的步骤跟命令吗?
最好是,打包 到导入结束 都描述下

a
abclet says: 回复

composer 时候显示 the requested PHP extension swoole is missing from your system.但是我php 已经安装了swoole

万隆 says: 回复

找到问题所在了,是装的Centos8系统里没有上海这个时区,只能改成Hong_Kong了

Y
Yelz says: 回复

mac 修改了nginx配置以后 docker-compose无论执行哪个命令 就报这么一堆 怎么破?
WARNING: The NGINX_VERSION variable is not set. Defaulting to a blank string.
WARNING: The CONTAINER_PACKAGE_URL variable is not set. Defaulting to a blank string.
WARNING: The NGINX_INSTALL_APPS variable is not set. Defaulting to a blank string.
WARNING: The NGINX_HTTP_HOST_PORT variable is not set. Defaulting to a blank string.
WARNING: The NGINX_HTTPS_HOST_PORT variable is not set. Defaulting to a blank string.
WARNING: The SOURCE_DIR variable is not set. Defaulting to a blank string.
WARNING: The NGINX_SSL_CERTIFICATE_DIR variable is not set. Defaulting to a blank string.
WARNING: The NGINX_CONFD_DIR variable is not set. Defaulting to a blank string.
WARNING: The NGINX_CONF_FILE variable is not set. Defaulting to a blank string.
WARNING: The NGINX_FASTCGI_PHP_CONF variable is not set. Defaulting to a blank string.
WARNING: The NGINX_FASTCGI_PARAMS variable is not set. Defaulting to a blank string.
WARNING: The NGINX_LOG_DIR variable is not set. Defaulting to a blank string.
WARNING: The TZ variable is not set. Defaulting to a blank string.
WARNING: The PHP_VERSION variable is not set. Defaulting to a blank string.
WARNING: The PHP_EXTENSIONS variable is not set. Defaulting to a blank string.
WARNING: The PHP_PHP_CONF_FILE variable is not set. Defaulting to a blank string.
WARNING: The PHP_FPM_CONF_FILE variable is not set. Defaulting to a blank string.
WARNING: The PHP_LOG_DIR variable is not set. Defaulting to a blank string.
WARNING: The DATA_DIR variable is not set. Defaulting to a blank string.
WARNING: The MYSQL_VERSION variable is not set. Defaulting to a blank string.
WARNING: The MYSQL_HOST_PORT variable is not set. Defaulting to a blank string.
WARNING: The MYSQL_CONF_FILE variable is not set. Defaulting to a blank string.
WARNING: The MYSQL_ROOT_PASSWORD variable is not set. Defaulting to a blank string.
ERROR: The Compose file ‘./../../../docker-compose.yml’ is invalid because:
services.mysql.ports is invalid: Port ranges don’t match in length
services.nginx.ports is invalid: Port ranges don’t match in length
services.nginx.ports is invalid: Port ranges don’t match in length

学而享 says:

.env.sample 改为 .env 没?里面是需要关联用到的参数,可以根据实际调整

学而享 says: 回复

请教歪麦大大,多 Web 服务,同样 php 版本的,应该每个服务独立一个 DNMP 还是共享使用一个就可以,对资源占用有什么区别吗?从安全角度考虑是不是独立比较好,相当于站点分离了,如果资源有影响,是不是可以共享 Mysql 。

c
chaohcao6411 says: 回复

问一下 docker-compose up 时候报错
Step 10/18 : ADD https://raw.githubusercontent.com/mlocati/docker-php-extension-installer/master/install-php-extensions /usr/local/bin/
ERROR: Service ‘php’ failed to build: ADD failed: Get https://raw.githubusercontent.com/mlocati/docker-php-extension-installer/master/install-php-extensions: read tcp 192.168.142.22:49402->151.101.0.133:443: read: connection reset by peer

访问这个https://raw.githubusercontent.com 不行

嘟嘟胖胖啊 says: 回复

大佬 安装PHP扩展 build时候出错
$ docker-compose build php
Building php
Step 1/18 : ARG PHP_VERSION
Step 2/18 : FROM ${PHP_VERSION}
—> cb46a5704478
Step 3/18 : ARG TZ
—> Using cache
—> 5804f2fdf0f3
Step 4/18 : ARG PHP_EXTENSIONS
—> Using cache
—> ee0cccc2aa64
Step 5/18 : ARG CONTAINER_PACKAGE_URL
—> Using cache
—> 3dc3487661d0
Step 6/18 : RUN sed -i “s/dl-cdn.alpinelinux.org/${CONTAINER_PACKAGE_URL}/g” /etc/apk/repositories
—> Using cache
—> 846c62a45eb2
Step 7/18 : COPY ./extensions /tmp/extensions
—> Using cache
—> 403bf2e12a82
Step 8/18 : WORKDIR /tmp/extensions
—> Using cache
—> aecad9d055c2
Step 9/18 : RUN chmod +x install.sh && sh install.sh && rm -rf /tmp/extensions
—> Using cache
—> ac5f36b26932
Step 10/18 : ADD https://raw.githubusercontent.com/mlocati/docker-php-extension-installer/master/install-php-extensions /usr/local/bin/
Service ‘php’ failed to build: ADD failed: Get https://raw.githubusercontent.com/mlocati/docker-php-extension-installer/master/install-php-extensions: dial tcp 0.0.0.0:443: connect: connection refused

扶墙了 也不行

嘟嘟胖胖啊 says:

扶墙了 好了 就是网抽风了

嘟嘟胖胖啊 says: 回复

mongo每次启动
mongodb | 2020-05-06T11:11:11.286+0800 I CONTROL [main] Automatically disabling TLS 1.0, to force-enable TLS 1.0 specify –sslDisabledProtocols ‘none’
mongodb | 2020-05-06T11:11:11.290+0800 I CONTROL [initandlisten] MongoDB starting : pid=1 port=27017 dbpath=/data/db 64-bit host=940cb84a9a5b
mongodb | 2020-05-06T11:11:11.290+0800 I CONTROL [initandlisten] db version v4.1.13
mongodb | 2020-05-06T11:11:11.290+0800 I CONTROL [initandlisten] git version: 441714bc4c70699950f3ac51a5cac41dcd413eaa
mongodb | 2020-05-06T11:11:11.290+0800 I CONTROL [initandlisten] OpenSSL version: OpenSSL 1.1.1 11 Sep 2018
mongodb | 2020-05-06T11:11:11.290+0800 I CONTROL [initandlisten] allocator: tcmalloc
mongodb | 2020-05-06T11:11:11.290+0800 I CONTROL [initandlisten] modules: none
mongodb | 2020-05-06T11:11:11.290+0800 I CONTROL [initandlisten] build environment:
mongodb | 2020-05-06T11:11:11.290+0800 I CONTROL [initandlisten] distmod: ubuntu1804
mongodb | 2020-05-06T11:11:11.290+0800 I CONTROL [initandlisten] distarch: x86_64
mongodb | 2020-05-06T11:11:11.290+0800 I CONTROL [initandlisten] target_arch: x86_64
mongodb | 2020-05-06T11:11:11.290+0800 I CONTROL [initandlisten] options: { net: { bindIp: “*” }, security: { authorization: “enabled” } }
mongodb | 2020-05-06T11:11:11.297+0800 I STORAGE [initandlisten] wiredtiger_open config: create,cache_size=1445M,session_max=33000,eviction=(threads_min=4,threads_max=4),config_base=false,statistics=(fast),log=(enabled=true,archive=true,path=journal,compressor=snappy),file_manager=(close_idle_time=100000),statistics_log=(wait=0),verbose=(recovery_progress),verbose=(checkpoint_progress),
mongodb | 2020-05-06T11:11:11.815+0800 E STORAGE [initandlisten] WiredTiger error (17) [1588734671:815007][1:0x7fe22c5c0ac0], connection: __posix_open_file, 712: /data/db/WiredTiger.wt: handle-open: open: File exists Raw: [1588734671:815007][1:0x7fe22c5c0ac0], connection: __posix_open_file, 712: /data/db/WiredTiger.wt: handle-open: open: File exists
mongodb | 2020-05-06T11:11:11.832+0800 I STORAGE [initandlisten] WiredTiger message unexpected file WiredTiger.wt found, renamed to WiredTiger.wt.48
mongodb | 2020-05-06T11:11:11.836+0800 E STORAGE [initandlisten] WiredTiger error (1) [1588734671:836121][1:0x7fe22c5c0ac0], connection: __posix_open_file, 712: /data/db/WiredTiger.wt: handle-open: open: Operation not permitted Raw: [1588734671:836121][1:0x7fe22c5c0ac0], connection: __posix_open_file, 712: /data/db/WiredTiger.wt: handle-open: open: Operation not permitted
mongodb | 2020-05-06T11:11:11.860+0800 E STORAGE [initandlisten] WiredTiger error (17) [1588734671:859961][1:0x7fe22c5c0ac0], connection: __posix_open_file, 712: /data/db/WiredTiger.wt: handle-open: open: File exists Raw: [1588734671:859961][1:0x7fe22c5c0ac0], connection: __posix_open_file, 712: /data/db/WiredTiger.wt: handle-open: open: File exists
mongodb | 2020-05-06T11:11:11.868+0800 I STORAGE [initandlisten] WiredTiger message unexpected file WiredTiger.wt found, renamed to WiredTiger.wt.49
mongodb | 2020-05-06T11:11:11.901+0800 E STORAGE [initandlisten] WiredTiger error (1) [1588734671:901550][1:0x7fe22c5c0ac0], connection: __posix_open_file, 712: /data/db/WiredTiger.wt: handle-open: open: Operation not permitted Raw: [1588734671:901550][1:0x7fe22c5c0ac0], connection: __posix_open_file, 712: /data/db/WiredTiger.wt: handle-open: open: Operation not permitted
mongodb | 2020-05-06T11:11:11.918+0800 E STORAGE [initandlisten] WiredTiger error (17) [1588734671:918955][1:0x7fe22c5c0ac0], connection: __posix_open_file, 712: /data/db/WiredTiger.wt: handle-open: open: File exists Raw: [1588734671:918955][1:0x7fe22c5c0ac0], connection: __posix_open_file, 712: /data/db/WiredTiger.wt: handle-open: open: File exists
mongodb | 2020-05-06T11:11:11.923+0800 I STORAGE [initandlisten] WiredTiger message unexpected file WiredTiger.wt found, renamed to WiredTiger.wt.50
mongodb | 2020-05-06T11:11:11.928+0800 E STORAGE [initandlisten] WiredTiger error (1) [1588734671:928205][1:0x7fe22c5c0ac0], connection: __posix_open_file, 712: /data/db/WiredTiger.wt: handle-open: open: Operation not permitted Raw: [1588734671:928205][1:0x7fe22c5c0ac0], connection: __posix_open_file, 712: /data/db/WiredTiger.wt: handle-open: open: Operation not permitted
mongodb | 2020-05-06T11:11:11.931+0800 W STORAGE [initandlisten] Failed to start up WiredTiger under any compatibility version.
mongodb | 2020-05-06T11:11:11.932+0800 F STORAGE [initandlisten] Reason: 1: Operation not permitted
mongodb | 2020-05-06T11:11:11.932+0800 F – [initandlisten] Fatal Assertion 28595 at src/mongo/db/storage/wiredtiger/wiredtiger_kv_engine.cpp 766
mongodb | 2020-05-06T11:11:11.932+0800 F – [initandlisten]
mongodb |
mongodb | ***aborting after fassert() failure

这个错是为什么呢? 权限问题吗?

n
null says:

阿里云 上我也遇到类似问题 解决方式
vim dnmp/services/php/Dockerfile

ADD https://raw.githubusercontent.com/mlocati/docker-php-extension-installer/master/install-php-extensions /usr/local/bin/
改为
COPY ./install-php-extensions /usr/local/bin/
cd dnmp/services/php/
wget https://raw.githubusercontent.com/mlocati/docker-php-extension-installer/master/install-php-extensions

峰云 says: 回复

WARNING: Ignoring http://mirrors.ustc.edu.cn/alpine/v3.11/main/x86_64/APKINDEX.tar.gz: temporary error (try again later)
fetch http://mirrors.ustc.edu.cn/alpine/v3.11/community/x86_64/APKINDEX.tar.gz
WARNING: Ignoring http://mirrors.ustc.edu.cn/alpine/v3.11/community/x86_64/APKINDEX.tar.gz: temporary error (try again later)
ERROR: unsatisfiable constraints:
WARNING: Ignoring APKINDEX.5f57d7a5.tar.gz: No such file or directory
WARNING: Ignoring APKINDEX.e1c8646f.tar.gz: No such file or directory
freetype (missing):
required by: world[freetype]
freetype-dev (missing):
required by: world[freetype-dev]
libjpeg-turbo (missing):
required by: world[libjpeg-turbo]
libjpeg-turbo-dev (missing):
required by: world[libjpeg-turbo-dev]
libpng (missing):
required by: world[libpng]
libpng-dev (missing):
required by: world[libpng-dev]
———- curl is installed ———-
ERROR: Service ‘php’ failed to build: The command ‘/bin/sh -c chmod +x install.sh && sh install.sh && rm -rf /tmp/extensions’ returned a non-zero code: 1

歪麦大佬,为什么centos8 docker-compose up会报错

K
KarlXu says: 回复

docker如何配置多个php版本同时运行?

K
KarlXu says:

我目前用的是laradock,方法是build两个php-fpm容器然后通过nginx配置去访问不同的版本http://www.karlxu.com/article/details/26

金水立方 says: 回复

想问一下,怎么配置swoole呢?

w
wpf900 says: 回复

Step 1/10 : ARG NGINX_VERSION
ERROR: Service ‘nginx’ failed to build: Please provide a source image with `from` prior to commit

怎么我第一步都报错呀 我是安装教程来的呀

l
lam2 says:

请问这个问题解决了吗?我也遇到了同样的问题

k
kun says: 回复

请教站点配置问题:在nginx容器里的conf.d下配置了dev.test.conf,本机hosts文件也添加了,为啥访问不到呢?

1
1462 says: 回复

您好,这个有集成Kafka的docker-compose文件配置吗?

r
rsalive says: 回复

如何安装sdebug ?有没有贴合这个项目的教程?

r
rsalive says: 回复

安装了swoole 之后,如何安装sdebug ?有没有贴合这个项目的教程?

狗妹 says: 回复

您好,安装好环境之后 redis Failed to open redis DB connection (tcp://127.0.0.1:6379, database=0): 111 – Connection refused
扩展已经安装好了没设置密码

l
laojiu says: 回复

mysql 8一直无限重启 什么都没改;一段时间没动了

圣斗士 says: 回复

你好 我尝试使用了dnmp 在使用一些较冷门的拓展。比如xdebug. yac. 是安装不上的
php 7.3.26版本 php 7.2.9版本 我试了这两个版本
我尝试了好几遍。麻烦看下什么问题 谢谢

嘟嘟胖胖啊 says: 回复

你好,现在这个mongo还是无法启动,总是报错:
{“t”:{“$date”:”2021-04-03T01:58:52.030+00:00″},”s”:”I”, “c”:”STORAGE”, “id”:22430, “ctx”:”initandlisten”,”msg”:”WiredTiger message”,”attr”:{“message”:”unexpected file WiredTiger.wt found, renamed to WiredTiger.wt.64″}}

{“t”:{“$date”:”2021-04-03T01:58:52.032+00:00″},”s”:”E”, “c”:”STORAGE”, “id”:22435, “ctx”:”initandlisten”,”msg”:”WiredTiger error”,”attr”:{“error”:1,”message”:”[1617415132:32961][1:0x7ff53b81fac0], connection: __posix_open_file, 808: /data/db/WiredTiger.wt: handle-open: open: Operation not permitted”}}

{“t”:{“$date”:”2021-04-03T01:58:52.051+00:00″},”s”:”E”, “c”:”STORAGE”, “id”:22435, “ctx”:”initandlisten”,”msg”:”WiredTiger error”,”attr”:{“error”:17,”message”:”[1617415132:51173][1:0x7ff53b81fac0], connection: __posix_open_file, 808: /data/db/WiredTiger.wt: handle-open: open: File exists”}}

{“t”:{“$date”:”2021-04-03T01:58:52.055+00:00″},”s”:”I”, “c”:”STORAGE”, “id”:22430, “ctx”:”initandlisten”,”msg”:”WiredTiger message”,”attr”:{“message”:”unexpected file WiredTiger.wt found, renamed to WiredTiger.wt.65″}}

{“t”:{“$date”:”2021-04-03T01:58:52.068+00:00″},”s”:”E”, “c”:”STORAGE”, “id”:22435, “ctx”:”initandlisten”,”msg”:”WiredTiger error”,”attr”:{“error”:1,”message”:”[1617415132:68127][1:0x7ff53b81fac0], connection: __posix_open_file, 808: /data/db/WiredTiger.wt: handle-open: open: Operation not permitted”}}

{“t”:{“$date”:”2021-04-03T01:58:52.076+00:00″},”s”:”W”, “c”:”STORAGE”, “id”:22347, “ctx”:”initandlisten”,”msg”:”Failed to start up WiredTiger under any compatibility version. This may be due to an unsupported upgrade or downgrade.”}

{“t”:{“$date”:”2021-04-03T01:58:52.076+00:00″},”s”:”F”, “c”:”STORAGE”, “id”:28595, “ctx”:”initandlisten”,”msg”:”Terminating.”,”attr”:{“reason”:”1: Operation not permitted”}}

{“t”:{“$date”:”2021-04-03T01:58:52.076+00:00″},”s”:”F”, “c”:”-“, “id”:23091, “ctx”:”initandlisten”,”msg”:”Fatal assertion”,”attr”:{“msgid”:28595,”file”:”src/mongo/db/storage/wiredtiger/wiredtiger_kv_engine.cpp”,”line”:1123}}

{“t”:{“$date”:”2021-04-03T01:58:52.077+00:00″},”s”:”F”, “c”:”-“, “id”:23092, “ctx”:”initandlisten”,”msg”:”\n\n***aborting after fassert() failure\n\n”}

a
allesong says: 回复

php 安装phalcon 7版本 跟56版本的都安装不成功过 问题跟 https://github.com/yeszao/dnmp/issues/416 一致。但是上面这边没有说明是啥原因,不知道能不能帮忙解答下?

嘟嘟胖胖啊 says: 回复

你好,麻烦问下 如何安装项目里不存在的PHP版本呢??

a
aiden says: 回复

请问如何切换mysql的版本呢?默认的mysql 版本是8.0如何切换到别的版本呢

代码骑士 says: 回复

五年前的文章了,对我还是有用,感谢博主。

t
think says: 回复

Mac怎么找不到下载git的目录在哪

G
GG Bond says: 回复

请问如何设置容器时间默认的TZ是Asia/Shanghai,但是时间比正常时间早8小时

蛋白质 says: 回复

大佬您好,请问DNMP能够实现通过修改nginx.conf使得容器内新增的nginx监听端口映射到宿主机中吗?还是一开始配置80和443之后,其他端口只能通过配置代理来访问呢?我折腾了一下午,只能手动更改容器目录下的`hostconfig.json` 和 `config.v2.json`配置吗

d
drip says: 回复

mac m1 执行docker-compose up
提示如下:
[+] Running 0/1
⠼ mysql5 Pulling 3.3s
no matching manifest for linux/arm64/v8 in the manifest list entries

请问该怎么解决?

h
honglin says: 回复

你好,安装不了mongodb扩展是什么原因?
failed to receive status: rpc error: code = Unavailable desc = error reading from server: EOF

回复 取消回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

昵称 *