使用docker搭建靈活的線上php環境 有時候你可能不太需要一些別人已經整合了的包或者映象
我們就可以使用以下方式自己動手逐一構建自己所需要的環境結構 並在最後實現一鍵自動化部署
一步一步點亮docker技能樹 github地址 github.com/ydtg1993/server
## ## ## ==
## ## ## ## ## ===
/"""""""""""""""""\___/ ===
~~~ {~~ ~~~~ ~~~ ~~~~ ~~~ ~ / ===- ~~~
\______ o __/
\ \ __/
\____\_______/
* 首先git拉取server專案 放到伺服器根目錄(到後面你也可以構建自己風格的環境結構)
1.下載映象
sudo docker pull php:7.2-fpm
冒號後選擇版本
sudo docker pull nginx
sudo docker pull mysql:5.7
8.0的密碼驗證經常出問題
sudo docker pull redis:3.2
sudo docker images
檢視已下載的所有映象
2.下載完成映象後執行容器 [以下采用–link方式建立容器 注意建立順序]
注:
-i 表示允許我們對容器進行操作
-t 表示在新容器內指定一個為終端
-d 表示容器在後臺執行
/bin/bash 這將在容器內啟動bash shell
-p 為容器和宿主機建立埠對映
--name 為容器指定一個名字
-v 將容器內路徑掛載到宿主機路徑
--privileged=true 給容器特權,在掛載目錄後容器可以訪問目錄以下的檔案或者目錄
--link可以用來連結2個容器,使得源容器(被連結的容器)和接收容器(主動去連結的容器)之間可以互相通訊,解除了容器之間通訊對容器IP的依賴
<執行mysql容器>
docker run --name mydb -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7
注:-MYSQL_ROOT_PASSWORD=123456 給mysql設定初始密碼
如果不需要搭建本地資料庫直接下一步
<執行redis容器>
docker run --name myredis -p 6379:6379 -d redis:3.2
注: 如果不需要搭建本地redis直接下一步
<執行php容器>
docker run -d -p 9000:9000 --name myphp -v /server/www:/var/www/html -v /server/php:/usr/local/etc/php --link mydb:mydb --link myredis:myredis --privileged=true php:7.2-fpm
注: 如果不需要搭建本地資料庫或者redis可以省去--link mydb:mydb --link myredis:myredis
注意-v 掛載一個空資料夾是會覆蓋容器中的內容,所以配置檔案要事先準備好
<執行nginx容器>
docker run --name mynginx -d -p 80:80 -v /server/www:/usr/share/nginx/html -v /server/nginx:/etc/nginx -v /server/logs/nginx.logs:/var/log/nginx --link myphp:myphp --privileged=true nginx
注:
-v語句冒號後是容器內的路徑 我將nginx的網頁專案目錄 配置目錄 日誌目錄分別掛載到了我事先準備好的/server目錄下
--link myphp:myphp 將nginx容器和php容器連線 通過別名myphp就不再需要去指定myphp容器的ip了
docker ps -a
檢視所有容器執行成功 這裡環境也就基本搭建完成了
掛載目錄後就可以不用進入容器中修改配置,直接在對應掛載目錄下改配置檔案 修改nginx配置到 /server/nginx/conf.d/Default.conf
3.PHP擴充套件庫安裝
docker exec -ti myphp /bin/bash
首先進入容器
docker-php-ext-install pdo pdo_mysql
安裝pdo_mysql擴充套件
docker-php-ext-install redis
注: 此時報錯提示redis.so 因為一些擴充套件並不包含在 PHP 原始碼檔案中
方法一:
tar zxvf /server/php_lib/redis-4.1.0.tgz
解壓已經下載好的redis擴充套件包
docker cp /server/php_lib/redis-4.1.0 myphp:/usr/src/php/ext/redis
將擴充套件放到容器中 再執行安裝
注:
直接將擴充套件包放到容器ext目錄裡可能會報錯Error: No such container:path: myphp:/usr/src/php/ext
你可以多開一個伺服器視窗 進入php容器中執行docker-php-ext-install redis此時報錯error: /usr/src/php/ext/redis does not exist
保持這個狀態然後在你的第一個伺服器視窗執行上條命令就成功了
(具體原因未知但確實要執行一次docker-php-ext-install命令 容器中才會開放/usr/src/php/ext這個目錄)
方法二:
注:
官方推薦使用 PECL(PHP 的擴充套件庫倉庫,通過 PEAR 打包)。用 pecl install 安裝擴充套件,然後再用官方提供的 docker-php-ext-enable
快捷指令碼來啟用擴充套件
pecl install redis && docker-php-ext-enable redis
pecl install xdebug && docker-php-ext-enable xdebug
docker restart myphp
裝完擴充套件 退出容器 重啟容器
*其它命令
docker stop $(docker ps -q)
停止所有容器
docker rm $(docker ps -aq)
刪除所有容器
docker rmi $(docker images -q)
刪除所有映象
docker inspect myphp
檢視容器配置資訊
*構築自己的目錄結構
你也可以構建自己所要的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的基本容器操作
docker-compose是編排容器的。例如,你有一個php映象,一個mysql映象,一個nginx映象。如果沒有docker-compose,
那麼每次啟動的時候,你需要敲各個容器的啟動引數,環境變數,容器命名,指定不同容器的連結引數等等一系列的操作,
相當繁瑣。而用了docker-composer之後,你就可以把這些命令一次性寫在docker-composer.yml檔案中,以後每次啟動
這一整個環境(含3個容器)的時候,你只要敲一個docker-composer up命令就ok了
1.安裝docker-compose
curl -L https://github.com/docker/compose/releases/download/1.8.1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
docker-compose --version
2.一鍵部署環境
/server/compose/docker-compose.yml已經配置好了 直接輸入命令即可
cd /server/compose
docker-compose up -d
對比上面執行容器命令來看docker_yml的配置結構和語義就一目瞭然了
用了docker-compose實現一鍵式操作 但問題是PHP的擴充套件庫還是得自己單獨裝 所以這裡需要用到Dockerfile來構建自定義容器映象
實現真正的一鍵完成
目錄:
server__| |__docker-compose.yml
|__compose.dockerfiles__|
|__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配置請記得刪除之前映象
cd /server/compose.dockerfiles
docker-compose up -d
以上就是docker所有的環境配置方式
本作品採用《CC 協議》,轉載必須註明作者和本文連結