1. 程式人生 > 其它 >再見了,我的散裝研發管理平臺;再見了,4臺ECS!

再見了,我的散裝研發管理平臺;再見了,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管理不是特別熟悉的小夥伴也可以根據提示輕鬆的完成程式碼倉庫的遷移。

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

在完成認證資訊配置好之後,Codeup就會從對應的平臺獲取所有專案倉庫,接下來只需要逐個選擇你要匯入的倉庫點選“匯入”按鈕,就能輕鬆完成程式碼的遷移。

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

持續整合

完成了程式碼遷移之後,接下來開整持續整合部分,對應的產品是雲效Flow,產品地址是:https://flow.aliyun.com/。

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

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

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

在部署操作上,因為與阿里雲的結合,可以很方便的關聯到賬號下的資源來選擇部署,所以你就不用自己維護伺服器清單了,特別方便!

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

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

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

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

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

管理門戶

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

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

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

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

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

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

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

總結

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

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

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

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

如果你還沒有實際可以操作的專案來體驗雲效DevOps,但也想學習和了解一下這個研發管理產品。那麼也可以通過參與下面這個“1分鐘程式碼自動捉蟲”活動,來體驗一把。

9月6-10日,雲效新使用者完成體驗,還可抽Cherry機械鍵盤、阿里雲定製GIt命令滑鼠墊、積木星球等。1000份禮品,100%中獎,先到先得!

歡迎關注我的公眾號:程式猿DD,分享外面看不到的乾貨與思考!