LNMP Docker - 在国内快速构建LNMP容器环境
3分钟构建开发、测试、生产L(Alpine Linux ) + N(Nginx) + M(MariaDB) + P(PHP) Docker 容器应用环境,升级信息参考。
主要特性
- 基于PHP 7.1版本,构建干净、轻量级PHP依赖环境。
- 基于Alpine Linux 最小化Linux环境加速构建镜像。 使用 阿里巴巴开源镜像站 在国内3分钟完成整个镜像构建。
- 内置PHP Composer,支持PHP CLI/FPM两种运行模式。PHP CLI 适用于命令行、后台PHP服务。PHP FPM基于CLI基础镜像,独立安装FPM模块。Nginx容器与PHP-FPM采用Socket方式连接,提供PHP Web应用环境。
- 提供PHP CLI模式独立运行模式参考:
call-websockt
与php-superviosr
。call-websockt
是基于workman 的PHP Socket服务。php-supervior
实现基于Supervisor的队列服务。 - 可独立配置容器运行时环境参数,支持容器运行日志、数据与宿主机分离,方便调试与维护。
- 支持Nginx虚拟站点、SSL证书服务。配置参考Nginx中
cert
与conf.d
目录文件。 - 支持多个虚拟站点内部程序互通。
- 使用Docker Compose 编排容器,支持在开发、测试、生产环境中快速完成服务器搭建任务。
安装Docker与Docker Compose
本项目基于CentOS 7构建,安装Docker环境参考官网。国内环境,推荐使用阿里云Docker Hub加速器服务。
$ sudo mkdir -p /etc/docker
$ sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://muehonsf.mirror.aliyuncs.com"]
}
EOF
$ sudo systemctl daemon-reload
$ sudo systemctl restart docker
推荐Github官网安装Docker Compose。
$ curl -L https://github.com/docker/compose/releases/download/1.13.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
$ chmod +x /usr/local/bin/docker-compose
安装LNMP Docker
-
克隆Git仓库。需要提前安装好Git。
$ git clone https://github.com/bravist/lnmp-docker && cd lnmp-docker
-
配置.env环境参数,一般无需修改默认参数。配置
PHP_FPM_DOMAIN
支持Nginx容器虚拟主机互通,配置SUPERVISOR_DOMAIN
支持Supervisor容器项目互通。参考这里了解容器多个项目内部通信机制。
# 生成.env文件
$ cp .env.example .env
- [*] 配置定时任务容器环境参数。默认无定时任务,可以参考
php-crond/crontabs/default.example
开启定时任务。
$ cd php-crond/crontabs/
$ cp default.example default
-
[*] 配置Supervisor后台进程处理任务。默认无后台进程处理,参考
php-supervisor/supervisor/default.conf.example
配置多进程任务。$ cd php-supervisor/supervisor $ cp default.conf.example default.conf
-
配置Nginx虚拟站点。参考
nginx/conf.d
目录下配置,复制一份新的站点配置文件,修改域名与主机目录。$ cd nginx/conf.d $ cp default.conf a.com.conf $ vi a.com.conf server { listen 80; server_name a.com; root /usr/share/nginx/html/a.com; index index.html index.htm index.php; #access_log /var/log/nginx/log/host.access.log main; location / { try_files $uri $uri/ /index.php$is_args$query_string; } error_page 404 /404.html; # redirect server error pages to the static page /50x.html error_page 500 502 503 504 /50x.html; location = /50x.html { root /usr/share/nginx/html; } # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 location ~ \.php$ { fastcgi_split_path_info ^(.+\.php)(/.+)$; fastcgi_pass unix:/var/run/php-fpm.sock; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param SCRIPT_NAME $fastcgi_script_name; fastcgi_index index.php; include fastcgi_params; } location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ { expires 30d; } location ~ .*\.(js|css)?$ { expires 2h; } location ~ /.well-known { allow all; } location ~ /\. { deny all; } # deny access to .htaccess files, if Apache's document root # concurs with nginx's one # location ~ /\.ht { deny all; } }
要在本地主机上访问a.com,需要在hosts文件中添加域名指向。
-
使用Docker Compose 快速启动容器。
$ docker-compose build && docker-compose up -d
其他说明
项目源码通过tianon/true
镜像挂载了主机当前项目文件目录: www
,推荐在改目录下新建不同子目录,然后在Nginx配置虚拟站点指向到该目录。
项目提供一份在PHP CLI模式中运行PHP应用的参考call-websocket。可以运行Workman这样的WebSocket的应用。在安装的过程中,可以忽略在lnmp-call-websocket
容器错误。
在安装过程中,如遇到问题,可以直接提交ISSUE反馈问题。为减少疑惑,提供一下命令做帮助。
# 查看所有运行和者退出的容器
$ docker ps -a
# 删除停止的容器
$ docker rm -f contianer_name ...
# 快速停止与删除容器组
$ docker-compose down
# 删除本地docker镜像
$ docker rmi -f image_name ....
# 清除所有已经停止运行的容器
$ docker container prune
所有的容器基于Alpine Linux ,默认使用sh
shell,进入容器时使用该命令:docker exec -it container_name sh
$ docker exec -it lnmp-nginx sh
安装 ctop 工具可以帮助查看容器在主机的使用情况。
$ ctop
ctop - 15:36:35 CST 10 containers
NAME CID CPU MEM NET RX/TX IO R/W PIDS
◉ lnmp-mariadb bd3cecff945e 0% 179M / 7.64G 90K / 276K 27M / 0B 0
◉ lnmp-nginx f4452c868dcc 0% 8M / 7.64G 14M / 5M 5M / 0B 0
◉ lnmp-php-fpm a68c55c28995 0% 72M / 7.64G 1M / 13M 20M / 0B 0
◉ lnmp-php-supervisor 15182399966b 1% 1.8G / 7.64G 92M / 145M 26M / 0B 0
◉ lnmp-redis 279b2f995b2a 0% 8M / 7.64G 62M / 16M 2M / 0B 0
◉ lnmp-www 09c684094c18 - - - - -