🎉smart-mqtt v0.28 发布,无边连接无限

来源: 投稿
2023-09-18 08:58:00

1、smart-mqtt 简介

smart-mqtt,是 smartboot 组织下面向物联网的首款解决方案,它使用 Java 语言开发,提供高效、可靠的 MQTT Broker 服务。

smart-mqtt 的独特优势在于大量设备接入的情况下,仍能保持低延迟和高吞吐量,满足物联网领域严苛的实时性需求。同时,smart-mqtt 为了最大限度地节省硬件成本,采用了高度优化的资源管理策略,降低了系统运行时的 CPU 和内存占用,使企业在保持高性能的同时,大幅降低运维成本。

另外,mqtt 协议天然适合 IM 场景,需要打造企业级 IM 应用,smart-mqtt 同样是一个非常好的选择。

smartboot 开源组织,一个容易被误认为是在 “重复造轮子” 的低调组织。曾获得 2020 年度 OSC 中国开源项目「优秀 Gitee 组织 」荣誉。

该组织内的明星项目包括:

  • smart-socket
    历时 5 年精炼出 2 千多行代码,轻松实现百万级长连接的 AIO 通信框架。

  • smart-http
    基于 smart-socket 实现的 HTTP/1.1 web 服务。

  • smart-servlet
    基于 smart-http 实现的 Servlet 3.1 容器服务。

  • smart-mqtt
    基于 smart-socket 实现的 MQTT 3.1.1/5.0 Broker&Client 服务。

  • smart-flow
    一款具备可观测性的轻量级业务编排框架。

组织地址:?https://smartboot.tech/
代码仓库:?https://gitee.com/smartboot

2、 版本更新

【社区版】

  1. bugfix:修复retain消息实现不符合规范的问题。(感谢 springrain-zorm 反馈)

  2. 调整消息总线接口入参设计。

  3. 删除 broker 模块中的 EventObject。

  4. 服务配置项 name 调整为 nodeId。

  5. 移除 BrokerContext#getRuntime 接口。

  6. 调整控制台 Banner 输出时机。

【企业版】

在这轮版本中,smart-mqtt 企业版对集群特性作了一次重构升级。虽说在初始版本中我们便已提供了集群能力,但长久以来一直有个问题困扰着我:如何设计一个简单、稳定的架构,同时又具备无限扩缩容的弹性能力

在万物互联时代,我们将面临的挑战可能是百万、千万,甚至上亿的物联规模。不同的连接规模必然对应着不同规格和数量的服务器资源,当企业业务量发展突破当前平台瓶颈时,如何实现快速、平滑、无感的集群扩容是对架构设计的考验。

在 emqx 5.0 中采用了一种称之为 Mria 的架构,smart-mqtt 也借鉴该设计。

  • 任意 woker 节点收到消息后会转发给与之相连的 core 节点;

  • 该 core 节点再分发至集群中的其他 core 节点;

  • core 节点需把其他 core 节点投递过来的消息转发至与自身相连的 worker 节点,再通过 worker 节点推送至符合订阅条件的客户端。

测试效果:

通过 docker-compose 快速搭建一套由 4 个 core 节点,6 个 worker 节点组成的集群。

集群拓扑如下:

 

3、性能测试报告

  • 场景一:
    10 个 publisher 每隔 1 毫秒发送 payload 为 128 字节的消息,这些消息分布在 128 种 topic 下,有 2000 个 subscriber 订阅这些 topic 的消息。

  smart-mqtt
QoS0 300W/s
QoS1 160W/s
QoS2 80W/s
  • 场景二:

2000 个 publisher 每隔 1 毫秒发送 10 个 payload 为 128 字节的消息,这些消息分布在 128 种 topic 下。

  smart-mqtt
QoS0 93W/s
QoS1 55W/s
QoS2 40W/s

4、如何获取 smart-mqtt

4.1 源码

4.2 Maven 依赖

  • mqtt broker

<dependency>
    <groupId>org.smartboot.mqtt</groupId>
    <artifactId>smart-mqtt-broker</artifactId>
    <version>0.28</version>
</dependency>
  • mqtt client

<dependency>
      <groupId>org.smartboot.mqtt</groupId>
      <artifactId>smart-mqtt-client</artifactId>
      <version>0.28</version>
</dependency>

4.3 发行包

5. 关于 smart-mqtt 企业版

smart-mqtt 目前是由个人开发者在业余时间维护,暂无提供商业化服务的计划。

出于项目的可持续发展需要,我们在 smart-mqtt 社区版的基础上,丰富了一些企业级功能。如果贵公司认可 smart-mqtt 的价值,可以通过成为赞助商获得企业版授权。

功能特性

  1. 企业版 License 认证。授权过期将无法启动服务,但并不会因授权过期影响正在运行的 Broker。

  2. MQTT over WebSocket。

  3. Broker 集群部署。

  4. 管理后台

  5. 指标数据持久化(H2、MySQL)

  6. 数据桥接:redis、kafka

  7. 未完待续...

赞助商等级

  青铜赞助商 白银赞助商 黄金赞助商 铂金赞助商
赞助条件 加入企业支持计划 500 元 / 年 1500 元 / 年 5000 元 / 年
License 有效期 1 年 1 年 1 年 1 年
部署指导 - 1 次 1 次 不限次数
Logo 展示位 - 小号 中号 大号
首页 Logo 展示 - - -
技术支持 文档 邮件 /ISSUE 微信 / QQ / 邮件 微信 / QQ / 邮件

白银赞助商的价值:

  • 成本:500 元 / 年,相当于一名初中级程序员一天的薪资。

  • 产出效益:

    • 增加品牌曝光率。

    • 节省投入在 Sass 云服务中的巨额资费。

    • 结交更多物联网领域的从业者。

成为赞助商遵循双方自愿原则,我们会在能力范围内尽可能提供 smart-mqtt 相关的技术支持。与此同时因时间和精力有限,我们也并不希望由此带来额外的负担,影响到项目的正常迭代。

所以,如有疑问尽量通过 ISSUE 交流,或者通过 ISSUE 和官方文档自助寻找答案,还望理解~~

ISSUE:?https://gitee.com/smartboot/smart-mqtt/issue

展开阅读全文
点击加入讨论🔥(1) 发布并加入讨论🔥
1 评论
1 收藏
分享
返回顶部
顶部