地址: https://github.com/ydtg1993/server
使用docker搭建靈活的線上php環境 有時候你可能不太需要一些別人已經整合了的包或者映象
我們就可以使用以下方式自己動手逐一構建自己所需要的環境結構 並在最後實現一鍵自動化部署
一步一步點亮docker技能樹
## .
## ## ## ==
## ## ## ## ## ===
/"""""""""""""""""\___/ ===
~~~ {~~ ~~~~ ~~~ ~~~~ ~~~ ~ / ===- ~~~
\______ o __/
\ \ __/
\____\_______/
首先git pull專案 放到伺服器根目錄(到後面你也可以構建自己風格的環境結構)
階段一
使用docker逐一構建
1.下載映象
冒號後選擇版本
不需要本地資料庫可忽略
不需要本地redis可忽略
檢視已下載的所有映象
2.下載完成映象後執行容器 [以下采用–link方式建立容器 注意建立順序]
注:
-i 表示允許我們對容器進行操作
-t 表示在新容器內指定一個為終端
-d 表示容器在後臺執行
/bin/bash 這將在容器內啟動bash shell
-p 為容器和宿主機建立埠對映
--name 為容器指定一個名字
-v 將容器內路徑掛載到宿主機路徑
--privileged=true 給容器特權,在掛載目錄後容器可以訪問目錄以下的檔案或者目錄
--link可以用來連結2個容器,使得源容器(被連結的容器)和接收容器(主動去連結的容器)之間可以通過別名通訊,解除了容器之間通訊對容器IP的依賴
注:-MYSQL_ROOT_PASSWORD=123456 給mysql設定初始密碼
如果不需要搭建本地資料庫直接下一步
注: 如果不需要搭建本地redis直接下一步
注: 如果不需要搭建本地資料庫或者redis可以省去--link mydb:mydb --link myredis:myredis
注意-v 掛載一個空資料夾是會覆蓋容器中的內容,所以配置檔案要事先準備好
注:
-v語句冒號後是容器內的路徑 我將nginx的網頁專案目錄 配置目錄 日誌目錄分別掛載到了我事先準備好的/server目錄下
--link myphp:myphp 將nginx容器和php容器連線 通過別名myphp就不再需要去指定myphp容器的ip了
檢視所有容器執行成功 這裡環境也就基本搭建完成了
掛載目錄後就可以不用進入容器中修改配置,直接在對應掛載目錄下改配置檔案 修改nginx配置到 /server/nginx/conf.d/Default.conf
3.PHP擴充套件庫安裝
首先進入容器
安裝pdo_mysql擴充套件
安裝redis擴充套件
注: 此時報錯提示redis.so 因為一些擴充套件並不包含在 PHP 原始碼檔案中
方法一:
解壓已經下載好的redis擴充套件包
將擴充套件放到容器中 再執行安裝
方法二:
注:
官方推薦使用 PECL(PHP 的擴充套件庫倉庫,通過 PEAR 打包)。用 pecl install 安裝擴充套件,然後再用官方提供的 docker-php-ext-enable
快捷指令碼來啟用擴充套件
pecl安裝redis
裝完擴充套件 exit退出容器 重啟容器
*其它常用命令
停止所有容器
刪除所有容器
刪除所有映象
檢視容器配置資訊
*構築自己的目錄結構
你也可以構建自己所要的server目錄結構 首先要知道掛載一個空資料夾會清空容器中資料夾下所有內容 所以應該先拷貝再掛載
例如: 建立一個臨時容器 sudo docker run --name mynginx -p 80:80 -it -d nginx
進入到容器中查自己所要的配置檔案目錄地址 例如: /etc/nginx 退出容器
拷貝容器中所要的目錄結構到宿主機 例如: docker cp mydb:/etc/nginx /server/nginx
刪除容器 建立新容器時就可以掛載該目錄了 此後對nginx的配置檔案的修改就可以直接在宿主機上快捷操作
docker run --name mynginx -d -p 80:80 -v /server/nginx:/etc/nginx --link myphp:myphp --privileged=true nginx
階段二
docker-compose自動化構建
完成以上步驟你就已經初步瞭解了docker的基本容器操作
docker-compose是編排容器的。例如,你有一個php映象,一個mysql映象,一個nginx映象。如果沒有docker-compose,
那麼每次啟動的時候,你需要敲各個容器的啟動引數,環境變數,容器命名,指定不同容器的連結引數等等一系列的操作,
相當繁瑣。而用了docker-composer之後,你就可以把這些命令一次性寫在docker-composer.yml檔案中,以後每次啟動
這一整個環境(含3個容器)的時候,你只要敲一個docker-composer up命令就ok了
1.安裝docker-compose
檢視版本資訊
2.一鍵部署環境
/server/compose/docker-compose.yml已經配置好了 直接輸入命令即可
對比上面執行容器命令來看docker_yml的配置結構和語義就一目瞭然了
階段三
dokcer-compose和dockerfile 完整構建
用了docker-compose實現一鍵式操作 但問題是PHP的擴充套件庫還是得自己單獨裝 所以這裡需要用到Dockerfile來構建自定義容器映象
實現真正的一鍵完成
目錄:
server -|
-| compose.dockerfiles -| docker-compose.yml
-| mysql -| Dockerfile 這裡設定我們自定的dockerfile來構建mysql映象
|
-| nginx -| Dockerfile 這裡設定我們自定的dockerfile來構建nginx映象
|
-| php -| Dockerfile 這裡設定我們自定的dockerfile來構建php映象
|
-| redis -| Dockerfile 這裡設定我們自定的dockerfile來構建redis映象
自定義php的dockerfile構建自定義映象同時安裝擴充套件 完成了所有dockerfile配置後 docker-compose.yml檔案就不需要
再用官方映象image:php-fpm:7.2 而是直接build:./php 直接引用目錄配置好的Dockerfile
最後提示: 映象一旦建立了下次docker-compose會直接取已有映象而不會build建立 若你修改了Dockerfile配置請記得刪除之前映象
其他補充
*問題1
當你用docker-compose自動化部署後想要更換其中一個容器
假設場景 在自動部署環境後發現nginx容器沒有開啟443埠
1.查詢自動化部署的容器組環境所在網段
查詢所有網段命令
查詢nginx所在網段 找到HostConfig.NetworkMode下所對應值 例如:composedockerfiles_default
2.先刪除nginx容器
3.重啟一個新的nginx容器 並且橋接相同網段
在原來的基礎上-p加上新埠443 並且使用網段橋接 --net=composedockerfiles_default
*問題2
當你在宿主機上需要用cli模式執行php
本作品採用《CC 協議》,轉載必須註明作者和本文連結