天天看點

再見了,我的散裝研發管理平台;再見了,4台ECS!

周末的時候,收到好幾個雲伺服器臨近過期的通知短信,準備續個費,居然都要大幾千!因為這幾個都是以前低價搶購的,掐指一算,如果都續費的話,要蠶食好多利潤!

作為一名自己養活自己的獨立開發者,節省成本是必備技能,不然哪來可觀的利潤?于是,就開始琢磨着做一些架構上的調整,看看能否在這次伺服器資源減少的情況下,繼續低成本的運作目前還在跑的業務。

因為業務産品是最重要的,是以這塊基本不能動。那麼能動的就是一些周邊設施了,比如:做任務管理、文檔管理或持續傳遞的工具。在調研了諸多SaaS産品和雲服務之後,最後選擇了阿裡雲的雲效全家桶。為什麼最終選擇了雲效全家桶呢?核心原因還是“全家桶”三個字,基本上我想要的研發管理功能都能否覆寫了。那麼這個全家桶具體能做什麼呢?下面給大家分享下我改造前和改造後的平台結構,給大家一個直覺的認識。

老架構:散裝內建

老架構的建立基本上借鑒了以前在公司裡搭建基礎平台時候所用的常用開源産品和商業産品,按功能來分,主要有以下這幾個:

  • 代碼倉庫:GitLab
  • 持續內建:Jenkins
  • 任務管理:JIRA
  • 文檔管理:Confluence

Gitlab和Jenkins都是開源産品,免費且應用廣泛,是大部分公司的散裝方案中會囊括的。JIRA和Confluence雖然是商業産品,但初級版本的認證隻需要9.9美元,對個人和10人以下小團隊還是非常友好的,由于JIRA強大的流程配置功能,可以将其作為整個研發管理平台的門戶。

補充:有很多開發者對于JIRA隻認為是一個任務管理的工具,不太了解JIRA的工作流功能,這裡簡單說明一下。JIRA之是以強大,有很大一點就是得益于其強大的工作流配置功能。由于GitLab、Jenkins等這些工具都有WebHook或JIRA市場下的插件支援,我們就可以很友善的把這些工具的使用步驟串聯起來。這樣我們在軟體研發過程中的業務需求、任務拆解、代碼版本、建構部署等一體化過程都可以JIRA這樣一個單一入口中來完成。

所用資源:由于之前搶購的各個伺服器配置都不高,大多是1C2G、2C4G的。為了穩定運作就都做了分開部署,一共消耗了4台ECS。

方案優點:

  • 學習成本低:這些産品都是網際網路公司中非常常見的,大部分開發都不會太陌生。同時這些軟體的生态都非常健全,都有很豐富的插件市場來适應使用者的各種需求。
  • 産品成本低:這裡用到的産品不是免費就是很便宜,是以成本的基礎成本不高

方案缺點:

  • 部署成本高:因為需要安裝的軟體産品多,部署成本較高

新架構:雲效全家桶

在決定使用雲效全家桶之後,接下來要做的就是對老架構中用到的各個産品找到替代的解決方案。下面跟着我的調研使用步驟,來看看這一個個産品的對應關系吧!

代碼倉庫

代碼倉庫在雲效的解決方案中是一個名為雲效Codeup的産品,産品位址:https://codeup.aliyun.com/ 。如果你跟我一樣,是要做倉庫遷移的話,非常簡單。如下圖所示,Codeup為各種常用平台都提供了專用的導入方式,對Git管理不是特别熟悉的小夥伴也可以根據提示輕松的完成代碼倉庫的遷移。

再見了,我的散裝研發管理平台;再見了,4台ECS!

在點選“導入代碼庫”之後,我們可以看到下圖界面,基本上常用的一些Git管理平台都已經支援,選擇你要遷移的源平台,然後根據官網文檔,找到對應平台需要擷取的認證方式做好配置即可。

再見了,我的散裝研發管理平台;再見了,4台ECS!

在完成認證資訊配置好之後,Codeup就會從對應的平台擷取所有項目倉庫,接下來隻需要逐個選擇你要導入的倉庫點選“導入”按鈕,就能輕松完成代碼的遷移。

再見了,我的散裝研發管理平台;再見了,4台ECS!

這塊比較簡單,基本所有的Git管理平台都可以支援類似的遷移操作。也不算特别的亮點吧,光從代碼管理上來說,主要貢獻就是為這次的改造計劃節省了一台ECS。

持續內建

完成了代碼遷移之後,接下來開整持續內建部分,對應的産品是雲效Flow,産品位址是:https://flow.aliyun.com/。

再見了,我的散裝研發管理平台;再見了,4台ECS!

在雲效Flow中建立CI/CD的流水線非常簡單,因為它提供了各個主流開發語言的多種持續內建案例的配置模版。

再見了,我的散裝研發管理平台;再見了,4台ECS!

這裡我嘗試了配置一個Spring Boot後端應用部署到ECS上,隻需要選擇上圖中的第一個推薦模版。就會出現如下圖的流水線配置界面,點選每個步驟都可以進行細節配置

再見了,我的散裝研發管理平台;再見了,4台ECS!

