DNMP(Docker + Nginx + MySQL + PHP7/5 + Redis)是一款全功能的LNMP一键安装程序。
QQ群: 572041090 (请备注dnmp交流)
DNMP项目特点:
100%
开源100%
遵循Docker标准- 支持多版本PHP共存,可任意切换(~~PHP5.4、~~PHP5.6、PHP7.2)
- 支持绑定任意多个域名
- 支持HTTPS和HTTP/2
- PHP源代码、MySQL数据、配置文件、日志文件都可在Host中直接修改查看
- 内置完整PHP扩展安装命令
- 默认支持
pdo_mysql
、redis
、xdebug
、swoole
等常用热门扩展,根据环境灵活配置 - 带有phpmyadmin和phpredisadmin数据库在线管理程序
- 实际项目中应用,确保
100%
可用 - 一次配置,Windows、Linux、MacOs皆可用
/
├── conf 配置文件目录
│ ├── conf.d Nginx用户站点配置目录
│ ├── nginx.conf Nginx默认配置文件
│ ├── mysql.cnf MySQL用户配置文件
│ ├── php-fpm.conf PHP-FPM配置文件(部分会覆盖php.ini配置)
│ └── php.ini PHP默认配置文件
├── Dockerfile PHP镜像构建文件
├── extensions PHP扩展源码包
├── log 日志目录
├── mysql MySQL数据目录
├── docker-compose-sample.yml Docker 服务配置示例文件
├── env.smaple 环境配置示例文件
└── www PHP代码目录
结构示意图:
-
本地安装
git
、docker
和docker-compose
(需要1.7.0及以上版本)。 -
clone
项目:$ git clone https://github.com/yeszao/dnmp.git
-
如果不是
root
用户,还需将当前用户加入docker
用户组:$ sudo gpasswd -a ${USER} docker
-
拷贝并命名配置文件(Windows系统请用copy命令),启动:
$ cd dnmp $ cp env.sample .env $ cp docker-compose-simple.yml docker-compose.yml $ docker-compose up
这里我们使用 docker-compose-simple.yml 文件内的服务,是简单版本,只包含Nginx、PHP7.2和MySQL8
3
个服务。如需更多服务,比如Redis、PHP5.6、MongoDB,ElasticSearch等,请参考 docker-compose-full.yml 文件内的服务列表,把需要的拷贝到 docker-compose.yml 文件在up
即可。注意:Windows安装360安全卫士的同学,请先将其退出,不然安装过程中可能Docker创建账号过程可能被拦截,导致启动时文件共享失败。
-
访问在浏览器中访问:
http://localhost
,PHP代码:./www/localhost/index.php
文件。 -
如需管理服务,请在命令后面加上服务器名称,dnmp支持的服务名有:
nginx
、php72
、php56
、mysql
、mongo
、redis
、phpmyadmin
、phpredisadmin
、elasticsearch
、adminmongo
、rabbitmq
、kibana
$ docker-compose up # 创建并且启动所有容器
$ docker-compose up 服务1 服务2 ... # 创建并且启动指定的多个容器
$ docker-compose up -d 服务1 服务2 ... # 创建并且已后台运行的方式启动多个容器
$ docker-compose start 服务1 服务2 ... # 启动服务
$ docker-compose stop 服务1 服务2 ... # 停止服务
$ docker-compose restart 服务1 服务2 ... # 重启服务
$ docker-compose build 服务1 服务2 ... # 构建或者重新构建服务
$ docker-compose rm 服务1 服务2 ... # 删除并且停止容器
$ docker-compose down 服务1 服务2 ... # 停止并删除容器,网络,图像和挂载卷
默认情况下,我们同时创建 PHP5.6和PHP7.2 2个PHP版本的容器,
切换PHP仅需修改相应站点 Nginx 配置的fastcgi_pass
选项,
例如,示例的 http://localhost 用的是PHP7.2,Nginx 配置:
fastcgi_pass php72:9000;
要改用PHP5.6,修改为:
fastcgi_pass php56:9000;
再 重启 Nginx 生效。
$ docker exec -it dnmp_nginx_1 nginx -s reload
PHP的很多功能都是通过扩展实现,而安装扩展是一个略费时间的过程,
所以,除PHP内置扩展外,在env.sample
文件中我们仅默认安装少量扩展,
如果要安装更多扩展,请打开你的.env
文件修改如下的PHP配置,
增加需要的PHP扩展:
PHP72_EXTENSIONS=pdo_mysql,opcache,redis # PHP 7.2要安装的扩展列表,英文逗号隔开
PHP56_EXTENSIONS=opcache,redis # PHP 5.6要安装的扩展列表,英文逗号隔开
然后重新build PHP镜像。
bash docker-compose build php72 docker-compose up -d
可用的扩展请看同文件的PHP extensions
注释块说明。
- 打开主机的
~/.bashrc
或者~/.zshrc
文件,加上:
php () {
tty=
tty -s && tty=--tty
docker run \
$tty \
--interactive \
--rm \
--volume $PWD:/var/www/html:rw \
--workdir /var/www/html \
dnmp_php72 php "$@"
}
- 让文件起效:
source ~/.bashrc
- 然后就可以在主机中执行php命令了:
~ php -v
PHP 7.2.13 (cli) (built: Dec 21 2018 02:22:47) ( NTS )
Copyright (c) 1997-2018 The PHP Group
Zend Engine v3.2.0, Copyright (c) 1998-2018 Zend Technologies
with Zend OPcache v7.2.13, Copyright (c) 1999-2018, by Zend Technologies
with Xdebug v2.6.1, Copyright (c) 2002-2018, by Derick Rethans
在开发的时候,我们可能经常使用docker exec -it
切换到容器中,把常用的做成命令别名是个省事的方法。
打开~/.bashrc,加上:
alias dnginx='docker exec -it dnmp_nginx_1 /bin/sh'
alias dphp72='docker exec -it dnmp_php72_1 /bin/sh'
alias dphp56='docker exec -it dnmp_php56_1 /bin/sh'
alias dmysql='docker exec -it dnmp_mysql_1 /bin/bash'
alias dredis='docker exec -it dnmp_redis_1 /bin/sh'
Log文件生成的位置依赖于conf下各log配置的值。
Nginx日志是我们用得最多的日志,所以我们单独放在根目录log
下。
log
会目录映射Nginx容器的/var/log/nginx
目录,所以在Nginx配置文件中,需要输出log的位置,我们需要配置到/var/log/nginx
目录,如:
error_log /var/log/nginx/nginx.localhost.error.log warn;
大部分情况下,PHP-FPM的日志都会输出到Nginx的日志中,所以不需要额外配置。
另外,建议直接在PHP中打开错误日志:
error_reporting(E_ALL);
ini_set('error_reporting', 'on');
ini_set('display_errors', 'on');
如果确实需要,可按一下步骤开启(在容器中)。
- 进入容器,创建日志文件并修改权限:
$ docker exec -it dnmp_php_1 /bin/bash $ mkdir /var/log/php $ cd /var/log/php $ touch php-fpm.error.log $ chmod a+w php-fpm.error.log
- 主机上打开并修改PHP-FPM的配置文件
conf/php-fpm.conf
,找到如下一行,删除注释,并改值为:php_admin_value[error_log] = /var/log/php/php-fpm.error.log
- 重启PHP-FPM容器。
因为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中的日志文件的配置。
我们建议在主机HOST中使用composer,避免PHP容器变得庞大。
- 在主机创建一个目录,用以保存composer的配置和缓存文件:
mkdir ~/dnmp/composer
- 打开主机的
~/.bashrc
或者~/.zshrc
文件,加上:composer () { tty= tty -s && tty=--tty docker run \ $tty \ --interactive \ --rm \ --user $(id -u):$(id -g) \ --volume ~/dnmp/composer:/tmp \ --volume /etc/passwd:/etc/passwd:ro \ --volume /etc/group:/etc/group:ro \ --volume $(pwd):/app \ composer "$@" }
- 让文件起效:
source ~/.bashrc
- 在主机的任何目录下就能用composer了:
cd ~/dnmp/www/ composer create-project yeszao/fastphp project --no-dev
- (可选)如果提示需要依赖,用
--ignore-platform-reqs --no-scripts
关闭依赖检测。 - (可选)第一次使用 composer 会在 ~/dnmp/composer 目录下生成一个config.json文件,可以在这个文件中指定国内仓库,例如:
{ "config": {}, "repositories": { "packagist": { "type": "composer", "url": "https://packagist.laravel-china.org" } } }
本项目默认在docker-compose.yml
中开启了用于MySQL在线管理的phpMyAdmin,以及用于redis在线管理的phpRedisAdmin,可以根据需要修改或删除。
phpMyAdmin容器映射到主机的端口地址是:8080
,所以主机上访问phpMyAdmin的地址是:
http://localhost:8080
MySQL连接信息:
- host:(本项目的MySQL容器网络)
- port:
3306
- username:(手动在phpmyadmin界面输入)
- password:(手动在phpmyadmin界面输入)
phpRedisAdmin容器映射到主机的端口地址是:8081
,所以主机上访问phpMyAdmin的地址是:
http://localhost:8081
Redis连接信息如下:
- host: (本项目的Redis容器网络)
- port:
6379
要在正式环境中使用,请:
- 在php.ini中关闭XDebug调试
- 增强MySQL数据库访问的安全策略
- 增强redis访问的安全策略
参考这个issue:yeszao#91
容器时间在.env文件中配置TZ
变量,所有支持的时区请看时区列表·维基百科或者PHP所支持的时区列表·PHP官网。
mysql8.0采用了default_authentication_plugin=mysql_native_password加密方式,8.0以前版本是用caching_sha2_password,所以如果用5.7版本的,切换到conf目录, 修改mysql.conf配置文件
[mysqld]
default_authentication_plugin=mysql_native_password
然后在 mysql 下执行以下命令来修改密码:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密码';
MIT