一. 開頭說兩句
大家好,我叫林宗霖,是一位測試工程師,也是全棧測開訓練營中的一名學員。
在跟著訓練營學習完Docker
容器技術系列的課程後,理所應當需要通過實操來進行熟悉鞏固。正好介面自動化測試平臺需要遷移到新的測試伺服器上,就想要體驗一番Docker
的“一次構建,處處執行”。這篇文章簡單介紹了下這次部署的過程,其中使用了Dockerfile
定製映象和Docker-Compose
多容器編排。
二. 專案介紹
專案採用的是前後端分離技術來實現的,前端是Vue+ElementUI
,後端是Django+DRF
,資料庫是MySQL
,當前部署版本沒有其他中介軟體。
2.1 安裝docker和docker-compose
下述所有操作,皆在
Centos 7
環境下進行
1.清理或解除安裝舊版本:
sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
2.更新yum庫
sudo yum install -y yum-utils
sudo yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo
3.安裝最新版本
sudo yum install docker-ce docker-ce-cli containerd.io
4.啟動Docker服務
sudo systemctl start docker
5.下載docker compose安裝包
採用curl安裝的方式比直接用pip安裝好處是不怕缺少某些依賴
sudo curl -L "https://github.com/docker/compose/releases/download/1.28.6/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
6.修改docker compose的許可權
sudo chmod +x /usr/local/bin/docker-compose
2.2 Dockerfile定製python容器
-
首先把需要部署的django專案程式碼放到特定目錄下(這裡是
/data/test_object
) -
把django專案依賴包檔案
requirements.txt
也放在該目錄下 -
建立Dockerfile檔案:
vim Dockerfile
-
Dockerfile內容:(注意:註釋別跟在語句後面,有些語句執行時會因此出現問題):
# 基礎映象
FROM python:3.6.8
# 把輸出及時重定向到檔案,替代python -u
ENV PYTHONUNBUFFERED 1
# 建立目錄並切換工作目錄
RUN mkdir /code && mkdir /code/db
WORKDIR /code
# 新增檔案
ADD ./requirements.txt /code/
# 執行命令
RUN pip install -r requirements.txt
# 新增檔案
ADD . /code/
2.3 編寫Docker Compose容器編排
- 同樣的目錄,建立docker-compose.yml檔案:
vim docker-compose.yml
,內容(編排Python容器和Mysql容器)
# docker compose版本
version: "3.9"
# 服務資訊
services:
# mysql容器,名字自定義
db:
image: mysql:5.7
expose:
- "3306"
volumes:
- ./db:/var/lib/mysql
#設定資料庫表的資料集
command: [
'--character-set-server=utf8',
'--collation-server=utf8_unicode_ci'
]
environment:
- MYSQL_DATABASE=xxxx
- MYSQL_ROOT_PASSWORD=yyyy
restart: always
# django服務
web:
# 基於本路徑的Dockerfile建立python容器
build: .
command: bash -c "python ./test_plat_form/manage.py migrate && python ./test_plat_form/manage.py runserver 0.0.0.0:8000"
volumes:
- .:/code
ports:
- "8000:8000"
expose:
- "8000"
# 當前服務所依賴的服務,會先啟動依賴服務再啟動當前服務
depends_on:
- db
# 容器ip是可變的,替代配置檔案中mysql的HOST的值;名字和上面的mysql容器服務的名字一致
links:
- db
volumes:
- ./files/suites:/code/test_plat_form/suites
- ./files/debugs:/code/test_plat_form/debugs
- ./files/reoprts:/code/test_plat_form/reports
- ./files/run_log:/code/test_plat_form/run_log
修改django專案setting.py檔案中的mysql的host,改成上面web節點中links的值
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'xxxx',
'USER': 'root',
'PASSWORD': 'yyyy',
'HOST': 'db', # 這裡進行修改
'PORT': 3306
}
}
執行命令
所在路徑:和Dockerfile等檔案同個路徑下
構建容器:docker-compose build
執行容器:docker-compose up
或者 後臺執行容器:docker-compose up -d
2.4 Vue專案的搭建
vue使用傳統的搭建方式即可:
- 伺服器配置node npm環境
- 安裝全域性pm2
- 修改專案中api的host為伺服器的ip或域名
- 打包vue專案:
npm run build
- 編寫個
app.js
啟動指令碼,主要目的是是讀取dist目錄下的單頁面檔案(index.js),監聽8080埠
const fs = require('fs');
const path = require('path');
const express = require('express');
const app = express();
app.use(express.static(path.resolve(__dirname, './dist')))
//讀取目錄下的單頁面檔案(index.js),監聽8080埠。
app.get('*', function(req, res) {
const html = fs.readFileSync(path.resolve(__dirname, './dist/index.html'), 'utf-8')
res.send(html)
})
app.listen(8080);
- 把打包好的dist目錄、app.js、package.json複製到專案目錄下
- 進入專案目錄,安裝依賴:
npm install
- 啟動服務:
pm2 start app.js
5、最終效果
執行容器日誌:
瀏覽器訪問http://ip:8080
並登入:
三、總結
這個專案組成目前還比較簡單,只用了2個容器進行編排。但是以此為例,在搭建更多容器時,我們首先根據專案組成定製不同的容器,然後規劃好容器之間的是組織關係和依賴關係,相信也是能順利搭建起來的。