需求:
目前上線前會(huì)將需要上線的代碼push到release分支塘淑,然后由人工填寫(xiě)參數(shù)點(diǎn)擊觸發(fā)jenkins上的任務(wù)舔痕。希望這個(gè)過(guò)程能完成自動(dòng)化棍现,只要有人往release上推代碼验残,就自動(dòng)跑部署release分支并測(cè)試
解決辦法及步驟:
1.在jenkins里需要自動(dòng)觸發(fā)的job里的“源碼管理”部分添加設(shè)置忱反,如下圖。填好git倉(cāng)庫(kù)url和需要檢測(cè)的分支名稱
注意事項(xiàng):
a.在填url的時(shí)候可能會(huì)提示找不到命令的錯(cuò)誤祝拯,遇到這個(gè)錯(cuò)的解決辦法是去jenkins系統(tǒng)管理->系統(tǒng)設(shè)置甚带,找到git設(shè)置部分,在Path to Git executable里填上git的路徑佳头,這個(gè)路徑在服務(wù)器上執(zhí)行命令which git可得到鹰贵。
b.還有可能遇到的是報(bào)Permission denied這樣的錯(cuò)誤。這是由于jenkins運(yùn)行時(shí)所用的系統(tǒng)用戶沒(méi)有訪問(wèn)git倉(cāng)庫(kù)權(quán)限導(dǎo)致的康嘉。需要在運(yùn)行jenkins的用戶目錄下生成git的公鑰和私鑰碉输,并將owner改成該用戶。
2.在jenkins需要觸發(fā)的job里“構(gòu)建觸發(fā)器”部分勾選Poll SCM亭珍,但里面什么都不填敷钾。
如果填則是填crontab那種格式的命令。填了的話就是讓它每隔一段時(shí)間去檢查下源碼管理里所設(shè)置的git倉(cāng)庫(kù)里的分支有沒(méi)有更新肄梨,有更新則觸發(fā)該job,沒(méi)更新則不觸發(fā)阻荒。這樣設(shè)置的缺點(diǎn)是檢查得如果太過(guò)頻繁,是對(duì)網(wǎng)絡(luò)資源的浪費(fèi)众羡,但是檢查時(shí)間隔得太長(zhǎng)觸發(fā)又不及時(shí)财松。
而且使用過(guò)程中有個(gè)問(wèn)題,就是比如5分鐘檢查一次纱控,第一次檢查的時(shí)候檢測(cè)到有更新辆毡,于是執(zhí)行job,這個(gè)job執(zhí)行的時(shí)間比較長(zhǎng)超過(guò)了檢查時(shí)間5分鐘甜害,那下一次檢查的時(shí)候舶掖,由于這個(gè)job還正在運(yùn)行中,則它還會(huì)認(rèn)為這更新沒(méi)有被job執(zhí)行尔店,如此便會(huì)再次觸發(fā)job眨攘。只有在觸發(fā)的job執(zhí)行完時(shí),它才知道這個(gè)更新是被這個(gè)構(gòu)建執(zhí)行過(guò)的嚣州,不用再觸發(fā)了鲫售。
所以官方上也并不推薦這種方法,推薦的是遠(yuǎn)程觸發(fā)的方式该肴,比如用git的post-receive鉤子觸發(fā)情竹,只要在鉤子里寫(xiě)上這句即可。
curl?http://yourserver/git/notifyCommit?url=[&branches=branch1[,branch2]*][&sha1=]
由于我們的項(xiàng)目用的是gitLab,然后gitLab有個(gè)webhook可以用匀哄。原理上跟post-receive鉤子是差不多的秦效。
3.在Jenkins里裝一個(gè)插件https://wiki.jenkins-ci.org/display/JENKINS/Gitlab+Hook+Plugin
看名字就知道這個(gè)插件是為了配合gitLab用的
4.在gitLab項(xiàng)目中添加web hook(Project Settings --> WebHooks)
gitlab的web hook有很多種,可以滿足不同的需求涎嚼,因?yàn)槲覀兊男枨笫莗ush代碼的時(shí)候觸發(fā)阱州,所以選的是Push events.
Url的作用:這個(gè)地方填的url是gitlab發(fā)請(qǐng)求用的。其實(shí)它的原理就是當(dāng)開(kāi)發(fā)人員在git上的操作觸發(fā)這個(gè)hook時(shí)法梯,gitlab就向這個(gè)url發(fā)一個(gè)post請(qǐng)求苔货。請(qǐng)求中帶著一堆參數(shù)比如提交者是誰(shuí),提交的分支是哪個(gè)立哑,commit號(hào)是多少等等夜惭。接受這個(gè)請(qǐng)求的那端可以利用這些信息去處理后續(xù)的一些事情,比如部署測(cè)試通知等等刁憋。
此處滥嘴,由于我們?cè)趈enkins上安裝了gitlab hook插件,所以我們只需要按照它的使用方法在url里填上以下鏈接即可:
http://your-jenkins-server/gitlab/notify_commit
效果:
有人release上提交代碼后至耻,就會(huì)自動(dòng)觸發(fā)jenkins上的任務(wù)若皱。push到別的分支是不會(huì)觸發(fā)的。
參考文獻(xiàn):
https://github.com/elvanja/jenkins-gitlab-hook-plugin#notify-commit-hook
https://wiki.jenkins-ci.org/display/JENKINS/Git+Plugin