近期参加了阿里云官方的一个开发者工具有奖评测活动,感兴趣的朋友可以去官网了解下,以下是我对这款工具的使用体验,欢迎各位朋友进行交流和斧正。
Alibaba Cloud Toolkit(以下简称工具集)是阿里中间件团队发布的一款面向阿里云服务的开发工具集,用来提升开发者使用阿里云产品时的用户体验。本文将对使用该工具集部署EDAS应用的各种能力进行一番评测。Alibaba Cloud Toolkit主要包含三种类型的工具,分别是IDE插件(目前仅支持Eclipse,IDEA插件据说正在开发中,很快会发布)、Maven插件和命令行工具。在对这三种类型的工具进行详细评测之前,我们先来了解一下使用Web界面部署普通EDAS应用的过程。
第一步,需要先申请一些ECS并将这些ECS导入到已经创建的集群中。
图1. 集群和集群中的ECS
第二步,创建应用。
在创建应用的时候选择使用该集群,并选择集群中的ECS作为部署目标。同时打开“立即部署”选项,再选择应用部署方式、应用运行环境和Java环境等,然后上传部署包,在确定了版本以及批次和分批方式后,就可以创建并部署应用了(图2)。
图2. 创建并部署应用
这个过程看似简单,却有如下一些问题。首先,界面是基于Web的,虽然简单易用,但是自动化能力不强,需要人为干预才能工作,效率不高;其次,用户需要自己打包和上传部署文件,导致开发和部署过程割裂。有了上面一些对EDAS传统部署过程的了解,我们再分别使用工具集中的不同工具来尝试重新部署应用,看看会有什么不同。
- IDE插件
通常而言,开发人员都会使用IDE来提升软件的开发效率,因此Alibaba Cloud Toolkit提供基于主流IDE的扩展插件就是顺其自然的事情,拿Eclipse为例,在Eclipse市场中就能搜索到Alibaba Cloud Toolkit,该插不仅支持EDAS,也有很多其他的功能,但这里我们主要关注面向EDAS的集成能力。
安装好插件以后,导入一个项目(可以是原生Dubbo,原生Spring Cloud或HSF项目),然后在Project Explore窗口右键点击该项目,会出现Alibaba Cloud上下文菜单,选择该菜单项后会出现Deploy to EDAS…子菜单项(图3)。
图3. Alibaba Cloud菜单及子菜单
如果是第一次使用该插件,会弹出一个设置窗口(图4)用来设置访问账户所需的Access Key ID和Access Key Secret,设置完成以后就会出现Deploy to EDAS窗口(图5)。
图4. 设置访问账户的Access Key ID和Access Key Secret
图5. 部署应用
该窗口的主要功能一目了然,选择Region、Namespace、Application和Group后,点击Deploy即开始部署。
该插件的优势正如前文所言,解决了开发到部署过程上下文切换的问题,可以在一个场景下完成这两种工作。而劣势(或者说功能的不足)是其能力还不能完全与传统的基于Web部署过程对齐:比如无法选择批次、分配方式,以及在第一次部署的时候无法选择容器和Java版本等等,希望未来的版本能够加以改进。
- Maven插件
使用Java的开发人员多数会使用Apache Maven来管理依赖、编译、测试、打包和发布等过程,因此Alibaba Cloud Toolkit也提供了与Maven的集成能力,即edas-maven-plugin。有关配置和使用方法,在官网的《通过 edas-maven-plugin 插件自动化部署应用》文档中已经有详细说明,就不在此赘述。
比起IDE插件来说,Maven插件能够更有效的解决自动化问题,尤其是跟持续集成与持续交付系统对接的时候更为有用。在一个配置完善的自动化系统中,开发人员将开发完成的代码提交到代码仓库,此时可以自动触发应用的构建、单元测试与打包,打包好的交付物会通过edas-maven-plugin部署到测试环境,运行一遍冒烟测试之后,再被部署到预发环境供测试人员测试。整个过程可以做到完全无人值守。
该Maven插件也同样存在很多不尽如人意的地方,比如配置项中需要使用应用或分组的ID来指定部署目标,虽然在Web界面上提供有相关的配置可以复制粘贴,但是依然不如直接使用名称来得方便。另外在执行mvn edas:deploy命令的时候必须要在package阶段之后(即命令必须为mvn package edas:deploy),否则无法找到要部署的包。最后同IDE插件遇到的问题相同,如果只有一个空应用,而没有指定过该应用的容器和Java版本的话,那么使用Maven插件部署的时候可能会出现问题。希望这些不足能够在未来的版本中得到解决。
- 命令行工具
命令行工具在整个Alibaba Cloud Toolkit里面是功能最强大的,当然也是使用门槛最高的,我们来分别了解一下。
说其功能强大,是因为命令行工具是对EDAS Open API的封装,因此只要是接口中提供的功能,都可以使用命令行工具来调用。这个功能并不算新颖,以前在没有提供命令行工具的时候,一些用户也会通过使用Python脚本调用Open API的方式来达到相同的目的,只是官方提供了这个能力之后,对于大部分的开发者而言减少了这部分的工作量。再者,该命令行工具是与aliyun这个命令集成到一起的,因此如果企业对自动化运维有很高要求的话,使用aliyun edas这个子命令可以避免绝大多数的手动操作,包括但不限于创建命名空间、创建集群、集群导入、创建应用以及部署应用、创建分组、应用生命周期管理等等。增强自动化且提高运维效率的同时,更多的可以避免因人为操作失误而导致的安全生产风险,间接提高了产品质量。有关命令行工具的具体配置和使用方法请参考文档《使用CLI快速部署EDAS应用》。
说其使用门槛高,主要在于单一命令只能完成一个原子操作,且操作过程大多是异步的,这就要求实现复杂功能的时候需要编写脚本来完成执行结果的轮询与命令串联。虽然这些工作对于开发人员来说算不上什么问题,但是总之是有可改进空间的。
以上便是Alibaba Cloud Toolkit提供的针对EDAS产品的全部功能的试用体验以及对其优点和现有不足的分析,鉴于笔者水平有限,提出的问题点并不一定完全准确。总而言之,该工具集的出现确实在很大程度上提升了开发人员的工作效率,也让各种CI/CD以及自动化运维等能力成为可能,确实是一个值得企业用户尤其是开发者用户去尝试的优秀工具集。