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

阿里巴巴雲原生發表於2021-09-17
簡介:目前雲效全家桶的功能相對來說比較適合個人開發或者中小團隊的群體,如果你此時正在為搭建這類管理平臺做選型,同時預算和人力都捉襟見肘,那麼不妨試試雲效這個產品!一起白嫖一起爽!尤其伺服器資源在阿里雲的小夥伴們,真得不能錯過!

作者|翟永超

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

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

因為業務產品是最重要的,所以這塊基本不能動。那麼能動的就是一些周邊設施了,比如:做任務管理、文件管理或持續交付的工具。在調研了諸多 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 管理不是特別熟悉的小夥伴也可以根據提示輕鬆的完成程式碼倉庫的遷移。

 title=

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

 title=

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

 title=

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

持續整合

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

 title=

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

 title=

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

 title=

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

 title=

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

 title=

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

 title=

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

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

 title=

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

 title=

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

管理門戶

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

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

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

 title=

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

 title=

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

 title=

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

 title=

 title=

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

總結

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

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

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

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

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

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

https://www.aliyun.com/product/yunxiao?channel=yy\_dd


感謝翟永超對雲效的信任和肯定,希望雲效可以陪伴他們不斷進步。
如果你也有故事要分享,掃描下方二維碼進群分享你的故事,後臺提交給我們。

版權宣告:本文內容由阿里雲實名註冊使用者自發貢獻,版權歸原作者所有,阿里雲開發者社群不擁有其著作權,亦不承擔相應法律責任。具體規則請檢視《阿里雲開發者社群使用者服務協議》和《阿里雲開發者社群智慧財產權保護指引》。如果您發現本社群中有涉嫌抄襲的內容,填寫侵權投訴表單進行舉報,一經查實,本社群將立刻刪除涉嫌侵權內容。

相關文章