配置簡單的 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
./images/console/Dockerfile
需要修改 Git 身份信息。
創建容器
在克隆后的目錄中執行:
docker-compose up --build -d
執行完畢后,使用 docker ps
可以發現有四個容器正在運行,包括:
目錄功能
創建容器后,原目錄下會有三個子目錄:
apps
用于存放項目文件,該目錄為 PHP 容器、Nginx 容器,以及工具類容器共享。
database
該目錄為數據庫目錄,與 MySQL 的數據目錄映射。
images
該目錄包含鏡像的 Dcokerfile 文件及配置目錄,其中,config 子目錄與服務類容器的對應配置文件目錄形成映射。
刪除容器
當不再使用時,可以使用以下命令刪除容器。注意:數據卷不會隨之刪除。
docker-compose down
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。
新聞熱點
疑難解答
圖片精選