Hmily 分布式事务重启月度报告

公众号程序猿DD

共 2003字,需浏览 5分钟

 ·

2020-09-13 11:53


点击上方蓝色“程序猿DD”,选择“设为星标”

回复“资源”获取独家整理的学习资料!

Hmily重启后月度报告

Hmily是一款高性能,高可靠,易使用的柔性分布式事务解决方案,目前提供了对dubbo,spring-cloud,motan,grpc等rpc框架的支持,在易用性上提供零侵入性式的 Spring-Boot, Spring-Namespace 快速集成,目标是打造金融级的一体系分布式事务解决方案。

调整Hmily架构,更合理的模块划分

全景图:

架构调整:

  • 抽离核心执行模块,支持多种事务模式以及混合使用(TCC模式,TAC模式)
  • 核心模块去除对spring的依赖
  • 定义多种SPI接口的实现
  • 新增 hmily-rpc : 聚合多种rpc框架的支持
  • 新增 hmily-spi : hmily框架自定义spi机制实现
  • 新增 hmily-bom : 解决版本依赖管理冲突的问题
  • 新增 hmily-metrics : 监控JVM,线程,事务运行状态,耗时等信息
  • 新增 hmily-tcc : tcc模式的核心实现
  • 新增 hmily-tac : tac模式的核心实现

SPI模块划分:

  • 新增 hmily-repository: 事务日志存储模块,支持(mysql,oracle,postgresql,sqlserver,zookeeper,redis,mongodb,file)
  • 新增 hmily-serializer: 事务日志序列化模块, 支持 (hessian,jdk,kryo,protobuf)
  • 新增 hmily-config:配置模块,支持(本地模式,zookeeper,nacos,apollo,etcd)
  • 新增 hmily-tac-sqlparser :tac模式下,sql解析模块

梳理Hmily社区issue,解决bug。

如上图:在社区中,主要是梳理和解决之前社区反馈的问题,以及社区合作进行新的开发。

解决bug(列举几个):
  • dubbo框架不支持注解方式的使用(spring-boot-starter-dubbo)
  • motan框架不支持注解方式的使用
  • spring-cloud用户如果使用feign与hystrix整合hmily时候的异常问题
  • 事务日志序列化异常
  • 超时异常事务悬挂bug
  • 事务定时恢复bug
社区完成功能(列举几个):
  • build:新增travis-ci功能
  • 事务日志存储:新增oracle,postgresql,sqlsever,mongo,zookeeper,file,redis方式支持
  • 配置模块:新增apollo,etcd,nacos配置中心支持
  • demo:新增motan-rpc方式使用hmily分布式事务demo

社区共建

社区奉行简单,快乐,优雅,和谐基本原则。

  • 代码准则:代码遵循hmily-checkstyle标准,也有很多灵活自由的空间。(talk is cheap ,show you code)
  • 开放准则:希望在这里每个人都有好的思想和观点,大家一起讨论,反复review代码,思考解决bug,快乐成长,绝不搞一言堂。

最近

会发布最新架构的hmily-2.1.0版本(只会支持TCC模式)

配置模块

  • 配置动态刷新功能,支持所有的配置中心

TAC模式:

  • SQL-parser: 正在接入apache-shardingsphere,apache-calcite
  • SQL-revert:正在开发

大约在冬季

很高兴来了这里季节,在这个时间点,会发布hmily-2.2.0版本,这个版本将完全支持TAC,TCC模式。TAC(transaction auto rollback) :有了这个模式,用户再也不用担心像TCC那样去写反向的cancel方法了。大大减少了使用成本以及学习成本。TCC: 稳定性,可靠性得到大大加强,彻底务悬挂问题。

以后的以后

  • 更多RPC框架的支持:brpc等等。
  • 支持 XA模式。

.....这里空起来,很多多的规划,希望你来参与建设。

  • github:https://github.com/dromara/hmily
  • gitee:https://github.com/shuaiqiyu/hmily
  • qq群: 162614487


往期推荐

Serverless 初体验:快速开发与部署一个Hello World(Java版)

短信验证码登录的实现流程

老司机给我们解读 Spring Boot 最流行的 16 条实践忠告

赠书:面向对象的两大迷思,再给你们解答一次

程序员接私活完整攻略+赠开源管理系统


我们在星球聊了很多深度话题,你不来看看?

我的星球是否适合你?

点击阅读原文看看我们都聊过啥?

浏览 27
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报