天天看點

更效率、更優雅 | 阿裡巴巴開發者工具不完全盤點一、Java 線上診斷工具 Arthas二、IDE 插件 Cloud Toolkit三、混沌實驗注入工具 ChaosBlade四、Java 代碼規約掃描插件五、應用實時監控工具 ARMS六、靜态開源站點搭建工具 Docsite七、Android 平台上的秒級編譯方案 Freeline八、性能測試工具 PTS九、雲效開發者工具 KT十、架構可視化工具 AHAS

更效率、更優雅 | 阿裡巴巴開發者工具不完全盤點一、Java 線上診斷工具 Arthas二、IDE 插件 Cloud Toolkit三、混沌實驗注入工具 ChaosBlade四、Java 代碼規約掃描插件五、應用實時監控工具 ARMS六、靜态開源站點搭建工具 Docsite七、Android 平台上的秒級編譯方案 Freeline八、性能測試工具 PTS九、雲效開發者工具 KT十、架構可視化工具 AHAS

(工欲善其事,必先利其器 - 圖檔來自網絡 )

文:王晨

從人工到自動化,從重複到創新,技術演進的曆程中,伴随着開發者工具類産品的發展。

阿裡巴巴将自身在各類業務場景下的技術積澱,通過開源、雲上實作或工具等形式對外開放,本文将精選了一些阿裡巴巴的開發者工具,希望能幫助開發者們提高開發效率、更優雅的寫代碼。

由于開發者涉及的技術領域衆多,筆者僅從自己熟悉的領域,以後端開發者的視角盤點平時可能有得到的工具。每個工具按照以下幾點進行介紹:

  • 工具名稱和簡介
  • 使用場景
  • 使用教程
  • 擷取方式

一、Java 線上診斷工具 Arthas

Arthas 阿裡巴巴2018年9月開源的一款 Java 線上診斷工具。

這個類從哪個 JAR 包加載的?為什麼會報各種類相關的 Exception?

我改的代碼為什麼沒有執行到?難道是我沒 commit?分支搞錯了?

遇到問題無法線上上 Debug,難道隻能通過加日志再重新釋出嗎?

線上遇到某個使用者的資料處理有問題,但線上同樣無法 Debug,線下無法重制!

是否有一個全局視角來檢視系統的運作狀況?

有什麼辦法可以監控到 JVM 的實時運作狀态?

Arthas支援JDK 6+,支援Linux/Mac/Windows,采用指令行互動模式,同時提供豐富的 Tab 自動補全功能,進一步友善進行問題的定位和診斷。

基礎教程:

https://alibaba.github.io/arthas/arthas-tutorials?language=cn&id=arthas-basics

進階教程:

https://alibaba.github.io/arthas/arthas-tutorials?language=cn&id=arthas-advanced

擷取方式:免費

開源位址:

https://github.com/alibaba/arthas

開發者交流群号:21965291(釘群)

二、IDE 插件 Cloud Toolkit

Cloud Toolkit 是一款 IDE 插件,可以幫助開發者更高效地開發、測試、診斷并部署應用。通過 Cloud Toolkit,開發者能夠友善地将本地應用一鍵部署到任意機器(本地或雲端),并内置 Arthas 診斷、高效執行終端指令和 SQL 等。

每次修改完代碼後,是否正在經曆反複地打包?在 Maven 、Git 以及其他運維腳本和工具的之間頻繁切換?

采用 SCP 工具上傳?使用XShell或SecureCRT登陸伺服器?替換部署包?重新開機?

檔案上傳到伺服器指定目錄,在各種 FTP、SCP 工具之間頻繁切換 ?

工具位址:

https://www.aliyun.com/product/cloudtoolkit

開發者交流群号:23341694(釘群)

三、混沌實驗注入工具 ChaosBlade

ChaosBlade 是一款遵循混沌工程實驗原理,提供豐富故障場景實作,幫助分布式系統提升容錯性和可恢複性的混沌工程工具,可實作底層故障的注入,提供了延遲、異常、傳回特定值、修改參數值、重複調用和try-catch 塊異常等異常場景。

微服務的容錯能力不易衡量?

容器編排配置是否合理無法驗證?

PaaS 層健壯性的測試工作無從入手?

https://github.com/chaosblade-io/chaosblade/wiki/

新手指南

開發者交流群号:23177705(釘群)

四、Java 代碼規約掃描插件

該插件用于檢測 Java 代碼中存在的不規範的位置,并給予提示。規約插件是采用kotlin語言開發。

IDEA插件使用文檔:

https://github.com/alibaba/p3c/wiki/IDEA

插件使用文檔

Eclipse插件使用文檔:

https://github.com/alibaba/p3c/wiki/Eclipse https://github.com/alibaba/p3c

五、應用實時監控工具 ARMS

ARMS 是一款 APM 類的監控工具,提供前端、應用、自定義監控 3 類監控選項,可快速建構實時的應用性能和業務監控能力。

工具的使用場景

晚上10點收到37條報警資訊,你卻無從下手?

當我們發現問題的時候,客戶/業務方已經發起投訴?

每個月花幾十萬買伺服器,卻無法保障使用者體驗?

前端監控接入:

https://help.aliyun.com/document_detail/106086.html

應用監控接入:

https://help.aliyun.com/document_detail/63796.html

自定義監控:

https://help.aliyun.com/document_detail/47474.html

擷取方式:收費

https://www.aliyun.com/product/arms

開發者交流群号:21914303(釘群)

六、靜态開源站點搭建工具 Docsite

Docsite 一款集官網、文檔、部落格和社群為一體的靜态開源站點的解決方案,具有簡單易上手、上手不撒手的特質,同時支援 react 和靜态渲染、PC端和移動端、支援中英文國際化、SEO、markdown文檔、全局站點搜尋、站點風格自定義、頁面自定義等功能。

https://docsite.js.org/zh-cn/docs/installation.html

項目位址:

https://github.com/txd-team/docsite

七、Android 平台上的秒級編譯方案 Freeline

Freeline 可以充分利用緩存檔案,在幾秒鐘内迅速地對代碼的改動進行編譯并部署到裝置上,有效地減少了日常開發中的大量重新編譯與安裝的耗時。Freeline 最快捷的使用方法就是直接安裝 Android Studio 插件。

使用教程:

https://github.com/alibaba/freeline/blob/master/README-zh.md https://github.com/alibaba/freeline

八、性能測試工具 PTS

PTS 可以模拟大量使用者通路業務的場景,任務随時發起,免去搭建和維護成本,支援 JMeter 腳本轉化為 PTS 壓測,同樣支援原生 JMeter 引擎進行壓測。

https://help.aliyun.com/document_detail/70290.html https://www.aliyun.com/product/pts

九、雲效開發者工具 KT

KT 可以簡化在 Kubernetes 下進行聯調測試的複雜度,提高基于Kubernetes的研發效率。

https://yq.aliyun.com/articles/690519 https://yq.aliyun.com/download/3393

十、架構可視化工具 AHAS

AHAS 為 K8s 等容器環境提供了架構可視化的功能,同時,具有故障注入式高可用能力評測和一鍵流控降級等功能,可以快速低成本的提升應用可用性。

服務化改造過程中,想精确的了解資源執行個體的構成和互動情況,實作架構的可視化?

想引入真實的故障場景和演練模型?

低門檻獲得流控、降級功能?

https://help.aliyun.com/document_detail/90323.html https://www.aliyun.com/product/ahas