開(kāi)發(fā)團(tuán)隊(duì)的預(yù)期目標(biāo)是每天能產(chǎn)生可交付的代碼,對(duì)于持續(xù)集成的目標(biāo)是每一次的構(gòu)建能產(chǎn)生可執(zhí)行的程序。一旦構(gòu)建失敗,開(kāi)發(fā)團(tuán)隊(duì)需要立即響應(yīng),修正,以解決延時(shí)帶來(lái)的浪費(fèi)。
所以,構(gòu)建失敗的及時(shí)通知變得異常重要,如何能及時(shí)通知committer,是由誰(shuí)導(dǎo)致的構(gòu)建失敗。這些工作如果你的團(tuán)隊(duì)還在人工執(zhí)行,那么可以閱讀下下面的方法,利用工具,提高效率。
很多工具為Jenkins開(kāi)發(fā)了通知工具,點(diǎn)擊查看Plugins,本文介紹其中的三種工具:郵件通知,簡(jiǎn)聊,Slack
郵件通知
郵件通知是Jenkins的默認(rèn)通知工具,可以直接配置。
1. 系統(tǒng)管理設(shè)置
Jenkins系統(tǒng)管理->系統(tǒng)設(shè)置
如圖,使用一個(gè)已有的郵箱(比如163或者qq)作為郵件通知郵箱,配置SMTP服務(wù)器,郵箱的用戶名和密碼。
用戶默認(rèn)郵件后綴是填寫(xiě)公司郵箱后綴,在郵件通知時(shí)會(huì)自動(dòng)將后綴增加至svn提交者的用戶名后面。
配置完成后可以勾選
通過(guò)發(fā)送測(cè)試郵件測(cè)試配置
如果出現(xiàn)“Email was successfully sent”,代表配置沒(méi)有問(wèn)題。
2. Job配置
在需要郵件通知的Job設(shè)置里面增加“構(gòu)建后操作步驟”->選擇E-mail Notification
郵件通知配置可以選擇在每一次構(gòu)建成功或 不成功,需要群發(fā)郵件的收件人信息。
但是如果你群發(fā)的收件人列表比較多,或者每次通知的人不一樣,比如每次只想通知導(dǎo)致構(gòu)建失敗的那個(gè)人(即最后一次上傳代碼的人),那么簡(jiǎn)單的E-mail Notification肯定不能滿足你的要求,需要加入下面這個(gè)插件Email extension plugin。
3. Email extension plugin
以上基本郵件通知已配置完成,Jenkins還有一個(gè)plugin用于編輯郵件通知的相關(guān)配置Email_Extension_Plugin。
“系統(tǒng)設(shè)置”中選擇“插件管理”,搜索Email extension plugin,直接安裝。安裝成功后,在Job設(shè)置里面增加構(gòu)建后步驟選擇添加“Editable Email Notification”
下面這些設(shè)置以“$”開(kāi)頭的全局變量可以在Jenkins->系統(tǒng)管理->系統(tǒng)設(shè)置->Extended E-mail Notification中進(jìn)行設(shè)置。
有些內(nèi)容可能會(huì)被下面的高級(jí)設(shè)置覆蓋,比如Default Content。
如果希望分別針對(duì)構(gòu)建成功和構(gòu)建失敗發(fā)送不同的郵件通知,可以點(diǎn)擊Advanced Setting。注意Triggers的設(shè)置,可以配置多種Triggers(觸發(fā)器),F(xiàn)ailure-Any,F(xiàn)ailure-1st(第一次構(gòu)建失?。琒uccess,F(xiàn)ixed,Abort等等。觸發(fā)器的種類很多,可以根據(jù)實(shí)際需要選擇。每種觸發(fā)器可以根據(jù)需要選擇Send To,比如Failure-Any可以add upstream Committers,Requestor等等。
每一個(gè)Trigger可以單獨(dú)在高級(jí)中配置Default Subject,Default Content,Recipient List等等,所以在觸發(fā)器中的這個(gè)設(shè)置是可以覆蓋上面的基礎(chǔ)設(shè)置的。
Email extension plugin的詳細(xì)版本可參考官網(wǎng)。
簡(jiǎn)聊
在Jenkins中選擇簡(jiǎn)聊插件,jianliao plugin,這一步同郵件,不再贅述。
接入簡(jiǎn)聊的團(tuán)隊(duì),可以在簡(jiǎn)聊的團(tuán)隊(duì)首頁(yè)->聚合服務(wù)->Jenkins,選擇添加。Jenkins的構(gòu)建通知會(huì)發(fā)到簡(jiǎn)聊的某個(gè)話題中,通??梢孕陆ㄒ粋€(gè)持續(xù)集成的話題,用于通知。
添加成功后,可以展開(kāi)設(shè)置指南,查看Jenkins中是如何設(shè)置簡(jiǎn)聊的,關(guān)鍵是將WebHook地址copy到Jenkins自己的Job中,設(shè)置指南中已經(jīng)非常詳細(xì),我就不再贅述了。
Slack
不清楚國(guó)內(nèi)團(tuán)隊(duì)使用slack的多不多,slack在國(guó)外是很火的,雖然首頁(yè)登錄比較慢,但team的首頁(yè)的訪問(wèn)完全沒(méi)有問(wèn)題。本節(jié)僅針對(duì)你已經(jīng)在slack上注冊(cè)了team,并想利用slack做Jenkins的構(gòu)建通知。
首先需要在Jenkins中安裝 slack plugin,同郵箱,不再贅述。
登錄slack,在team的setting中選擇App&integrations.
直接在搜索欄中輸入Jenkins,跳轉(zhuǎn)至Jenkins配置頁(yè)面。
新添加一個(gè)Jenkins的config,選擇要通知的channel。
選擇add Jenkins CI integration后,也會(huì)有詳細(xì)的Jenkins接入指引。跟著指引操作一般就不會(huì)有什么問(wèn)題了,slack與簡(jiǎn)聊不一樣,是通過(guò)Token來(lái)標(biāo)識(shí)CI集成的通知標(biāo)識(shí)
總結(jié)
以上就是三種通知渠道,你喜歡哪種?個(gè)人認(rèn)為如果團(tuán)隊(duì)比較習(xí)慣于用實(shí)時(shí)溝通工具,slack和簡(jiǎn)聊都是比較好的工具,通知也很方便,比郵箱要實(shí)時(shí)很多。當(dāng)然,如果你的團(tuán)隊(duì)還沒(méi)有接入工具,用郵箱也是可以達(dá)到這樣的目的。
如果對(duì)Jenkins的配有還有什么疑問(wèn),可以參考Jenkins實(shí)踐一:mac下Jenkins+gradle配置Android持續(xù)集成環(huán)境
如有問(wèn)題,可以隨時(shí)交流。