您现在的位置是:首页 > 文章详情

DamiBus 0.56,本地多模块调用框架(1000 万/秒)

日期:2023-12-12点击:82

DamiBus,专为本地多模块之间通讯解耦而设计(尤其是未知模块、隔离模块、领域模块)。零依赖。

特点

结合 Bus 与 RPC 的概念,可作事件分发,可作接口调用,可作响应订阅。

  • 支持事务传导(同步分发、异常透传)
  • 支持事件标识、拦截器(方便跟踪)
  • 支持监听者排序、附件传递(多监听时,可相互合作)
  • 支持 Bus 和 Api 两种体验风格

与常见的 EventBus、ApiBean 的区别

  DamiBus EventBus Api DamiBus 的情况说明
广播 发送(send) + 监听(listen)
以及 Api 模式
应答 发送并请求(sendAndRequest) + 监听(listen) + 答复(reply)
以及 Api 模式
回调 有+ 有- 发送并订阅(sendAndSubscribe) + 监听(listen) + 答复(reply)
耦合 弱- 弱+ 强++  

如果涉及类加载器隔离:请在主程序标为编译,在其它模块标为可选。

本次更新了什么?

  • 添加 DamiBus::sendAndRequest 带超时的接口
  • solon 升为 1.6.2

性能测试?

瞬发 1000万个事件,1秒左右可发完(基于 jdk11 测试):

 public class SendTest { static Integer count = 0; public static void main(String[] args) { Dami.bus().listen("test.demo", e -> { count = count + 1; }); long start = System.currentTimeMillis(); for (int i = 0; i < 10_000_000; i++) { Dami.bus().send("test.demo", "1"); } System.out.println(System.currentTimeMillis() - start + "::" + count); } } 

疑问: 为什么不用分布式消息队列呢?不好意思,真的是不同的维度事儿。

项目地址

原文链接:https://www.oschina.net/news/270702/damibus-0-56-released
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章