本篇內(nèi)容介紹了“Docker+Jenkins+Gitlab+Django應(yīng)用部署的方法”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
萬州網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)公司!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項目制作,到程序開發(fā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)公司2013年開創(chuàng)至今到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運(yùn)維經(jīng)驗,來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)公司。
一、背景介紹
在互聯(lián)網(wǎng)應(yīng)用快速更新迭代的大背景下,傳統(tǒng)的人工手動或簡單腳本已經(jīng)不能適應(yīng)此變化,此時devops為我們提供了良好的解決方案,應(yīng)用好ci/cd可以大大的方便我們的日常工作,自動化快速的持續(xù)集成/持續(xù)交付為我們帶來了應(yīng)用開放的更快速度、更好的穩(wěn)定性和更強(qiáng)的可靠性。
二、拓?fù)洵h(huán)境
2.1 架構(gòu)拓?fù)?/strong>
如上圖實(shí)例,簡單花了下流程拓?fù)洌?/p>
當(dāng)研發(fā)push本地代碼到gitlab-server后,webhook自動觸發(fā)jenkins構(gòu)建應(yīng)用
在docker host上部署應(yīng)用git clone來自gitlabserver源碼,并啟動應(yīng)用
前端可以放置lb來做高可用
數(shù)據(jù)庫連接云數(shù)據(jù)庫
可將日志存儲在log后期投遞到elk實(shí)現(xiàn)日志可視化
構(gòu)建完成郵件通知相關(guān)人員(測試或開放)
2.2 系統(tǒng)軟件版本
名稱 | 版本 |
---|---|
linux系統(tǒng) | centos7.3 64位 |
docker | 1.13 |
django | 2.0 |
三、安裝部署
3.1 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)格的軟件項目
利用參數(shù)化構(gòu)建方便后續(xù)部署docker傳入映射的源端口和release
源代碼來自gitlab的django項目
利用webhook關(guān)聯(lián)gitlab和jenkins
jenkins安裝插件:
生成隨機(jī)token值
將jenkins生成的gitlab webhook url配置到gitlab
當(dāng)開發(fā)者在本地push代碼后自動觸發(fā)jenkins構(gòu)建項目,有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>項目名稱 : ${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>項目 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打包好了項目的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
“Docker+Jenkins+Gitlab+Django應(yīng)用部署的方法”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!
本文題目:Docker+Jenkins+Gitlab+Django應(yīng)用部署的方法
分享URL:http://aaarwkj.com/article14/pdesge.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、虛擬主機(jī)、軟件開發(fā)、定制網(wǎng)站、域名注冊
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)