
从人工到自动化,从重复到创新,技术演进的历程中,伴随着开发者工具类产品的发展。阿里巴巴将自身在各类业务场景下的技术积淀,通过开源、云上实现或工具等形式对外开放,本文将精选了一些阿里巴巴的开发者工具,希......
从人工到自动化,从重复到创新,技术演进的历程中,伴随着开发者工具类产品的发展。
阿里巴巴将自身在各类业务场景下的技术积淀,通过开源、云上实现或工具等形式对外开放,本文将精选了一些阿里巴巴的开发者工具,希望能帮助开发者们提高开发效率、更优雅的写代码。
由于开发者涉及的技术领域众多,笔者仅从自己熟悉的领域,以后端开发者的视角盘点平时可能用得到的工具。
每个工具按照以下几点进行介绍:
1.工具名称和简介
2.使用场景
一、Java线上诊断工具Arthas
Arthas阿里巴巴2018年9月开源的一款Java线上诊断工具。
工具的使用场景:
1.这个类从哪个jar包加载的?为什么会报各种类相关的Exception?
2.我改的代码为什么没有执行到?难道是我没commit?分支搞错了?
3.遇到问题无法在线上debug,难道只能通过加日志再重新发布吗?
4.线上遇到某个用户的数据处理有问题,但线上同样无法debug,线下无法重现!
5.是否有一个全局视角来查看系统的运行状况?
6.有什么办法可以监控到JVM的实时运行状态?
Arthas支持JDK6+,支持Linux/Mac/Windows,采用命令行交互模式,同时提供丰富的Tab自动补全功能,进一步方便进行问题的定位和诊断。
二、IDE插件CloudToolkit
CloudToolkit是一款IDE插件,可以帮助开发者更高效地开发、测试、诊断并部署应用。通过CloudToolkit,开发者能够方便地将本地应用一键部署到任意机器(本地或云端),并内置Arthas诊断、高效执行终端命令和SQL等,提供IntelliJIDEA版,Eclipse版,PyCharm版和Maven版。
1.每次修改完代码后,是否正在经历反复地打包?
2.在Maven、Git以及其他运维脚本和工具的之间频繁切换?
3.采用SCP工具上传?使用XShell或SecureCRT登陆服务器?替换部署包?重启?
4.文件上传到服务器指定目录,在各种FTP、SCP工具之间频繁切换?
三、混沌实验注入工具ChaosBlade
ChaosBlade是一款遵循混沌工程实验原理,提供丰富故障场景实现,帮助分布式系统提升容错性和可恢复性的混沌工程工具,可实现底层故障的注入,提供了延迟、异常、返回特定值、修改参数值、重复调用和try-catch块异常等异常场景。
1.微服务的容错能力不易衡量?
2.容器编排配置是否合理无法验证?
3.PaaS层健壮性的测试工作无从入手?
四、Java代码规约扫描插件
该插件用于检测Java代码中存在的不规范的位置,并给予提示。规约插件是采用Kotlin语言开发。
五、应用实时监控工具ARMS
ARMS是一款APM类的监控工具,提供前端、应用、自定义监控3类监控选项,可快速构建实时的应用性能和业务监控能力。
1.晚上10点收到37条报警信息,你却无从下手?
2.当我们发现问题的时候,客户/业务方已经发起投诉?
3.每个月花几十万买服务器,却无法保障用户体验?
六、静态开源站点搭建工具Docsite
Docsite一款集官网、文档、博客和社区为一体的静态开源站点的解决方案,具有简单易上手、上手不撒手的特质,同时支持react和静态渲染、PC端和移动端、支持中英文国际化、SEO、markdown文档、全局站点搜索、站点风格自定义、页面自定义等功能。
七、Android平台上的秒级编译方案Freeline
Freeline可以充分利用缓存文件,在几秒钟内迅速地对代码的改动进行编译并部署到设备上,有效地减少了日常开发中的大量重新编译与安装的耗时。Freeline最快捷的使用方法就是直接安装AndroidStudio插件。
八、性能测试工具PTS
PTS可以模拟大量用户访问业务的场景,任务随时发起,免去搭建和维护成本,支持JMeter脚本转化为PTS压测,同样支持原生JMeter引擎进行压测。
九、云效开发者工具K
KT可以简化在Kubernetes下进行联调测试的复杂度,提高基于Kubernetes的研发效率。
十、架构可视化工具AHAS
AHAS为K8s等容器环境提供了架构可视化的功能,同时,具有故障注入式高可用能力评测和一键流控降级等功能,可以快速低成本的提升应用可用性。
1.服务化改造过程中,想精确的了解资源实例的构成和交互情况,实现架构的可视化?
2.想引入真实的故障场景和演练模型?
3.低门槛获得流控、降级功能?
十一、数据处理工具EasyExcel
EasyExcel是一个用来对Java进行解析、生成Excel的框架,它重写了poi对07版Excel的解析,原本一个3M的Excel用POIsax需要100M左右内存,EasyExcel可降低到KB级别,并且再大的excel也不会出现内存溢出的情况。03版依赖POI的sax模式。在上层做了模型转换的封装,让使用者更加简单方便。
十二、iOS类工具HandyJSON
HandyJSON是一个用于Swift语言中的JSON序列化/反序列化库。与其他流行的SwiftJSON库相比,HandyJSON的特点是,它支持纯Swift类,使用也简单。它反序列化时(把JSON转换为Model)不要求Model从NSObject继承(因为它不是基于KVC机制),也不要求你为Model定义一个Mapping函数。只要你定义好Model类,声明它服从HandyJSON协议,HandyJSON就能自行以各个属性的属性名为Key,从JSON串中解析值。
十三、云上资源和应用部署工具EDASServerless
EDASServerless一款基于Kubernetes,面向应用和微服务的Serverless平台。用户无需管理和维护集群与服务器,即可通过镜像、WAR包和JAR包,快速创建原生支持Kubernetes的容器应用,同时支持SpringCloud和Dubbo等主流微服务框架。
十四、数据库连接池Druid
Druid是Java语言下的数据库连接池,它能够提供强大的监控和扩展功能。
十五、Java工具集Dragonwell
AlibabaDragonwell是阿里巴巴内部OpenJDK定制版AJDK的开源版本,AJDK为在线电商,金融,物流做了结合业务场景的优化,运行在超大规模的,100,000+服务器的阿里巴巴数据中心。AlibabaDragonwell与JavaSE标准兼容,目前仅支持Linux/x86_64平台。