點選每個步驟都可以進行細節配置,比如:如何用maven指令建構,如何上傳制品

再見了,我的散裝研發管理平台;再見了,4台ECS!

在部署操作上,因為與阿裡雲的結合,可以很友善的關聯到賬号下的資源來選擇部署,是以你就不用自己維護伺服器清單了,特别友善!

再見了,我的散裝研發管理平台;再見了,4台ECS!

那麼這個流水線功能是否能滿足雲原生應用一次建構多處部署的特性呢?下面我也嘗試做了一下,大緻流程就是:在test環境,做建構、上傳制品、部署;在pre環境,做選擇制品、部署;在pro環境,做選址執行、部署。模拟了一下這種比較常見的CI/CD管理流程。

再見了,我的散裝研發管理平台;再見了,4台ECS!

如上圖所示,是可以滿足的。這也已經滿足了我這邊的持續內建要求。不過這裡在流水線串聯,想要實作選擇制品這一步上,支援的使用者體驗還不是特别好,花了我一些配置和咨詢的時間才完成。據悉這部分體驗優化馬上在9月15日版本也會優化!疊代很快,非常給力!

這裡值得一提的是,在雲效Flow中所提供的各種操作模版是非常适應于我們國内使用者的,比如:可以看看我在test環境的流程細節,這裡增加了代碼掃描,裡面就涵蓋了阿裡巴巴代碼規約的檢查報告等。

再見了,我的散裝研發管理平台;再見了,4台ECS!

而對于通知提醒也是非常符合國内開發團隊的管理特點,提供了釘釘、企業微信、飛書這些國内才常用的軟體支援。

再見了,我的散裝研發管理平台;再見了,4台ECS!

好了,通過雲效Flow,又幫我節省了一台Jenkins的ECS。

管理門戶

在講老架構的時候,我提到了使用JIRA的重要原因是要将其作為整個研發管理的門戶,因為他可以整合其他所有周邊設施。比如:任務的管理、持續內建的觸發等等。那麼在雲效全家桶中,是否有扮演這樣角色的産品呢?作為一站式的解決方案,必須得安排上,對應的産品就是雲效DevOps,産品位址:https://devops.aliyun.com/ 。

到這裡可能你要問了,任務管理和文檔管理這兩個不替換了嗎?必須替換!隻是,因為作為門戶的雲效DevOps其實就涵蓋了這兩塊内容。是以,接下來就一起看看雲效DevOps的強大功能吧!

這款産品的上手非常快,因為它提供了一些常用模版。我這邊就直接給予DevOps研發模版來建立。

再見了,我的散裝研發管理平台;再見了,4台ECS!

完成建立後,不難發現菜單中的需求、疊代、任務、缺陷、測試計劃、版本管理不就是JIRA的替代品麼?而知識庫不就是Confluence的替代品嘛!

再見了,我的散裝研發管理平台;再見了,4台ECS!

這裡還很貼心的提供了Excel導入的功能,是以我隻需要從JIRA裡導出Issue,然後在這裡導入,就可以繼續做之前的任務管理啦!

再見了,我的散裝研發管理平台;再見了,4台ECS!

同時,作為管理門戶,對于之前介紹的雲效Codeup、雲效Flow自然也可以聯系起來。隻需要通過點選菜單中的代碼、流水線(剛建立的時候,需要點選關聯選擇同賬号下配置的代碼倉庫和流水線),就能進行檢視和實作日常操作!

再見了,我的散裝研發管理平台;再見了,4台ECS!
再見了,我的散裝研發管理平台;再見了,4台ECS!

到這裡,雲效DevOps基本就完成在散裝方案中JIRA和Confluence的角色,妥妥的繼續釋放出兩台ECS!

總結

最後,盤點下這次從自己做的散裝方案到使用雲效全家桶之後,我認為比較大的幾個收益點:

  1. 成本降低了:節約了4台ECS。對于我們這種個人開發或小團隊來說,雲效基本就是免費的,白嫖能不爽麼?
  2. 運維容易了:跟阿裡雲的高度整合,對于資源的維護以及關聯操作更加友善!

對于雲效DevOps這個産品,從我的場景來說非常好用,核心原因是已經夠用。但如果要做非常複雜的管理可能還有一些困難,比如:在目前版本中,我并沒有找到類似JIRA那樣強大的工作流支援,這樣的話如果團隊有一些複雜流程管理,例如多人參與的稽核流程,還有與其他系統的關聯,還沒有比較好的支援(不過,在與雲效的小夥伴咨詢這類功能的時候,得知這類功能已經在内測,那麼具體功能支援如何,等後面公測了我們一起拭目以待吧)。

就目前整個雲效全家桶的功能來說,我覺得最主要的适用群體還是我這種個人開發或者中小團隊!如果你此時正在為搭建這類管理平台做選型,同時跟我一樣,預算和人力都捉襟見肘,那麼不妨試試雲效這個産品!一起白嫖一起爽!尤其伺服器資源在阿裡雲的小夥伴們,真得不能錯過

點選下方連結立即體驗雲效DevOps全家桶!

阿裡雲雲效-DevOps自動化運維-企業級DevOps平台-項目協作工具-阿裡雲

繼續閱讀