详解使用 Docker 构建 LNMP 环境
配置简单的 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 <[email protected]> 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
此外,我们也可以添加一个数据卷将配置文件目录映射到主机上以便随时修改。
制作工具镜像
我们可以制作一个容器,用于安装 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 <[email protected]> # 安装 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 "[email protected]"
注意按照实际情况修改 Git 信息。
快速构建 LNMP 环境
由于之前的 Dockerfile 中存在不少下载命令,使用 docker-compose up --build -d
时会因网速问题执行很长时间,所以我们可以将下载部分抽离出来,制作成新镜像后直接使用。这样一来,构建的过程就会非常迅速。
我已经在 Github 上创建了这样一个项目,其中那些需要大量下载的镜像都已制作并上传到镜像仓库,大家可以通过以下方式克隆:
git clone [email protected]:dailybird/docker-compose-lnmp.git
使用方式可以参考以下步骤。
自定义
在创建容器前,有一些内容需要按照实际情况进行修改:
docker-compose.yml
- 修改 web 容器配置中的端口号,可将 8080 改为其他端口;
- 修改 database 容器配置中数据库用户名、密码一类的信息;
./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