构建的环境为:PHP 7.1.3 fpm & Nginx 1.11.10 & MySQL 5.7
对 Docker 不熟悉的读者可以参考之前撰文的一篇文章:Docker 快速上手
配置简单的 LNMP 环境
这里使用 docker-compose 的方式,配置内容如下:
docker-compose.yml
version: "2"
services:
# Nginx 1.11.10: https://hub.docker.com/_/nginx/
web:
image: nginx:1.11.10
ports:
# 将主机的 8080 端口映射到容器的 80 端口
- 8080:80
depends_on:
- php
# 同 php 一起共享 ./apps 目录
volumes_from:
- php
# 创建一个数据卷,由 ./images/nginx/config => /etc/nginx/conf.d
volumes:
- ./images/nginx/config:/etc/nginx/conf.d:ro
# PHP 7.1-fpm: https://hub.docker.com/_/php/
php:
image: php:7.1-fpm
volumes:
- ./apps:/mnt/apps
# MySQL 5.7: https://hub.docker.com/_/mysql/
database:
image: mysql:5.7
# 配置一些环境变量,具体的环境变量细节可以访问上面的网址查看
environment:
MYSQL_ROOT_PASSWORD: "root"
MYSQL_USER: "dailybird"
MYSQL_PASSWORD: "dailybirdo"
volumes:
- ./database:/var/lib/mysql
default.conf
在 docker-compose.yml
中,已将 Nginx 的配置目录 /etc/nginx/conf.d
映射到 ./images/nginx/config
目录中。根据 Nginx 的配置,处于该目录下所有 .conf
文件都会作为配置文件,因而我们可以新建一个 default.conf
进行配置。
server{
listen 80;
server_name localhost;
root /mnt/apps;
index index.php index.html index.htm;
location / {
index index.php index.html;
try_files $uri $uri/ /index.php?$query_string;
}
location ~ \.php$ {
# 这里使用 php 作为内部域名连接 php 容器
fastcgi_pass php:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}
创建容器
在 docker-compose.yml
所在目录下,执行以下指令,创建支撑 LNMP 服务的容器组:
docker-compose up -d
这之后,Docker 会创建一个 bridge
类型的网络并将这三个容器接入网络内。
此外,由于 docker-compose.yml
中的数据卷配置,在当前目录下,还会创建 database
目录用于映射数据库文件目录;创建 apps
目录用于存放 web 应用;创建 images/nginx/config
目录映射 Nginx 配置文件目录。
测试
在 docker-compose.yml
中,我们进行了 8080 => 80
的端口映射;此外,在 default.conf
中,Nginx 的请求被指向了容器的 /mnt/apps
目录,而该目录与主机的 ./apps
目录形成了映射,因而我们可以通过 localhost:8080
访问到 Nginx 容器的服务。当然,还要注意主机端口的占用情况,必要时可以在 docker-compose.yml
中将 8080 端口改为其他。
此时,我们只需要在 ./apps
目录下创建一个简单的 PHP 文件,如 test.php
,然后便可以通过 localhost:8080/test.php
访问了。
向 PHP 镜像中添加扩展
如果需要向 PHP 中添加扩展,则需要借助 Dockerfile,并按照官方镜像给出的方法,安装相应的扩展,详情可见 Docker – PHP7.1-fpm。如下,可在 PHP 镜像中添加 gd
pdo_mysql
zip
opcache
扩展。
# Dockerfile 文件
FROM php:7.1-fpm
MAINTAINER dailybird <dailybird@mail.com>
RUN apt-get update && apt-get install -y libpng12-dev libjpeg-dev \
&& rm -rf /var/lib/apt/lists/* \
&& docker-php-ext-configure gd --with-png-dir=/usr --with-jpeg-dir=/usr \
&& docker-php-ext-install gd pdo_mysql zip opcache
相应的,我们也需要将 docker-compose.yml
文件中的 image
改 build
方式,即由 Dockerfile
创建:
# ...
php:
# image: php:7.1-fpm
build:
# 指出 Dockerfile 所在的文件目录和文件名
context: ./images/php
dockerfile: Dockerfile
# ...
覆盖 PHP 配置
我们可以通过 Dockerfile
文件,将一部分配置文件拷贝到 /usr/local/etc/php/conf.d
中,从而在镜像启动时便可以覆盖对应的配置:
# Dockerfile 其他内容...
# 将对应的配置文件拷贝到容器中的 PHP 配置目录中,以覆盖原有的 PHP 配置
COPY ./config/php.ini /usr/local/etc/php/conf.d/
COPY ./config/opcache-recommended.ini /usr/local/etc/php/conf.d/
这两个配置文件的内容为:
php.ini
memory_limit = 512M
post_max_size = 1024M
upload_max_filesize = 1024M
更多配置项可见:http://php.net/manual/zh/ini….
opcache-recommended.ini
opcache.memory_consumption=128
opcache.interned_strings_buffer=8
opcache.max_accelerated_files=4000
opcache.revalidate_freq=60
opcache.fast_shutdown=4
opcache.enable_cli=1
有关 opcache 可以参考:http://www.cnblogs.com/HD/p/4…
此外,我们也可以添加一个数据卷将配置文件目录映射到主机上以便随时修改。
制作工具镜像
我们可以制作一个容器,用于安装 git
composer
等命令工具以便可以使用它们操作项目文件。这时,我们需要对以下文件进行修改:
docker-compose.yml
services:
# 其他...
# 用于 Git,Composer 等工具
console:
build:
context: ./images/console
dockerfile: Dockerfile
volumes_from:
- php
tty: true
由于继承了与 PHP 镜像相同的数据卷,这一工具容器也可以实现对 ./apps
项目文件目录的操作。
Dockerfile
接下来需要添加 Dockerfile
文件,该文件对应 docker-compose.yml
中的 build
,如下:
FROM php:7.1-fpm
MAINTAINER dailybird <dailybird@mail.com>
# 安装 git curl vim zip
RUN apt-get update && apt-get install -y git curl vim libfreetype6-dev \
&& rm -rf /var/lib/apt/list* \
&& pecl install zip \
&& docker-php-ext-enable zip
# 安装 composer
RUN curl -o composer.phar https://getcomposer.org/download/1.4.1/composer.phar \
&& chmod +x composer.phar
# 配置 composer ,将镜像源改为中国国内
RUN mv composer.phar /usr/local/bin/composer \
&& echo 'export PATH="$PATH:$HOME/.composer/vendor/bin"' >> ~/.bashrc \
&& . ~/.bashrc \
&& composer config -g repo.packagist composer https://packagist.phpcomposer.com
# 设置 Git 的身份
RUN git config --global user.name "username" \
&& git config --global user.email "user@mail.com"
注意按照实际情况修改 Git 信息。
快速构建 LNMP 环境
由于之前的 Dockerfile 中存在不少下载命令,使用 docker-compose up --build -d
时会因网速问题执行很长时间,所以我们可以将下载部分抽离出来,制作成新镜像后直接使用。这样一来,构建的过程就会非常迅速。
我已经在 Github 上创建了这样一个项目,其中那些需要大量下载的镜像都已制作并上传到镜像仓库,大家可以通过以下方式克隆:
git clone https://github.com/dailybird/docker-compose-lnmp.git
使用方式可以参考以下步骤。
自定义
在创建容器前,有一些内容需要按照实际情况进行修改:
docker-compose.yml
修改 web 容器配置中的端口号,可将
8080
改为其他端口;修改 database 容器配置中数据库用户名、密码一类的信息;
修改 database 的 ports。该配置用于建立远程连接,使得本地可以通过
3306
端口连接到宿主机,进而连接到这一 Docker 容器的 MySQL 服务。可按需要修改端口映射关系或注释该行;
./images/console/Dockerfile
需要修改 Git 身份信息。
创建容器
在克隆后的目录中执行:
docker-compose up --build -d
执行完毕后,使用 docker ps
可以发现有四个容器正在运行,包括:
PHP 容器,包含 fpm 和一些 PHP 扩展;
web 容器:Nginx 容器;
MySQL 容器;
console 容器:工具类容器,包括 Git,Composer 等;
目录功能
创建容器后,原目录下会有三个子目录:
apps
用于存放项目文件,该目录为 PHP 容器、Nginx 容器,以及工具类容器共享。
database
该目录为数据库目录,与 MySQL 的数据目录映射。
images
该目录包含镜像的 Dcokerfile 文件及配置目录,其中,config 子目录与服务类容器的对应配置文件目录形成映射。
删除容器
当不再使用时,可以使用以下命令删除容器。注意:数据卷不会随之删除。
docker-compose down