用Redis作为消息队列的使用方法——附C#源码

消息队列概念

文章源码Github地址:https://github.com/yangwohenmai/TEST/tree/master/Redis

在Redis中,消息队列的用法称之为 redis的 发布/订阅,以下是官方文档的介绍

redis的另一个常见用法是作为 发布/订阅消息分发工具;
这也很简单,并且在连接失败的情况下, ConnectionMultiplexer 将处理重新订阅所请求的信道的所有细节。

ISubscriber sub = redis.GetSubscriber();

同样,从 GetSubscriber 返回的对象是一个不需要存储的低成本的通道对象。
发布/订阅 API没有数据库的概念,但和之前一样,我们可以选择的提供一个异步状态。
注意,所有订阅都是全局的:它们不限于 ISubscriber 实例的生命周期。
redis中的 发布/订阅 功能使用命名的“channels”; channels 不需要事先在服务器上定义(这里有一个有趣的用法是利用每个用户的通知渠道类驱动部分的实时更新)
如在.NET中常见的,订阅采用回调委托的形式,它接受通道名称和消息:

sub.Subscribe("messages", (channel, message) => {
    Console.WriteLine((string)message);
});

另外(通常在一个单独的机器上的一个单独的进程),你可以发布到该通道:

sub.Publish("messages", "hello");

这将(实际上瞬间)将“hello”写到订阅进程的控制台。 和之前一样,通道名和消息都可以是二进制的。

有关顺序和并发消息处理的使用文档说明,请参见 发布/订阅消息顺序


消息队列使用方法

消息队列要用到StackExchange.Redis.dll

可以到文章开头的github上下载下来,在bin文件夹里。

using ServiceStack.Redis;
using StackExchange.Redis;
using System;
using System.Threading;

namespace RedisMessageQueen
{
    [Serializable]
    public class Student
    {
        public string id;
        public string name;
    }
    class Program
    {
        //static ConnectionMultiplexer redisClient = ConnectionMultiplexer.Connect("localhost");
        static ConnectionMultiplexer redisClient = ConnectionMultiplexer.Connect("127.0.0.1:6379");

        static void Main(string[] args)
        {
            ISubscriber sub = redisClient.GetSubscriber();

            #region 消息队列方法1,自己发消息自己取数据
            //建立一个监听对象,监听通道名为messages
            //这部分相当于服务端
            sub.Subscribe("messages", (channel, message) =>
            {
                //收到消息后将消息显示出来
                Console.WriteLine((string)message);
            });
            Thread.Sleep(1000);

            //通过Publish向messages通道发送消息,发送通道名称和监听通道名称要相同
            //这部分可以写到客户端里
            sub.Publish("messages", "hello");
            sub.Publish("messages", "hello1");
            sub.Publish("messages", "hello2");
            #endregion


            #region 消息队列方法2,在cmd客户端通过 SUBSCRIBE <通道名称> 命令来监听
            Thread.Sleep(10000);
            sub.Publish("redisMessages", "This message from C# program123");
            string pub = Console.ReadLine();
            //连发十条消息
            for (int i = 0; i < 10; i++)
            {
                sub.Publish("redisMessages", pub);
            }
            #endregion


            Console.ReadLine();
        }
    }
}

效果图如下:

运行程序,消息队列方法1中,sub.Subscribe("messages", (channel, message))监听到了程序自己发送的消息。

如果想做一个服务端一个客户端,只要制定好IP,端口,和消息通道名称就行了。

 

也可以打开cmd看监听效果,先在redis安装文件夹中打开cmd,启动redis-cli.exe。

然后输入SUBSCRIBE <通道名称> 命令来监听,我程序指定的通道名称是redisMessages,所以命令就是subscribe redisMessages

 

收到了程序发送的第一条消息:This message from C# program

我们也可以手写消息来测试发送 功能

在Java中,可以使用Redis作为消息队列。可以通过以下步骤实现: 1. 首先,需要获取Redis连接。可以使用Jedis库来连接Redis数据库。可以使用以下代码获取连接: ```java Jedis jedis = redisConnection.getJedis(); ``` 2. 然后,可以使用`jedis.publish(channel, message)`方法向指定的频道发送消息。其中,`channel`是要发送消息的频道名称,`message`是要发送的消息内容。可以使用以下代码发送消息: ```java jedis.publish(channel, message); ``` 3. 如果要实现消息的消费者功能,可以创建一个继承自`MessageConsumer`接口的类,并实现其中的方法。可以使用以下代码作为消费者的实现: ```java public abstract class MessageConsumerRedisImpl implements MessageConsumer { public MessageConsumerRedisImpl(RedisConnection redisConnection, String\[\] channels) { Jedis jedis = null; try { if (channels != null && channels.length > 0) { jedis = redisConnection.getJedis(); jedis.subscribe(new JedisPubSub() { @Override public void onMessage(String channel, String message) { System.out.println("receive " + message + " from " + channel); handleMessage(message); } }, channels); } } catch (Exception e) { e.printStackTrace(); } finally { if (jedis != null) { jedis.close(); } } } } ``` 4. 如果要实现消息的生产者功能,可以创建一个实现`MessagePublisher`接口的类,并实现其中的方法。可以使用以下代码作为生产者的实现: ```java public class MessagePublisherRedisImpl implements MessagePublisher { private RedisConnection redisConnection; private String\[\] channels; public void setRedisConnection(RedisConnection redisConnection) { this.redisConnection = redisConnection; } public void setChannels(String\[\] channels) { this.channels = channels; } public boolean sendMessage(String message) { Jedis jedis = null; try { if (channels != null && channels.length > 0) { jedis = redisConnection.getJedis(); for (String channel : channels) { jedis.publish(channel, message); } return true; } } catch (Exception e) { e.printStackTrace(); } finally { if (jedis != null) { jedis.close(); } } return false; } } ``` 通过以上步骤,可以在Java中使用Redis作为消息队列。 #### 引用[.reference_title] - *1* *2* *3* [在 Java 中使用 redis消息队列服务](https://blog.csdn.net/BASK2312/article/details/128832145)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

日拱一两卒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值