bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

Docker+Jenkins+Gitlab+Django應用部署的方法

本篇內容介紹了“Docker+Jenkins+Gitlab+Django應用部署的方法”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

萬州網站制作公司哪家好,找創新互聯公司!從網頁設計、網站建設、微信開發、APP開發、響應式網站建設等網站項目制作,到程序開發,運營維護。創新互聯公司2013年開創至今到現在10年的時間,我們擁有了豐富的建站經驗和運維經驗,來保證我們的工作的順利進行。專注于網站建設就選創新互聯公司

一、背景介紹

在互聯網應用快速更新迭代的大背景下,傳統的人工手動或簡單腳本已經不能適應此變化,此時devops為我們提供了良好的解決方案,應用好ci/cd可以大大的方便我們的日常工作,自動化快速的持續集成/持續交付為我們帶來了應用開放的更快速度、更好的穩定性和更強的可靠性。

二、拓撲環境

2.1 架構拓撲

Docker+Jenkins+Gitlab+Django應用部署的方法

如上圖實例,簡單花了下流程拓撲:

  • 當研發push本地代碼到gitlab-server后,webhook自動觸發jenkins構建應用

  • 在docker host上部署應用git clone來自gitlabserver源碼,并啟動應用

  • 前端可以放置lb來做高可用

  • 數據庫連接云數據庫

  • 可將日志存儲在log后期投遞到elk實現日志可視化

  • 構建完成郵件通知相關人員(測試或開放)

 2.2 系統軟件版本


名稱版本
linux系統centos7.3 64位
docker1.13
django2.0

三、安裝部署

3.1 jenkins安裝部署

jenkins安裝部署可參考:

安裝完成后添加docker目標服務器

Docker+Jenkins+Gitlab+Django應用部署的方法

配置郵件發送服務器

Docker+Jenkins+Gitlab+Django應用部署的方法

3.2 docker安裝部署

docker安裝部署及dockerfile編寫可參考:容器docker詳解

3.3 gitlab安裝部署

gitlab安裝在公網linux服務器運行一些命令即可,如果沒有公網需要手動修改 /etc/gitlab/gitlab.rb 文件的 external_url 'http://自己的內網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
# 獲取公網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 配置發布流程

jenkins新建構建一個自由風格的軟件項目

Docker+Jenkins+Gitlab+Django應用部署的方法

利用參數化構建方便后續部署docker傳入映射的源端口和release

Docker+Jenkins+Gitlab+Django應用部署的方法

源代碼來自gitlab的django項目

Docker+Jenkins+Gitlab+Django應用部署的方法

利用webhook關聯gitlab和jenkins

jenkins安裝插件:

Docker+Jenkins+Gitlab+Django應用部署的方法

生成隨機token值

Docker+Jenkins+Gitlab+Django應用部署的方法

將jenkins生成的gitlab webhook url配置到gitlab

Docker+Jenkins+Gitlab+Django應用部署的方法

Docker+Jenkins+Gitlab+Django應用部署的方法

當開發者在本地push代碼后自動觸發jenkins構建項目,有dockerfile內寫的git pull代碼,再次不用將代碼由jenkins分發到docker宿主機,jenkins作為觸發docker構建使用

Docker+Jenkins+Gitlab+Django應用部署的方法

配置構建完成后的郵件

郵件模版,郵件類型選擇:

內容類型選擇:html

郵件主題填寫: 構建通知:${build_status} - ${project_name} - build # ${build_number} !

構建通知模版:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>${env, var="job_name"}-第${build_number}次構建日志</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>(本郵件是程序自動下發的,請勿回復!)</td>
 </tr>
 <tr>
  <td><h2>
   <font color="#0000ff">構建結果 - ${build_status}</font>
  </h2></td>
 </tr>
 <tr>
  <td><br />
  <b><font color="#0b610b">構建信息</font></b>
  <hr size="2" width="100%" align="center" /></td>
 </tr>
 <tr>
  <td>
  <ul>
   <li>項目名稱 : ${project_name}</li>
   <li>構建編號 : 第${build_number}次構建</li>
   <li>svn 版本: ${svn_revision}</li>
   <li>觸發原因: ${cause}</li>
   <li>構建日志: <a href="${build_url}console">${build_url}console</a></li>
   <li>構建 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">構建日志 (最后 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>

觸發類型可根據自身需要填寫,這里填寫always無論成功還是失敗都發送郵件

Docker+Jenkins+Gitlab+Django應用部署的方法 

查看遠程docker服務器內的文件

Docker+Jenkins+Gitlab+Django應用部署的方法

django部署已經利用conda打包好了項目的python3.6的環境包自制了docker鏡像

Docker+Jenkins+Gitlab+Django應用部署的方法

之前利用的是純凈的python3.6系統,在每次構建的時候利用pip安裝requirements.txt的模塊,但是長此以往由于環境變化很少,每次需要pip安裝耗時,所以利用conda將打包好的python環境自制成定制化環境,以此來減少環境部署時間,也可以通過docker鏡像制作是-v參數將本地磁盤掛載在環境內,每次構建本地的conda即可,完成快速環境部署。

查看dockerfile

from 87a69025db6a
maintainer kaliarch

# 定義docker中工作目錄
env work_dir /work/
# 創建docker內工作目錄
run mkdir $work_dir
# 定義映射端口

expose 80

workdir $work_dir 
run git clone http://123.xxxx.xxxxx.245/devops/go2cloud.git

# 添加啟動服務腳本
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

# 服務入口文件
#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}

# 啟動服務
#nohup ${py_cmd} -u ${main_app} runserver 0.0.0.0:80 >> ${log_dir}server-$(date +%f).log 2>&1 &
# 啟動腳本遷移調度腳本
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)

# 構建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參數將日志持續化存儲到docker 宿主機之上

四、測試展示

4.1 測試構建

手動構建測試

Docker+Jenkins+Gitlab+Django應用部署的方法 

4.2 查看log

Docker+Jenkins+Gitlab+Django應用部署的方法 

Docker+Jenkins+Gitlab+Django應用部署的方法 

Docker+Jenkins+Gitlab+Django應用部署的方法

4.3 查看docker容器

Docker+Jenkins+Gitlab+Django應用部署的方法

4.4 測試app

Docker+Jenkins+Gitlab+Django應用部署的方法

“Docker+Jenkins+Gitlab+Django應用部署的方法”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注創新互聯網站,小編將為大家輸出更多高質量的實用文章!

本文題目:Docker+Jenkins+Gitlab+Django應用部署的方法
分享URL:http://vcdvsql.cn/article14/pdesge.html

成都網站建設公司_創新互聯,為您提供外貿網站建設網站建設虛擬主機軟件開發定制網站域名注冊

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

h5響應式網站建設