www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 公眾號精選 > 架構(gòu)師社區(qū)
[導(dǎo)讀]來自:DBAplus社群 作者介紹 劉華(Kenneth),就職于世界500強(qiáng)銀行,負(fù)責(zé)基金服務(wù)業(yè)務(wù)軟件開發(fā)與交付,DevOps團(tuán)隊(duì)負(fù)責(zé)人。敏捷、精益、DevOps領(lǐng)域?qū)<遥O限編程、Scrum、看板方法、測試驅(qū)動開發(fā)、持續(xù)集成、行為驅(qū)動開發(fā)、DevOps工具棧。著有《獵豹行動


銀行持續(xù)交付實(shí)戰(zhàn):一個單體系統(tǒng)足以撐起全球大項(xiàng)目

來自:DBAplus社群

作者介紹

劉華(Kenneth),就職于世界500強(qiáng)銀行,負(fù)責(zé)基金服務(wù)業(yè)務(wù)軟件開發(fā)與交付,DevOps團(tuán)隊(duì)負(fù)責(zé)人。敏捷、精益、DevOps領(lǐng)域?qū)<?,精通極限編程、Scrum、看板方法、測試驅(qū)動開發(fā)、持續(xù)集成、行為驅(qū)動開發(fā)、DevOps工具棧。著有《獵豹行動:硝煙中的敏捷轉(zhuǎn)型之旅》一書。


我們的核心系統(tǒng)是一個單體系統(tǒng),支撐全球多個國家和地區(qū)的業(yè)務(wù)。同時,業(yè)務(wù)部門近年生意紅火,接了幾個大客戶,針對這些大客戶的大型項(xiàng)目也在如火如荼地進(jìn)行中。


由于生產(chǎn)環(huán)境只有一套,而且已經(jīng)有業(yè)務(wù)在生產(chǎn)環(huán)境上跑,這些大項(xiàng)目最終也要在這套生產(chǎn)環(huán)境上上線。這套系統(tǒng)是糅合了各地、各不同業(yè)務(wù)的復(fù)雜系統(tǒng)。


之前,為了滿足各個客戶交付時間,每個項(xiàng)目都拉了一個獨(dú)立的分支進(jìn)行開發(fā),減少各項(xiàng)目之間的依賴,但這也導(dǎo)致了每個項(xiàng)目各自為政,互不交流。一旦這些項(xiàng)目開發(fā)完成,要和生產(chǎn)環(huán)境的版本進(jìn)行合并。這種巨型合并勢必帶來巨大風(fēng)險,相互隔絕的開發(fā)模式也將帶來大量的合并沖突。


我們一直在思考如何降低這種合并風(fēng)險,以及如何打破各大型項(xiàng)目各自為政的困局,實(shí)現(xiàn)產(chǎn)品化的敏捷交付?;貧w測試成為實(shí)現(xiàn)這些使命的基礎(chǔ)。


使命——實(shí)現(xiàn)敏捷交付


前面提到,目前的開發(fā)模式是針對不同的大客戶,分別設(shè)立了不同的大型項(xiàng)目進(jìn)行開發(fā)。這些項(xiàng)目的交付周期往往數(shù)以年計,交付周期長,風(fēng)險大。


生產(chǎn)環(huán)境又只有一套,而且已經(jīng)有業(yè)務(wù)在生產(chǎn)環(huán)境上跑,代碼合并困難,上線風(fēng)險巨大。


我們希望能打破這種大型項(xiàng)目的交付形式,以產(chǎn)品化的思維進(jìn)行管理。


具體實(shí)施的思路是:


  1. 合并——對各大型項(xiàng)目的現(xiàn)有代碼與生產(chǎn)環(huán)境的版本進(jìn)行一次性的合并;

  2. 統(tǒng)一Backlog——各類需求(包括現(xiàn)在以大型項(xiàng)目形式服務(wù)的大客戶的需求)以用戶故事的形式進(jìn)入到同一個Backlog;

  3. Scrum——建立以Scrum為形式的持續(xù)交付機(jī)制,以一個月作為Sprint的周期,通過Sprint計劃會議敲定Sprint的交付計劃;

  4. 持續(xù)交付——每個Sprint完成計劃內(nèi)各用戶故事的交付全流程,包括回歸測試和上線到生產(chǎn)環(huán)境。


