摘要:集群環(huán)境的部署方式使用集群管理工具通過版本新增文件實現(xiàn)滾動升級容器等同于應(yīng)用的部署
1. 思路&流程
Jenkins集成Docker鏡像實現(xiàn)自動發(fā)布與Jenkins發(fā)布mavne項目思路一樣總體流程 為:
Jenkins 拉去遠(yuǎn)端源碼 —— gitl
實現(xiàn)應(yīng)用打包 —— jenkins本地
把應(yīng)用程序打包進(jìn)Docker鏡像 —— Dockerfile
鏡像上傳到Docker私有倉庫 —— shell或者 Docker相關(guān)的Jekins插件
刪除老的Docker容器,運行新的Docker容器 —— shell腳本
2. 環(huán)境準(zhǔn)備
Jenkins java maven Docker git git-Jenkins插件
配置Jenkins
Git倉庫可以開啟鉤子功能實現(xiàn)push代碼后自動觸發(fā)Jenkins構(gòu)建功能,如需要可以在git倉庫中開啟此功能。
新建項目 選擇mavan風(fēng)格項目或者自由風(fēng)格項目(這里使用自由風(fēng)格)
3. 配置Jenkins構(gòu)建觸發(fā)器
說明1:觸發(fā)遠(yuǎn)程構(gòu)建 (例如,使用腳本) 這個選項就是上面提到配合git倉庫的鉤子功能實現(xiàn)代碼PUSH后Jenkins收到通知自動觸發(fā)構(gòu)建項目的動作 說明2:Poll SCM日程表 定時檢查源碼變更,如果有更新就克隆下最新code下來,然后執(zhí)行構(gòu)建動作
每5分鐘檢查一次該項目分支是否有變動,如果有就拉去最新code執(zhí)行構(gòu)建動作 注:構(gòu)建觸發(fā)器這里我們不做任何選擇,這里只是介紹這兩周功能,如有需要自行實現(xiàn)。
4. 構(gòu)建日志輸出
查看docker本地倉庫
鏡像已經(jīng)存在
容器已經(jīng)在運行了
項目中的Dockerfile
Git倉庫的項目當(dāng)中需要存放Dockerfie文件,用于打包應(yīng)用到鏡像里面
5. Dockerfile內(nèi)容如下:
為了避免構(gòu)建過程過多時間執(zhí)行過長,Dockerfile文件只做了一件事就是把Jenkins打包好的應(yīng)用文件添加進(jìn)容器里。其他所需的環(huán)境和操作都將在基礎(chǔ)鏡像上完成,提高構(gòu)建效率。
注:這里的 FROM java6是需要存在在Docker本地倉庫上的鏡像,如果不存在Jekins在執(zhí)行構(gòu)建過程中回去Docker Hub上拉取對應(yīng)鏡像,如果沒有則會報錯。
6.基礎(chǔ)鏡像 Dockerfile
Java6的鏡像是從這里由來,添加了tomcat以及JAVA環(huán)境變量 構(gòu)建Docker鏡像這里只做一下簡單說明
Jenkins構(gòu)建后操作
Jekins可以使用相關(guān)的Docker插件來實現(xiàn)此功能,但由于外網(wǎng)被墻安裝困難,這里采用Execute Shell方式實現(xiàn),也比較簡單易于后期維護(hù)。
imagesid=`docker images|grep -i docker-test|awk "{print $3}"` project=/root/.jenkins/workspace/Docker if ! -n "$imagesid";then echo $imagesid "is null" else docker rmi $imagesid -f fi cd $project docker build -t docker-test . if docker ps -a|grep -i docker;then docker rm -f docker fi docker run -it -d -p 8099:8080 --name docker docker-test
注:這里的殺掉老的容器和刪除舊的容器 grep的都是通過容器的名稱所匹配的,所以再啟動啟動容器的時候要指定容器名稱 –name,否則就是啟動失敗。
7. 頁面訪問驗證
我Docker鏡像里的應(yīng)用就是一個index頁面,容器訪問成功。
8. 擴(kuò)展
- 多節(jié)點升級
以上只是針對單節(jié)點本機(jī)Docker的打包部署方式,如需要多借點部署,不用多次編譯構(gòu)建,只需執(zhí)行一次構(gòu)建操作,把鏡像上傳到企業(yè)內(nèi)部私有倉庫,通過ansibles 實現(xiàn)多節(jié)點部署。
- Docker集群環(huán)境的部署方式
使用kubernets集群管理工具通過Deployment(1.2版本新增)文件實現(xiàn)滾動升級容器(等同于應(yīng)用的部署)
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/27968.html
摘要:對測試的影響讓單元測試運行的更順暢單元測試驅(qū)動開發(fā)是一個很好的應(yīng)用程序開發(fā)方式,單元測試往往也是和代碼一起被提交到代碼倉庫中。但是很多單元測試通常依賴于很多其他服務(wù),而這些服務(wù)的標(biāo)準(zhǔn)化配置往往是一個難點,如數(shù)據(jù)庫的搭建防火墻的配置等。 傳統(tǒng)的軟件開發(fā)、測試、運維需要三個團(tuán)隊在三個不同的環(huán)境中進(jìn)行,而三個環(huán)境的不同引發(fā)了很多的問題。如:工作內(nèi)容的重復(fù);開發(fā)環(huán)境中可運行的程序在測試和運維環(huán)...
摘要:而持續(xù)集成的意義就在于減少風(fēng)險,和重復(fù)的過程,最終提高工作效率。第二級調(diào)度由被稱作的組件組成。能和不同類型的通信,每種由相應(yīng)的應(yīng)用集群管理。這是的任務(wù)啟動過程。數(shù)人云運維平臺持續(xù)集成實踐這是數(shù)人云運維平臺的持續(xù)集成實踐。 今天小數(shù)給大家?guī)淼挠质鞘愕母韶洠寒?dāng)運維遇到云計算,當(dāng)Docker遇到Mesos和Jenkins,會擦出怎樣的火花呢?且看來自數(shù)人云運維工程師金燁的演講實錄分享——...
摘要:為了看起來清晰,我寫了一個文件,將這個文件和之前的放在同一個目錄中,可以用以下命令快速啟動,啟動之后新構(gòu)建的鏡像和容器都名為。 showImg(https://segmentfault.com/img/remote/1460000014924499?w=883&h=515); 在軟件開發(fā)過程中,如果我們每一次提交的代碼都能夠進(jìn)行一次完整的編譯、測試、打包、發(fā)布,就能及早發(fā)現(xiàn)問題、及早修...
摘要:而所謂的持續(xù),就是說每完成一個完整的部分,就向下個環(huán)節(jié)交付,發(fā)現(xiàn)問題可以馬上調(diào)整。那么每完成一部分就測試,這是持續(xù)部署。這是一個免費的源代碼,可以處理任何類型的構(gòu)建或持續(xù)集成。容器是完全使用沙箱機(jī)制,相互之間不會有任何接口。 導(dǎo)讀: 很久沒有更新文章了 最近公司在使用Spring Cloud構(gòu)建的項目中經(jīng)常會持續(xù)發(fā)布變更頻繁,一天中會出現(xiàn)發(fā)布多次的情況 在這種情況下對測試環(huán)境做了改造 ...
摘要:基于的特性,以及持續(xù)集成的需求,個推采用為持續(xù)集成搭建了一整套測試系統(tǒng)。個推持續(xù)集成流程以一個假設(shè)名為模塊為例,以開發(fā)人員的視角闡述了持續(xù)集成的邏輯。 軟件開發(fā)過程中,開發(fā)成員經(jīng)常需要把自己工作集成到項目中,通常每個成員每天至少集成一次。如果項目較小,對外部的依賴較小,那么軟件集成可能不會是什么問題。但是目前很多軟件項目特別是互聯(lián)網(wǎng)項目面臨著需求不明確,系統(tǒng)架構(gòu)復(fù)雜,任務(wù)分配混亂等一系...
閱讀 1438·2021-11-19 11:38
閱讀 3573·2021-11-15 11:37
閱讀 816·2021-09-30 09:48
閱讀 967·2021-09-29 09:46
閱讀 906·2021-09-23 11:22
閱讀 1884·2019-08-30 15:44
閱讀 3403·2019-08-26 13:58
閱讀 2392·2019-08-26 13:26