DNMP(Docker + Nginx + MySQL + PHP7/5)是一款全功能的LNMP一键安装程序。
DNMP项目特点:
100%
开源100%
遵循Docker标准100%
可用目录说明:
/
├── conf 配置文件目录
│ ├── conf.d Nginx用户站点配置目录
│ ├── nginx.conf Nginx默认配置文件
│ ├── mysql.cnf MySQL用户配置文件
│ ├── php-fpm.conf PHP-FPM配置文件(部分会覆盖php.ini配置)
│ └── php.ini PHP默认配置文件
├── docker-compose54.yml PHP5.4 docker-compose项目文件
├── docker-compose56.yml PHP5.6 docker-compose项目文件
├── docker-compose.yml PHP最新版docker-compose项目文件
├── log Nginx日志目录
├── mysql MySQL数据目录
├── php PHP各版本的Dockerfile目录
└── www PHP代码目录
结构示意图:
git
、docker
和docker-compose
。clone
项目:
$ git clone https://github.com/yeszao/dnmp.git
root
用户,还需将当前用户加入docker
用户组:
$ sudo gpasswd -a ${USER} docker
$ cd dnmp
$ docker-compose up
localhost
,会看到类似如下的输出:这是项目的演示效果,PHP代码在这个目录:./www/site1/
。
默认情况下,我们启动的是最新版本的PHP,命令如下:
$ docker-compose up
在docker-compose stop
后,我们可以用下面的命令启动PHP5.4或PHP5.6:
$ docker-compose -f docker-compose54.yml up
$ docker-compose -f docker-compose56.yml up
如果该版本是第一次启动,那么还需要加上--build
参数构建,不然还是会启动最新版本:
$ docker-compose -f docker-compose54.yml up --build
$ docker-compose -f docker-compose56.yml up --build
在版本切换时,我们不需要修改任何配置文件,包括Nginx配置文件和php.ini等, 除非是代码兼容错误,否则切换版本后应该都能正常工作。
注意:因为所有PHP版本使用的是同一个端口配置,所以我们同时只能使用一个版本,要切换到另外一个版本,必须先停止原来的版本。
本项目的演示站点有两个:
要预览这两个站点,请在主机的hosts
文件中加上如下两行:
127.0.0.1 www.site1.com
127.0.0.1 www.site2.com
hosts
文件位置: /etc/hosts
hosts
文件位置: C:\Windows\System32\drivers\etc\hosts
然后通过浏览器这两个地址就能看到效果,其中:
Log文件生成的位置依赖于conf下各log配置的值。
Nginx日志是我们用得最多的日志,所以我们单独放在根目录log
下。
log
会目录映射Nginx容器的/var/log/dnmp
目录,所以在Nginx配置文件中,需要输出log的位置,我们需要配置到/var/log/dnmp
目录,如:
error_log /var/log/dnmp/nginx.site1.error.log warn;
大部分情况下,PHP-FPM的日志都会输出到Nginx的日志中,所以不需要额外配置。
如果确实需要,可按一下步骤开启。
$ touch log/php-fpm.error.log
$ chmod a+w log/php-fpm.error.log
conf/php-fpm.conf
,找到如下一行,删除注释,并改值为:
php_admin_value[error_log] = /var/log/dnmp/php-fpm.error.log
因为MySQL容器中的MySQL使用的是mysql
用户启动,它无法自行在/var/log
下的增加日志文件。所以,我们把MySQL的日志放在与data一样的目录,即项目的mysql
目录下,对应容器中的/var/lib/mysql/
目录。
slow-query-log-file = /var/lib/mysql/mysql.slow.log
log-error = /var/lib/mysql/mysql.error.log
以上是mysql.conf中的日志文件的配置。
dnmp默认已经在容器中安装了composer,使用时先进入容器:
$ docker exec -it dnmp_php_1 /bin/bash
然后进入相应目录,使用composer:
# cd /var/www/html/site1
# composer update
因为composer依赖于PHP,所以,是必须在容器里面操作composer的。
本项目默认在docker-compose.yml
中开启了用于MySQL在线管理的phpMyAdmin,以及用于redis在线管理的phpRedisAdmin,可以根据需要修改或删除。
phpMyAdmin容器映射到主机的端口地址是:8080
,所以主机上访问phpMyAdmin的地址是:
http://localhost:8080
MySQL连接信息:
3306
phpRedisAdmin容器映射到主机的端口地址是:8081
,所以主机上访问phpMyAdmin的地址是:
http://localhost:8081
Redis连接信息如下:
6379
默认情况下,我们已经安装了Xdebug扩展,但并未在php.ini中配置启用。
要使用xdebug调试,在php.ini文件最后加上这几行:
[XDebug]
xdebug.remote_enable = 1
xdebug.remote_handler = "dbgp"
xdebug.remote_host = "172.17.0.1"
xdebug.remote_port = 9000
xdebug.remote_log = "/var/log/dnmp/php.xdebug.log"
然后重启PHP容器。
说明:这个问题主要是受国内网络环境影响,现在PHP7以上的版本直接采用从源码安装扩展,所以这个问题已经没有了。
MIT
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。