FolkMQ 1.6.0(纯血国产,适合信创)

folkmq · 浏览次数 : 16

小编点评

**FolkMQ消息中间件** FolkMQ是一个“新式”的消息中间件,强调“简而强”。它具有内嵌、单机、集群等多种部署方式,功能丰富,适用于不同场景。 **主要功能** - **生产者**:发布普通消息、Qos0消息、定时消息、顺序消息、可过期消息、事务消息和广播消息。 - **消费者**:订阅、取消订阅。 - **流量控制**:客户端流量控制支持(trafficLimiter),可控制客户端内存占用。 **支持客户端语言** - Java - Python - JavaScript(支持Node.js后端,Web前端) **传输协议** - tcp - udp - websocket - kcp **更新亮点** 1. **控制台流量看板**:提供客户端流量控制功能,帮助开发者实时了解客户端连接情况。 2. **确认机制优化**:FolkMQ服务器启用新的确认机制,降低内存占用。 **问题修复** - 修复了python SDK批量订阅无效的问题。 - 修复了javascript SDK批量订阅无效的问题。 **版本更新** - socket.d 升级至 2.5.4 **面向简单编程** 1. **启动服务**:使用Docker容器化部署FolkMQ服务器,设置端口映射。 2. **编写程序**:引入FolkMQ-transport-netty依赖,编写简单的客户端程序进行测试。 **代码和资源** - 代码仓库:[GitHub](https://github.com/noear/folkmq) - 官网:[FolkMQ Noear](https://folkmq.noear.org) FolkMQ作为一个简洁强大的消息中间件,凭借其丰富的功能和持续优化的更新,成为了许多开发者和系统架构师的首选。

正文

FolkMQ 是个“新式”的消息中间件。强调:“简而强”。可内嵌,可单机,可集群(部署包为 9Mb)。

功能简表

角色 功能
生产者(客户端) 发布普通消息、Qos0消息、定时消息、顺序消息、可过期消息、事务消息、广播消息
消费者(客户端) 订阅、取消订阅。消费-ACK(自动、手动)
服务端 发布-Confirm、订阅-Confirm、取消订阅-Confirm、派发-Retry、派发-Delayed

客户端语言支持

Java、Python、JavaScript(支持 node.js 后端,web 前端)

传输协议支持

tcp、udp、websocket、kcp

本次更新

  • 新增 控制台 “流量看板”
  • 新增 客户端流量控制支持(trafficLimiter),可控制客户端内存占用
  • 优化 folkmq-server 启用新的确认机制(向下兼容),可减少内存占用
  • 修复 python sdk 批量订阅无效的问题
  • 修复 javascript sdk 批量订阅无效的问题
  • socket.d 升为 2.5.4

面向简单编程

1) 启动服务

docker run -p 18602:18602 -p 8602:8602 noearorg/folkmq-server:1.6.0

2) 编写程序

  • 引入一个小依赖
<dependency>
    <groupId>org.noear</groupId>
    <artifactId>folkmq-transport-netty</artifactId>
    <version>1.6.0</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)));
        //......等
    }
}

代码仓库

官网

与FolkMQ 1.6.0(纯血国产,适合信创)相似的内容: