Redis开发07:使用stackexchange.redis库实现简单消息队列

一、原理

bash 复制代码
消息入队(消息生产):
第一次 A
第二次 B     A
第三次 C     B      A

消息出队(消息消费):
从右往左开始,依次消费A、B、C

结论:简易队列,先进先出

二、代码

cs 复制代码
class Program
{
    // Redis 连接配置
    private static readonly ConnectionMultiplexer Redis =
        ConnectionMultiplexer.Connect("127.0.0.1:6379");

    private static readonly IDatabase Database = Redis.GetDatabase();

    private const string QueueKey = "simple_queue"; // 队列名称(Redis List 的 key,不要和现有的重复)

    /// <summary>
    /// 发送消息(生产者)
    /// </summary>
    /// <param name="message">消息内容(字符串)</param>
    public static async Task<bool> ProduceAsync(string message)
    {
        if (string.IsNullOrEmpty(message)) 
            return false;

        try
        {
            await Database.ListLeftPushAsync(QueueKey, message);
            Console.WriteLine($"[生产者] 已发送消息: {message}");
            return true;
        }
        catch (Exception ex)
        {
            Console.WriteLine($"[生产者] 发送失败: {ex.Message}");
            return false;
        }
    }

    /// <summary>
    /// 接收消息(消费者) - 阻塞模式(推荐)
    /// </summary>
    public static async Task ConsumeAsync()
    {
        Console.WriteLine("[消费者] 开始监听消息队列...");
        while (true)
        {
            try
            {
                var result = await Database.ListRightPopAsync(QueueKey);

                if (!result.IsNull)
                {
                    string message = result.ToString();
                    Console.WriteLine($"[消费者] 收到消息: {message}");
                    // 在此处处理你的业务逻辑
                    ProcessMessage(message);
                }
            }
            catch (Exception ex)
            {
                Console.WriteLine($"[消费者] 读取消息出错: {ex.Message}");
                await Task.Delay(1000); 
            }
        }
    }

    /// <summary>
    /// 模拟处理消息(业务逻辑方法)
    /// </summary>
    private static void ProcessMessage(string message)
    {
        // 例如:保存到数据库、调用 API 等
        Console.WriteLine($"[Processor] 已处理消息: {message}");
        Thread.Sleep(5000);
    }

    // --- 主程序示例 ---
    static async Task Main(string[] args)
    {
        var isConsume = true;//是否为消费者

        if (isConsume)
        {
            // 启动消费者
            await ConsumeAsync();
        }
        else
        {
            //启动生产者
            for (int i = 1; i <= 5; i++)
            {
                string msg = $"Test message {i} at {DateTime.Now:HH:mm:ss}";
                await ProduceAsync(msg);
                await Task.Delay(1000); // 每秒发一条
            }
        }
    }
}

三、效果

相关推荐
Coder_Boy_3 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
helloworldandy3 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
数据知道5 小时前
PostgreSQL 故障排查:如何找出数据库中最耗时的 SQL 语句
数据库·sql·postgresql
qq_12498707535 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
枷锁—sha5 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
Coder_Boy_5 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Gain_chance5 小时前
35-学习笔记尚硅谷数仓搭建-DWS层最近n日汇总表及历史至今汇总表建表语句
数据库·数据仓库·hive·笔记·学习
此生只爱蛋6 小时前
【Redis】主从复制
数据库·redis
马猴烧酒.6 小时前
【面试八股|JAVA多线程】JAVA多线程常考面试题详解
java·服务器·数据库
天天爱吃肉82186 小时前
跟着创意天才周杰伦学新能源汽车研发测试!3年从工程师到领域专家的成长秘籍!
数据库·python·算法·分类·汽车