要實(shí)現(xiàn)以上模式,上線前的回歸測試至關(guān)重要。而且由于一個Sprint內(nèi),也就是一個月內(nèi),要完成Sprint交付計劃內(nèi)所有用戶故事的需求澄清、設(shè)計、開發(fā)、測試、用戶驗(yàn)收和上線,時間非常緊,回歸測試也必須在一、兩天內(nèi)完成。


如何實(shí)現(xiàn)既能充分保護(hù)生產(chǎn)環(huán)境,又能實(shí)現(xiàn)快速反饋的回歸測試,成為一個重要議題。


自動化大量功能測試不可行


對于如何設(shè)計和實(shí)施覆蓋率高、執(zhí)行穩(wěn)定而且快速的自動化回歸測試,一直是一個難題。


我們曾經(jīng)的一個思路是把現(xiàn)有的功能測試用例進(jìn)行自動化,但很快發(fā)現(xiàn)這個思路不可行,主要原因如下:


  1. 只能依賴UI測試——由于核心系統(tǒng)是供應(yīng)商產(chǎn)品,開發(fā)是由供應(yīng)商負(fù)責(zé)的,對我們來說就是個黑盒子,我們只能通過UI進(jìn)行測試。眾所周知,UI的自動化測試,開發(fā)、維護(hù)成本高,脆弱而且執(zhí)行時間長;


  2. 無法快速反饋——通過功能進(jìn)行覆蓋,要求不斷增加測試用例來提高覆蓋率,由于UI測試的執(zhí)行時間長,用例越多,整體執(zhí)行時間越長,如果執(zhí)行周期要數(shù)以天計,則無法達(dá)到快速反饋的目的;


  3. 性價比低——功能測試用例的覆蓋率其實(shí)是不可見的,即使把所有功能測試都自動化了,其實(shí)際覆蓋率依然不高,也就是說這個投入的性價比很低。


我們必須要尋找一種方法,以最小的投入獲取最大的保障。


我們對回歸測試自動化的預(yù)期進(jìn)行了重新定位。我們進(jìn)行回歸測試,就是要保護(hù)生產(chǎn)環(huán)境的關(guān)鍵業(yè)務(wù)可以照常進(jìn)行。我們要防止的,是新的特性發(fā)布造成生產(chǎn)環(huán)境災(zāi)難,也就是導(dǎo)致關(guān)鍵業(yè)務(wù)無法進(jìn)行的大面積故障。對于非災(zāi)難性的小故障,完全可以通過運(yùn)維手段來處理。


因此,我們不應(yīng)該把回歸測試定位為防止一切問題。


以不變應(yīng)萬變


基于以上對回歸測試預(yù)期的重新定位,我們和業(yè)務(wù)部門協(xié)商,請他們列舉出當(dāng)前在生產(chǎn)環(huán)境上最關(guān)鍵的業(yè)務(wù)過程有哪些。我們要保證的是,當(dāng)新的特性上線后的首個交易日,原有的最關(guān)鍵的業(yè)務(wù)過程不會受到嚴(yán)重影響。


基于這個預(yù)期,我們以業(yè)務(wù)部門提供的關(guān)鍵業(yè)務(wù)過程作為測試用例,并形成以下的回歸測試思路:


準(zhǔn)備階段:


  1. 在某個測試環(huán)境里,系統(tǒng)版本與生產(chǎn)環(huán)境版本相同;

  2. 備份環(huán)境數(shù)據(jù);

  3. 以某個交易日為基準(zhǔn),執(zhí)行相應(yīng)的測試用例;

  4. 備份輸入、輸出數(shù)據(jù)(包括生成的接口文件和報表)。


執(zhí)行階段:


  1. 在該測試環(huán)境里,導(dǎo)入在準(zhǔn)備階段備份的環(huán)境數(shù)據(jù);

  2. 升級系統(tǒng)到目標(biāo)版本;

  3. 以準(zhǔn)備階段相同的交易日和相同的輸入數(shù)據(jù)(在準(zhǔn)備階段已備份)執(zhí)行相同的測試用例,生成相應(yīng)的接口文件和報表;

  4. 與準(zhǔn)備階段的輸出(接口文件和報表)進(jìn)行比對;

  5. 如果目標(biāo)版本的輸出與原版本的對比沒有非預(yù)期的差異,視為通過。


簡單總結(jié),就是對比兩個系統(tǒng)版本在相同測試環(huán)境、相同環(huán)境數(shù)據(jù)、相同交易日、相同輸入的情況下,輸出是否有非預(yù)期的差異。


