Apache基金会总结RocketMQ:中国70%的银行核心业务已采用,国内技术人员贡献明显增多(21)

发布于2019-04-21 20:14:35

Apache生态利用社区建立了一种极其有效的开放式创新Apache Way,旨在通过社区声音、邮件列表以及项目管理委员会完成对Apache产品的快速迭代。 Apache RocketMQ项目管理委员会成员Von Gosling对RocketMQ这款企业级产品在项目和社区上的项目前景进行了分享和介绍,本文通过他的分享也希望读者能更多地参与Apache社区的推广和问题解决。

2018年Von Gosling发表了一篇文章来自非英语国家的社区如何理解并使用Apache方式进行开放式创新,表达了开发人员希望有一个开放的社区环境,善于使用邮件列表,能倾听社区的声音并及时做出响应和决定。本文,Von Gosling通过一些实际的例子分享了一些Apache RocketMQ社区建设和如何协作创新的故事。

Apache RocketMQ前景

Apache RocketMQ最初是用在线电子商务事务处理的分布式消息传递引擎,可以在许多公司的生产环境中进行数十亿甚至数万亿的信息传输。

优点

RocketMQ正在尝试去补充一些还未能在企业级进行支持的核心功能。

新功能

去年,RocketMQ社区宣布了三个有吸引力的功能:事务性消息消息跟踪身份验证和授权

Apache生态

问题

在采用消息传递机制的企业级应用程序中,始终存在一个令人不安的问题:我的信息发送到哪里了? 消费者接收成功或失败,我如何找到消息历史?这是一项非常困难的任务,特别是当提供云发布/订阅服务时,因为消息传递是一种异步解耦过程,上游和下游相互之间并不了解。

一个例子

幸运的是,中国移动研究院的一些人在Apache RocketMQ Meetup上找到了项目管理委员会(PMC)的成员,并告知了他们碰到的问题。PMC成员向他们推荐了社区中最新的RIP计划,这项计划是Apache RocketMQ内部代码非常有挑战性的一次优化和改进。在PMC成员的帮助下,他们一起补充、讨论并接受了这项改进计划。Von Gosling透露到,经过一段必要的时间规划,RocketMQ开始设计、编码和讨论,交换代码并实现细节。其中包括几个聚会,聚集在一起讨论和审查代码,直到后来的在线验证和发布。更有意义的是,在审核过程中,来自社区的另一个云供应商还参加了进来。通过简单的视频通信,最初的实现被优化并解决了兼容性问题。在社区中,最后的新版本由两家云供应商在生产中进行了验证。通过ACL提供的功能,PMC和社区持续协作,最终发布了RIP计划的最终版本。

社区的工作

通过聚会收集要求,通过公开讨论,再加上使用Zoom的视频通信,RocketMQ社区在去年完成了几个重要的发布。同时,为了更好地促进生态繁荣,还对Apache RocketMQ外部存储库下的几个项目进行了重组(80%以上是在孵化期间由社区贡献的项目)。除了设定里程碑,增加了类似的孵化和毕业机制,进一步降低了社区参与的难度,同时更好地保证了产品质量。今天,已经毕业的几个不同语言的SDK项目来自大量使用和维护的用户,社区的热情甚至超越了想法。它还验证了未来的云架构是独立于语言的,甚至是无服务器的。在这一大趋势下,社区积极参与了RocketMQ多语言生态建设。RocketMQ现在支持java、cpp、python、go、nodejs,其他语言也在计划中。目前的CPP客户端最多可支持8个平台,如CentOS、MacOS、Ubuntu和Windows。

RocketMQ社区

不仅如此,越来越多的社区爱好者也自发地组织起来:他们积极地策划城市车站等类似活动,也需要PMC给予一些关注和鼓励。与此同时,Apache也在思考社区是否应该有类似发布经理一样面向开发人员的角色,比如开发人员关系维护者或项目经理,以便获得更多用户的理解,更多地参与到产品中来。近年来社区的发展也给RocketMQ社区带来了许多新的气象,出现了越来越多的活跃开发者。在最近的大约三个月内,从dev电子邮件列表发送了近2,000封电子邮件。研究表明,中国70%的顶级银行在核心业务链接上使用Apache RocketMQ,大约60%的互联网金融和保险客户在其生产环境中使用RocketMQ,中国20强互联网公司中75%广泛采用经典的pub/sub场景。

最近,RocketMQ社区一直在讨论下一代消息传递平台的开发。Von Gosling表示,RocketMQ希望它会是一个带有轻量级数据处理平台的统一消息传递引擎,并欢迎大家参与其中,告诉PMC您在未来版本的RocketMQ中期待看到哪些功能。