Skip to content

Latest commit

 

History

History
131 lines (111 loc) · 6.21 KB

README.md

File metadata and controls

131 lines (111 loc) · 6.21 KB

集成了多个服务,目前有nginx、php、mysql、mongodb、redis、rabbitmq、phpredisadmin、supervisord(安装在php容器中)。如果你想支持更多的服务,可以参考原有的服务目录结构、env.sample配置、docker-compose-sample.yml配置

目录

1.目录结构

/
├── mongodb                             Mongodb
│   └── Dockerfile                      Mongodb构建文件
├── Mysql                               Mysql目录
│   ├── conf                            Mysql配置文件目录
│   │    └── mysql.cnf                  mysql配置文件
│   └── Dockerfile                      Mysql构建文件
├── nginx                               Nginx
│   ├── conf                            Mysql配置文件目录
│   │    ├── conf.d                     Nginx站点ssh秘钥目录
│   │    ├── vhost                      Nginx虚拟站点配置目录
│   │    └── nginx.conf                 Nginx默认配置文件
│   └── Dockerfile                      Nginx构建文件
├── PHP                                 PHP
│   ├── conf                            PHP配置文件目录
│   │    ├── supervisord.d              supervisord配置目录
│   │    ├── php.ini                    PHP配置文件
│   │    └── php-fpm.conf               php-fpm配置文件
│   ├── extensions                      PHP扩展目录(为了快速构建可以先下载好一些扩展)
│   ├── sh                              构建中运行脚本目录
│   └── Dockerfile                      PHP构建文件
├── phpredisadmin                       redis界面管理
│   └── Dockerfile                      phpredisadmin构建文件
├── rebbitmq                            rebbitmq
│   └── Dockerfile                      rebbitmq构建文件
├── redis                               redis
│   └── Dockerfile                      redis构建文件
├── docker-compose-sample.yml           Docker-compose配置示例文件
├── env.smaple                          环境配置示例文件
└── README.MD                           文档说明

2.使用

  1. 本地安装gitdockerdocker-compose
  2. clone项目
  3. 拷贝并命名配置文件,启动:
    $ cd dnmp
    $ cp env.sample .env
    $ cp docker-compose-sample.yml docker-compose.yml
    $ docker-compose up
    
  4. 访问在浏览器中访问:
  • http://localhost: 默认http站点
  • https://localhost:自定义证书https站点,访问时浏览器会有安全提示,忽略提示访问即可 两个站点使用同一PHP代码:./www/localhost/index.php

要修改端口、日志文件位置、php代码目录位置、php扩展、php镜像版本等,请修改**.env**文件,然后重新构建:

$ docker-compose build php72    # 重建单个服务
$ docker-compose build          # 重建全部服务

3.PHP扩展

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注释块说明。

4.添加快捷命令

在开发的时候,我们可能经常使用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'

其它的服务一样,自行设置

5.配置文件说明

主要说明几个全局变量:
// php项目代码存放路径,一般映射在宿主机/app目录下
CODE_PATH=/app/www
// 各个服务软件的数据备份,比如mysql、redis等等,防止容器挂后数据不见的问题
DATA_PATH=/app/data
// 各个服务的配置,放在当前目录下每个服务目录的conf目录中
CONF_PATH=./
// 各个服务的log
LOG_PATH=/app/log

php项目代码、各服务的数据备份、各服务的日志都统一放在放在宿主机/app目录下,方便统一管理。 你也可以把配置也放到这个/app目录下,如果放到/app目录下,需要你提前把所有的服务目录下的conf目录中的所有文件都要复制到/app/conf/xxx服务名。

例如:mysql的配置复制到/app目录下,则为/app/conf/mysql/服务目录下的conf的所有目录文件。然后修改配置文件CONF_PATH=/app/conf

6.PHP镜像选择

PHP镜像支持多个版本,可以查看:https://github.com/docker-library/repo-info/tree/master/repos/php/remote

如果你用swoole不需要php-fpm的话,可以使用7.2-cli-alpine,如果需要php-fpm则用7.2-fpm-alpine。

7.存在问题

1:目前在/php/Dockerfile文件中,无法使用$(nproc),使用会报错,无法拿到cpu的数目

2:supervisord脚本安装时,启动无效果,需要进入容器启动才行

3:如果mysql启动不成功,查看容器报错为:[ERROR] Could not open file '/var/log/mysql/mysql.error.log' for error logging: Permission denied 则需要你删除映射的/app/log/mysql目录,然后重新开启容器

4:swoole扩展偶尔安装不上去,是因为可能文件损坏,请到https://github.com/swoole/swoole-src/releases 下载对应的版本