首页 > 服务器 > Web服务器 > 正文

详解使用 Docker 构建 LNMP 环境

2024-09-01 13:51:13
字体:
来源:转载
供稿:网友

配置简单的 LNMP 环境

这里使用 docker-compose 的方式,配置内容如下:

docker-compose.ymlversion: "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-fpmMAINTAINER 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 = 512Mpost_max_size = 1024Mupload_max_filesize = 1024M

更多配置项可见:http://php.net/manual/zh/ini....

opcache-recommended.ini

opcache.memory_consumption=128opcache.interned_strings_buffer=8opcache.max_accelerated_files=4000opcache.revalidate_freq=60opcache.fast_shutdown=4opcache.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-fpmMAINTAINER dailybird <dailybird@mail.com># 安装 git curl vim zipRUN 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# 安装 composerRUN 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 git@github.com:dailybird/docker-compose-lnmp.git

使用方式可以参考以下步骤。

自定义

在创建容器前,有一些内容需要按照实际情况进行修改:

docker-compose.yml

  1. 修改 web 容器配置中的端口号,可将 8080 改为其他端口;
  2. 修改 database 容器配置中数据库用户名、密码一类的信息;

./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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持VEVB武林网。


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表