這個思路的最大特點(diǎn)是,以不變應(yīng)萬變。生產(chǎn)環(huán)境的關(guān)鍵業(yè)務(wù)過程不會經(jīng)常變化,也就是說測試用例基本上比較固定。通過反復(fù)運(yùn)行固定的測試用例實(shí)現(xiàn)回歸測試的目標(biāo),保護(hù)生產(chǎn)環(huán)境上的關(guān)鍵業(yè)務(wù)過程,避免災(zāi)難。以最少的用例實(shí)現(xiàn)最大的保護(hù)。


而且測試的結(jié)果驗(yàn)證是通過比對不同版本的輸出,我們不必在乎具體的輸出內(nèi)容,只需要關(guān)注輸出是否有非預(yù)期差異。


當(dāng)然,一旦有新的大客戶上線,也就是有新的關(guān)鍵業(yè)務(wù)過程,這些過程也應(yīng)該放入到回歸測試用例中,當(dāng)然,用例的選擇還是以避免災(zāi)難為準(zhǔn)則。


在前面提到的功能測試思路里,我們需要不斷增加測試用例以增加測試覆蓋率,但是由于測試只能在UI進(jìn)行,這樣無限增加功能測試用例是不可持續(xù)的。


通過實(shí)踐,我們發(fā)現(xiàn)要充分發(fā)揮這個新思路的價值,要注意以下幾點(diǎn):


  1. 專屬環(huán)境——由于這套環(huán)境需要反復(fù)整理環(huán)境數(shù)據(jù)和升級,一定要為這個回歸測試準(zhǔn)備一套專屬的測試環(huán)境,不要在共享的環(huán)境里進(jìn)行;


  2. 明確檢查點(diǎn)——由于執(zhí)行測試輸出的接口文件、報表里一定有時間戳、自增ID等每次執(zhí)行都會變化的信息,不能簡單通過文件來比對。在擬定測試用例時,就應(yīng)該明確這些接口文件、報表里的有哪些數(shù)據(jù)需要檢查。在每個版本交付時,開發(fā)人員也應(yīng)該明確告知哪些數(shù)據(jù)檢查點(diǎn)會有預(yù)期差異。否則對比工作將耗費(fèi)大量的時間和精力;


  3. 變更范圍要小——如果對比的兩個系統(tǒng)版本的變更范圍太大,會導(dǎo)致輸出有大量差異,比對意義不大。因此這個方法不太適合大的合并,比較適合落實(shí)了敏捷交付后,由于每個Sprint的變更范圍較小,兩個系統(tǒng)版本間的輸出差異不多,比對較容易。


以這個思路建立了回歸測試框架,我們便可以著手執(zhí)行過程的自動化,從而提升其執(zhí)行的效率。


總結(jié)


我們的核心系統(tǒng)是一套單體復(fù)雜系統(tǒng),支撐全球多個國家和地區(qū)不同的業(yè)務(wù)。


為了實(shí)現(xiàn)敏捷交付,我們希望打破目前以大型項(xiàng)目為形式的各自為政,把各項(xiàng)目的所有需求放在統(tǒng)一的Backlog通過Scrum的方法進(jìn)行持續(xù)交付。


要實(shí)現(xiàn)這一點(diǎn),我們需要在每個Sprint都進(jìn)行有效的回歸測試,以保護(hù)生產(chǎn)環(huán)境的關(guān)鍵業(yè)務(wù)在新特性上線后不會有災(zāi)難性的故障。


通過對比兩個系統(tǒng)版本在相同測試環(huán)境、相同環(huán)境數(shù)據(jù)、相同交易日、相同輸入的情況下,執(zhí)行關(guān)鍵業(yè)務(wù)過程的有限的測試用例,輸出是否有非預(yù)期的差異的回歸測試方法,以少勝多,以不變應(yīng)萬變,持續(xù)保護(hù)生產(chǎn)環(huán)境的核心業(yè)務(wù),為持續(xù)交付保駕護(hù)航。




特別推薦一個分享架構(gòu)+算法的優(yōu)質(zhì)內(nèi)容,還沒關(guān)注的小伙伴,可以長按關(guān)注一下:

銀行持續(xù)交付實(shí)戰(zhàn):一個單體系統(tǒng)足以撐起全球大項(xiàng)目

長按訂閱更多精彩▼

銀行持續(xù)交付實(shí)戰(zhàn):一個單體系統(tǒng)足以撐起全球大項(xiàng)目

如有收獲,點(diǎn)個在看,誠摯感謝


免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點(diǎn),不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