佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 詳解Django+Vue+Docker搭建接口測試平臺實(shí)戰(zhàn)

詳解Django+Vue+Docker搭建接口測試平臺實(shí)戰(zhàn)

熱門標(biāo)簽:網(wǎng)站建設(shè) 硅谷的囚徒呼叫中心 智能手機(jī) 阿里云 百度競價點(diǎn)擊價格的計(jì)算公式 美圖手機(jī) 使用U盤裝系統(tǒng) 檢查注冊表項(xiàng)

一. 開頭說兩句

大家好,我叫林宗霖,是一位測試工程師,也是全棧測開訓(xùn)練營中的一名學(xué)員。

在跟著訓(xùn)練營學(xué)習(xí)完Docker容器技術(shù)系列的課程后,理所應(yīng)當(dāng)需要通過實(shí)操來進(jìn)行熟悉鞏固。正好接口自動化測試平臺需要遷移到新的測試服務(wù)器上,就想要體驗(yàn)一番Docker的“一次構(gòu)建,處處運(yùn)行”。這篇文章簡單介紹了下這次部署的過程,其中使用了Dockerfile定制鏡像和Docker-Compose多容器編排。

二. 項(xiàng)目介紹

項(xiàng)目采用的是前后端分離技術(shù)來實(shí)現(xiàn)的,前端是Vue+ElementUI,后端是Django+DRF,數(shù)據(jù)庫是MySQL,當(dāng)前部署版本沒有其他中間件。

2.1 安裝docker和docker-compose

下述所有操作,皆在Centos 7環(huán)境下進(jìn)行

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服務(wù)

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的權(quán)限

sudo chmod +x /usr/local/bin/docker-compose

2.2 Dockerfile定制python容器

首先把需要部署的django項(xiàng)目代碼放到特定目錄下(這里是/data/test_object

把django項(xiàng)目依賴包文件requirements.txt也放在該目錄下

創(chuàng)建Dockerfile文件:vim Dockerfile

Dockerfile內(nèi)容:(注意:注釋別跟在語句后面,有些語句執(zhí)行時會因此出現(xiàn)問題):

# 基礎(chǔ)鏡像
FROM python:3.6.8

# 把輸出及時重定向到文件,替代python -u
ENV PYTHONUNBUFFERED 1

# 創(chuàng)建目錄并切換工作目錄
RUN mkdir /code && mkdir /code/db
WORKDIR /code

# 添加文件
ADD ./requirements.txt /code/

# 執(zhí)行命令
RUN pip install -r requirements.txt

# 添加文件
ADD . /code/

2.3 編寫Docker Compose容器編

排同樣的目錄,創(chuàng)建docker-compose.yml文件:vim docker-compose.yml,內(nèi)容(編排Python容器和Mysql容器)

# docker compose版本
version: "3.9"

# 服務(wù)信息
services:

  # mysql容器,名字自定義
  db:
    image: mysql:5.7
    expose:
      - "3306"
    volumes:
      - ./db:/var/lib/mysql
    #設(shè)置數(shù)據(jù)庫表的數(shù)據(jù)集
    command: [
      '--character-set-server=utf8',
      '--collation-server=utf8_unicode_ci'
      ]
    environment:
      - MYSQL_DATABASE=xxxx
      - MYSQL_ROOT_PASSWORD=yyyy
    restart: always


  # django服務(wù)
  web:
    # 基于本路徑的Dockerfile創(chuàng)建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"
    # 當(dāng)前服務(wù)所依賴的服務(wù),會先啟動依賴服務(wù)再啟動當(dāng)前服務(wù)
    depends_on:
      - db
    # 容器ip是可變的,替代配置文件中mysql的HOST的值;名字和上面的mysql容器服務(wù)的名字一致
    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項(xiàng)目setting.py文件中的mysql的host,改成上面web節(jié)點(diǎn)中l(wèi)inks的值

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'xxxx',
        'USER': 'root',
        'PASSWORD': 'yyyy',
        'HOST': 'db',  # 這里進(jìn)行修改
        'PORT': 3306
    }
}

執(zhí)行命令

所在路徑:和Dockerfile等文件同個路徑下
構(gòu)建容器:docker-compose build
運(yùn)行容器:docker-compose up 或者 后臺運(yùn)行容器:docker-compose up -d

2.4 Vue項(xiàng)目的搭建

vue使用傳統(tǒng)的搭建方式即可:

服務(wù)器配置node npm環(huán)境

安裝全局pm2

修改項(xiàng)目中api的host為服務(wù)器的ip或域名

打包vue項(xiàng)目:npm run build編寫個app.js啟動腳本,主要目的是是讀取dist目錄下的單頁面文件(index.js),監(jiān)聽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),監(jiān)聽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復(fù)制到項(xiàng)目目錄下

進(jìn)入項(xiàng)目目錄,安裝依賴:npm install

啟動服務(wù):pm2 start app.js5、最終效果

運(yùn)行容器日志:

瀏覽器訪問http://ip:8080并登錄:

三、總結(jié)

這個項(xiàng)目組成目前還比較簡單,只用了2個容器進(jìn)行編排。但是以此為例,在搭建更多容器時,我們首先根據(jù)項(xiàng)目組成定制不同的容器,然后規(guī)劃好容器之間的是組織關(guān)系和依賴關(guān)系,相信也是能順利搭建起來的。

到此這篇關(guān)于詳解Django+Vue+Docker搭建接口測試平臺實(shí)戰(zhàn)的文章就介紹到這了,更多相關(guān)Django+Vue+Docker搭建接口測試 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

標(biāo)簽:湘潭 賀州 懷化 黃山 山南 煙臺 湖北 通遼

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解Django+Vue+Docker搭建接口測試平臺實(shí)戰(zhàn)》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    黄大仙区| 玉林市| 屏山县| 淮南市| 钟山县| 沾化县| 南陵县| 甘德县| 宾川县| 安乡县| 漳州市| 六枝特区| 射洪县| 黄山市| 宾川县| 运城市| 英德市| 太和县| 江油市| 林周县| 古交市| 凉城县| 阿拉善盟| 天长市| 彭泽县| 栖霞市| 鄄城县| 永登县| 宁远县| 丹阳市| 通河县| 彰武县| 尚义县| 青川县| 涡阳县| 元谋县| 宁国市| 成都市| 土默特左旗| 开阳县| 蓝田县|