12

构建的环境为: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 文件中的 imagebuild 方式,即由 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

  1. 修改 web 容器配置中的端口号,可将 8080 改为其他端口;

  2. 修改 database 容器配置中数据库用户名、密码一类的信息;

  3. 修改 database 的 ports。该配置用于建立远程连接,使得本地可以通过 3306 端口连接到宿主机,进而连接到这一 Docker 容器的 MySQL 服务。可按需要修改端口映射关系或注释该行;

./images/console/Dockerfile

需要修改 Git 身份信息。

创建容器

在克隆后的目录中执行:

docker-compose up --build -d

执行完毕后,使用 docker ps 可以发现有四个容器正在运行,包括:

  1. PHP 容器,包含 fpm 和一些 PHP 扩展;

  2. web 容器:Nginx 容器;

  3. MySQL 容器;

  4. console 容器:工具类容器,包括 Git,Composer 等;

目录功能

创建容器后,原目录下会有三个子目录:

apps

用于存放项目文件,该目录为 PHP 容器、Nginx 容器,以及工具类容器共享。

database

该目录为数据库目录,与 MySQL 的数据目录映射。

images

该目录包含镜像的 Dcokerfile 文件及配置目录,其中,config 子目录与服务类容器的对应配置文件目录形成映射。

删除容器

当不再使用时,可以使用以下命令删除容器。注意:数据卷不会随之删除。

docker-compose down

参考

  1. PHP配置文件详解php.ini - 博客园

  2. Nginx:fastcgi_param详解 - CSDN

  3. 为什么不需要在 Docker 容器中运行 sshd

  4. 再用五分钟利用docker升级搭建好php7.0.10服务环境(添加扩展mysql、gd、phalcon) - CSDN

  5. PHP开启opcache方法 - 博客园

  6. Git 的 .gitignore 配置 - 博客园

  7. Docker 教程 - 宁皓网


dailybird
1.1k 声望73 粉丝

I wanna.