名稱 | 版本 |
---|---|
Linux系統(tǒng) | CentOS7.3 64位 |
Docker | 1.13 |
Django | 2.0 |
三、安裝部署
3.1 Jenkins安裝部署
Jenkins安裝部署可參考:jenkins筆記
安裝完成后添加Docker目標(biāo)服務(wù)器
配置郵件發(fā)送服務(wù)器
3.2 Docker安裝部署
Docker安裝部署及Dockerfile編寫可參考:容器Docker詳解
3.3 Gitlab安裝部署
GitLab安裝在公網(wǎng)Linux服務(wù)器運(yùn)行一些命令即可,如果沒有公網(wǎng)需要手動修改 /etc/gitlab/gitlab.rb
文件的 external_url 'http://自己的內(nèi)網(wǎng)IP'
yum install -y libsemanage-static libsemanage-devel policycoreutils openss h-server openssh-clients postfix systemctl enable postfix && systemctl start postfix wget https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/gitlab-ce-8.0. 0-ce.0.el7.x86_64.rpm rpm -i gitlab-ce-8.0.0-ce.0.el7.x86_64.rpm # 獲取公網(wǎng)IP PUBLICIP=$(curl http://ipv4.icanhazip.com) # 修改 sed -i "s/gitlab-server/${PUBLICIP}/g" /etc/gitlab/gitlab.rb gitlab-ctl reconfigure gitlab-ctl restart echo "Username:root" echo "Password:5iveL!fe"
3.4 配置發(fā)布流程
Jenkins新建構(gòu)建一個自由風(fēng)格的軟件項(xiàng)目
利用參數(shù)化構(gòu)建方便后續(xù)部署Docker傳入映射的源端口和release
源代碼來自gitlab的django項(xiàng)目
利用webhook關(guān)聯(lián)gitlab和jenkins
jenkins安裝插件:
生成隨機(jī)token值
將jenkins生成的GitLab webhook URL配置到gitlab
當(dāng)開發(fā)者在本地push代碼后自動觸發(fā)jenkins構(gòu)建項(xiàng)目,有Dockerfile內(nèi)寫的git pull代碼,再次不用將代碼由jenkins分發(fā)到docker宿主機(jī),jenkins作為觸發(fā)docker構(gòu)建使用
配置構(gòu)建完成后的郵件
郵件模版,郵件類型選擇:
內(nèi)容類型選擇:HTML
郵件主題填寫: 構(gòu)建通知:${BUILD_STATUS} - ${PROJECT_NAME} - Build # ${BUILD_NUMBER} !
構(gòu)建通知模版:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>${ENV, var="JOB_NAME"}-第${BUILD_NUMBER}次構(gòu)建日志</title> </head> <body leftmargin="8" marginwidth="0" topmargin="8" marginheight="4" offset="0"> <table width="95%" cellpadding="0" cellspacing="0" style="font-size: 11pt; font-family: Tahoma, Arial, Helvetica, sans-serif"> <tr> <td>(本郵件是程序自動下發(fā)的,請勿回復(fù)!)</td> </tr> <tr> <td><h2> <font color="#0000FF">構(gòu)建結(jié)果 - ${BUILD_STATUS}</font> </h2></td> </tr> <tr> <td><br /> <b><font color="#0B610B">構(gòu)建信息</font></b> <hr size="2" width="100%" align="center" /></td> </tr> <tr> <td> <ul> <li>項(xiàng)目名稱 : ${PROJECT_NAME}</li> <li>構(gòu)建編號 : 第${BUILD_NUMBER}次構(gòu)建</li> <li>SVN 版本: ${SVN_REVISION}</li> <li>觸發(fā)原因: ${CAUSE}</li> <li>構(gòu)建日志: <a href="${BUILD_URL}console">${BUILD_URL}console</a></li> <li>構(gòu)建 Url : <a href="${BUILD_URL}">${BUILD_URL}</a></li> <li>工作目錄 : <a href="${PROJECT_URL}ws">${PROJECT_URL}ws</a></li> <li>項(xiàng)目 Url : <a href="${PROJECT_URL}">${PROJECT_URL}</a></li> </ul> </td> </tr> <tr> <td><b><font color="#0B610B">Changes Since Last Successful Build:</font></b> <hr size="2" width="100%" align="center" /></td> </tr> <tr> <td> <ul> <li>歷史變更記錄 : <a href="${PROJECT_URL}changes">${PROJECT_URL}changes</a></li> </ul> ${CHANGES_SINCE_LAST_SUCCESS,reverse=true, format="Changes for Build #%n:<br />%c<br />",showPaths=true,changesFormat="<pre>[%a]<br />%m</pre>",pathFormat=" %p"} </td> </tr> <tr> <td><b>Failed Test Results</b> <hr size="2" width="100%" align="center" /></td> </tr> <tr> <td><pre style="font-size: 11pt; font-family: Tahoma, Arial, Helvetica, sans-serif">$FAILED_TESTS</pre> <br /></td> </tr> <tr> <td><b><font color="#0B610B">構(gòu)建日志 (最后 100行):</font></b> <hr size="2" width="100%" align="center" /></td> </tr> <!-- <tr> <td>Test Logs (if test has ran): <a href="${PROJECT_URL}ws/TestResult/archive_logs/Log-Build-${BUILD_NUMBER}.zip">${PROJECT_URL}/ws/TestResult/archive_logs/Log-Build-${BUILD_NUMBER}.zip</a> <br /> <br /> </td> </tr> --> <tr> <td><textarea cols="80" rows="30" readonly="readonly" style="font-family: Courier New">${BUILD_LOG, maxLines=100}</textarea> </td> </tr> </table> </body> </html>
觸發(fā)類型可根據(jù)自身需要填寫,這里填寫always無論成功還是失敗都發(fā)送郵件
查看遠(yuǎn)程Docker服務(wù)器內(nèi)的文件
django部署已經(jīng)利用conda打包好了項(xiàng)目的Python3.6的環(huán)境包自制了Docker鏡像
之前利用的是純凈的Python3.6系統(tǒng),在每次構(gòu)建的時候利用pip安裝requirements.txt的模塊,但是長此以往由于環(huán)境變化很少,每次需要pip安裝耗時,所以利用conda將打包好的Python環(huán)境自制成定制化環(huán)境,以此來減少環(huán)境部署時間,也可以通過docker鏡像制作是-v參數(shù)將本地磁盤掛載在環(huán)境內(nèi),每次構(gòu)建本地的conda即可,完成快速環(huán)境部署。
查看Dockerfile
FROM 87a69025db6a MAINTAINER kaliarch # 定義docker中工作目錄 ENV WORK_DIR /work/ # 創(chuàng)建docker內(nèi)工作目錄 RUN mkdir $WORK_DIR # 定義映射端口 EXPOSE 80 WORKDIR $WORK_DIR RUN git clone http://123.xxxx.xxxxx.245/Devops/go2cloud.git # 添加啟動服務(wù)腳本 ADD *.sh ${WORK_DIR} CMD `which bash` /work/start_all.sh && tail -f /work/logs/server-$(date +%F).log
查看Django啟動腳本
#!/bin/bash BASEPATH=$(cd `dirname $0`;pwd) PY_CMD=/python3/bin/python # 服務(wù)入口文件 #MAIN_APP=${BASEPATH}/go2cloud/manage.py # 遷移腳本入口文件 SCRIPTS_APP=${BASEPATH}/go2cloud/scripts/migrate_task_schdule.py # 刪除腳本入口文件 DELETE_APP=${BASEPATH}/go2cloud/scripts/delete_transfer_server.py # 日志目錄 LOG_DIR=${BASEPATH}/logs/ [ ! -d ${LOG_DIR} ] && mkdir ${LOG_DIR} # 啟動服務(wù) #nohup ${PY_CMD} -u ${MAIN_APP} runserver 0.0.0.0:80 >> ${LOG_DIR}server-$(date +%F).log 2>&1 & # 啟動腳本遷移調(diào)度腳本 echo "---------$0 $(date) excute----------" >> ${LOG_DIR}task-script-$(date +%F).log nohup ${PY_CMD} -u ${SCRIPTS_APP} >> ${LOG_DIR}script-$(date +%F).log 2>&1 & # 啟動遷移刪除腳本 echo "---------$0 $(date) excute----------" >> ${LOG_DIR}delete-script-$(date +%F).log nohup ${PY_CMD} -u ${DELETE_APP} >> ${LOG_DIR}delete-script-$(date +%F).log 2>&1 &
查看jenkins部署腳本
#!/bin/bash release=$1 port=$2 BASEPATH=$(cd `dirname $0`;pwd) # 構(gòu)建go2cloud-platform 鏡像 cd /dockerwork docker build -t go2cloud-platform-mini:$release . IMGNAME=$(docker images|awk -v release=$release '{if($1=="go2cloud-platform-mini" && $2==release) print $3}') echo $IMGNAME # 啟動容器 docker run -d -p ${port}:80 -v /testlog/:/work/logs ${IMGNAME}
利用-v參數(shù)將日志持續(xù)化存儲到docker 宿主機(jī)之上
四、測試展示
4.1 測試構(gòu)建
手動構(gòu)建測試
4.2 查看log
4.3 查看docker容器
4.4 測試app
五、反思改進(jìn)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
標(biāo)簽:綏化 孝感 蕪湖 南充 福州 撫順 巴中 晉城
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解Docker+Jenkins+Gitlab+Django應(yīng)用部署實(shí)踐》,本文關(guān)鍵詞 詳解,Docker+Jenkins+Gitlab+Django,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。