Skip to content

轻量级消息队列,无延迟分发,支持消费组和消息去重,不支持集群部署

License

Notifications You must be signed in to change notification settings

NewLifeX/NewLife.MQ

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

26 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

消息队列 NewLife.MQ

NewLife.MQ 是一个轻量级消息队列,无延迟分发,支持消费组和消息去重,不支持集群部署。

主要特点:

  • 轻量级。服务端和客户端都是通过nuget引用NewLife.MQ即可,也可以在Windows上直接安装发行版NewLife.MQServer
  • 低延迟。默认不做持久化,发布消息后直接分发到目标队列,客户端长连接实时消费。(特别适用于跨系统异步通信)
  • 消费者。支持广播消息给多个消费者。
  • 消息延迟和去重。支持延迟消息,支持对重复发送的消息进行去重,降低消费成本。

2019-02-20 v2.0混合测试通过

1, 实现了基础的发送与消费
2, 每个Topic下有一个队列,目前使用并行字典实现,自增消息ID为key,便于查找和删除 3, 每个消费组(相同登录用户)记录消费偏移量

// 初始化客户端
var client = new MQClient
{
    Servers = new[] { "tcp://127.0.0.1:6789" },
    Log = XTrace.Log,

    Topic = "测试主题",
};

// 发布消息
var msgid = client.Public("发布测试").Result;
XTrace.WriteLine("msgid={0}", msgid);

// 消费消息
client.OnConsume = msgs =>
{
    foreach (var item in msgs)
    {
        XTrace.WriteLine("消费到 {0}", item);
    }
};
client.StartConsume();

主要术语:

  • MQHost 消息队列主机,管理多主题的订阅和发布
  • Topic 主题队列,每个主题有一个队列用于缓冲保存消息,同时记录多个消费者
  • Consumer 消费者,发布到主题的消息,会广播给各个消费者。多个订阅者构成消费者集群,消息只推送给其中一个订阅者。
  • Subscriber 订阅者,使用相同消费者标识的不同来源,视为不同订阅者,比如同一个消费者账号的不同网络连接。

新生命开源项目矩阵

各项目默认支持net4.5/net4.0/netstandard2.0

项目 年份 状态 .NET Core 说明
基础组件 支撑其它中间件以及产品项目
NewLife.Core 2002 维护中 算法、日志、网络、RPC、序列化、缓存、多线程
XCode 2005 维护中 数据中间件,MySQL、SQLite、SqlServer、Oracle
NewLife.Net 2005 维护中 网络库,千万级吞吐率,学习gRPC、Thrift
NewLife.Cube 2010 维护中 Web魔方,权限基础框架,集成OAuth
中间件 对接各知名中间件平台
NewLife.Redis 2017 维护中 Redis客户端,微秒级延迟,百亿级项目验证
NewLife.RocketMQ 2018 维护中 支持Apache RocketMQ和阿里云消息队列
NewLife.Thrift 2019 维护中 Thrift协议实现
NewLife.Hive 2019 维护中 纯托管读写Hive,Hadoop数据仓库,基于Thrift协议
NewLife.MQ 2016 维护中 轻量级消息队列
NoDb 2017 开发中 NoSQL数据库,百万级kv读写性能,持久化
NewLife.Cache 2018 维护中 自定义缓存服务器
NewLife.Ftp 2008 维护中 Ftp客户端实现
NewLife.MySql 2018 开发中 MySql驱动
产品平台 产品平台级,编译部署即用,个性化自定义
AntJob 2019 开发中 蚂蚁调度系统,大数据实时计算平台
Stardust 2018 开发中 星尘,微服务平台,分布式平台
XLink 2016 维护中 物联网云平台
XProxy 2005 维护中 产品级反向代理
XScript 2010 维护中 × C#脚本引擎
NewLife.DNS 2011 维护中 × DNS代理服务器
NewLife.CMX 2013 维护中 × 内容管理系统
SmartOS 2014 保密中 C++11 嵌入式操作系统,完全独立自主,ARM Cortex-M芯片架构
GitCandy 2015 维护中 × Git管理系统
其它
XCoder 2006 维护中 × 码神工具,开发者必备
XTemplate 2008 维护中 × 模版引擎,T4(Text Template)语法
X组件 .NET2.0 2002 存档中 .NET2.0 日志、网络、RPC、序列化、缓存、Windows服务、多线程
X组件 .NET4.0 2002 存档中 .NET4.0 日志、网络、RPC、序列化、缓存、Windows服务、多线程

新生命开发团队

网站:http://www.NewLifeX.com 博客:https://nnhy.cnblogs.com QQ群:1600800

About

轻量级消息队列,无延迟分发,支持消费组和消息去重,不支持集群部署

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages