作者|翟永超
周末的時候,收到好幾個雲服務器臨近過期的通知短信,准備續個費,居然都要大幾千!因為這幾個都是以前低價搶購的,掐指一算,如果都續費的話,要蠶食好多利潤!
作為一名自己養活自己的獨立開發者,節省成本是必備技能,不然哪來可觀的利潤?於是,就開始琢磨着做一些架構上的調整,看看能否在這次服務器資源減少的情況下,繼續低成本的運行目前還在跑的業務。
因為業務產品是最重要的,所以這塊基本不能動。那么能動的就是一些周邊設施了,比如:做任務管理、文檔管理或持續交付的工具。在調研了諸多 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!
總結
最后,盤點下這次從自己做的散裝方案到使用雲效全家桶之后,我認為比較大的幾個收益點:
- 成本降低了:節約了4台 ECS。對於我們這種個人開發或小團隊來說,雲效基本就是免費的,白嫖能不爽么?
- 運維容易了:跟阿里雲的高度整合,對於資源的維護以及關聯操作更加方便!
對於雲效 DevOps 這個產品,從我的場景來說非常好用,核心原因是已經夠用。但如果要做非常復雜的管理可能還有一些困難,比如:在目前版本中,我並沒有找到類似 JIRA 那樣強大的工作流支持,這樣的話如果團隊有一些復雜流程管理,例如多人參與的審核流程,還有與其他系統的聯動,還沒有比較好的支持(不過,在與雲效的小伙伴咨詢這類功能的時候,得知這類功能已經在內測,那么具體功能支持如何,等后面公測了我們一起拭目以待吧)。
就目前整個雲效全家桶的功能來說,我覺得最主要的適用群體還是我這種個人開發或者中小團隊!如果你此時正在為搭建這類管理平台做選型,同時跟我一樣,預算和人力都捉襟見肘,那么不妨試試雲效這個產品!一起白嫖一起爽!尤其服務器資源在阿里雲的小伙伴們,真得不能錯過!
如果你還沒有實際可以操作的項目來體驗雲效 DevOps,但也想學習和了解一下這個研發管理產品。那么也可以通過參與下面這個“1分鍾代碼自動捉蟲”活動,來體驗一把。
點擊下方鏈接立即體驗雲效DevOps全家桶!https://www.aliyun.com/product/yunxiao?channel=yy_dd