本文主要是介绍FolkMQ v1.5.1 发布(“新式”国产消息中间件),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
FolkMQ 是个“新式”的消息中间件。强调:“小而巧”、“简而强”。
功能简表
角色 | 功能 |
---|---|
生产者(客户端) | 发布普通消息、Qos0消息、定时消息、顺序消息、可过期消息、事务消息、广播消息 |
消费者(客户端) | 订阅、取消订阅。消费-ACK(自动、手动) |
服务端 | 发布-Confirm、订阅-Confirm、取消订阅-Confirm、派发-Retry、派发-Delayed |
客户端语言支持
Java、Python、JavaScript(支持 node.js 后端,web 前端)
传输协议支持
tcp、udp、websocket、kcp
部署支持
可内嵌(依赖包为 200Kb+),可单机,可集群(部署包为 10Mb)。
本次更新
- 新增 广播消息(给生产者添加广播模式)
- 添加 控制台“强制清空”消息的操作
- 添加 “fokmq:ws” 适配 websocket 子协议验证(避免乱连)
- 添加 “server-broker” 控制台的集群节点面板添加“内存用率”查看
- 优化 异步消息生产端的内存控制
- 优化 客户端锁处理,默认无锁改为顺序锁
- sokcet.d 升为 2.5.1
面向简单编程
1) 启动服务
docker run -p 18602:18602 -p 8602:8602 noearorg/folkmq-server:1.5.1
2) 编写程序
- 引入一个小依赖
<dependency><groupId>org.noear</groupId><artifactId>folkmq-transport-netty</artifactId><version>1.5.1</version>
</dependency>
- 写程序喽
public class ClientDemo {public static void main(String[] args) throws Exception {//创建客户端,并连接MqClient client = FolkMQ.createClient("folkmq://127.0.0.1:18602").nameAs("demoapp").connect();//订阅主题client.subscribe("demo.topic", message -> {System.out.println(message);});//发布普通消息client.publish("demo.topic", new MqMessage("helloworld!"));//发布Qos0消息client.publish("demo.topic", new MqMessage("helloworld!").qos(0));//发布顺序消息client.publish("demo.topic", new MqMessage("helloworld!").sequence(true));//发布广播消息client.publish("demo.topic", new MqMessage("helloworld!").broadcast(true));//发布定时消息(或延时消息)client.publish("demo.topic", new MqMessage("helloworld!").scheduled(Datetime.Now().addDay(10)));//......等}
}
代码仓库
- https://gitee.com/noear/folkmq
- https://github.com/noear/folkmq
官网
- https://folkmq.noear.org
这篇关于FolkMQ v1.5.1 发布(“新式”国产消息中间件)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!