redis 消息的订阅发布 Java 实现 消息生产者 消息消费者

新:https://blog.iaiot.com/redis-publish-subscribe.html

1.发布消息(消息生产者 MessageProducer):

public static final String CHANNEL_KEY = "channel:1";
jedis.publish(CHANNEL_KEY, message);

2.订阅消息(消息消费者):

/**
 * 消息消费者
 *
 * @author hxx
 */
public class MessageConsumer implements Runnable {

    /**
     * 频道
     */
    public static final String CHANNEL_KEY = "channel:1";

    /**
     * 处理接收消息
     */
    private AlarmJedisPubSub alarmJedisPubSub = new AlarmJedisPubSub();

    /**
     * Logger
     */
    private static Logger LOG = LoggerFactory.getLogger(MessageConsumer.class);

    @Override
    public void run() {
        Jedis jedis = null;
        try {
            jedis = JedisPoolUtils.getPublicJedis();
            jedis.subscribe(alarmJedisPubSub, CHANNEL_KEY);
        }
        catch (Exception e) {
            LOG.error("消费消息失败:" + e.getMessage(), e);
        }
        finally {
            JedisPoolUtils.returnRes(jedis);
        }
    }

    /**
     * 接收到消息后推给前端
     *
     * @author ab
     */
    class AlarmJedisPubSub extends JedisPubSub {
        @Override
        public void onMessage(String channel, String message) {
            LOG.info("接收到来自频道" + channel + "的消息:" + message);
            ResinWebSocketListener.sendToOneUser(JSON.parseObject(message), message, "msg");
        }
    }

    /**
     * 测试
     *
     * @param args args
     */
    public static void main(String[] args) {
        MessageConsumer messageConsumer = new MessageConsumer();
        Thread t1 = new Thread(messageConsumer);
        t1.start();
    }
}

参考:https://www.cnblogs.com/qlqwjy/p/9763754.html

Java中使用Redis的`addlistener`方法可以实现顺序消费消息Redis是一个基于内存的数据结构存储系统,可以用作缓存、消息队列等等。`addlistener`方法用于向Redis实例的订阅频道添加一个监听器,当有新的消息发布到该频道时,监听器会被触发并消费消息。 要实现顺序消费,可以利用Redis的有序集合数据结构(Sorted Set)来存储消息,并且为每个消息设置一个递增的有序分数(score),表示消息的顺序。 1. 生产者消息依次发布Redis的有序集合中,使用消息的递增分数作为排序依据。例如,第一个消息的分数为1,第二个消息的分数为2,以此类推。 2. 消费者使用`addlistener`方法监听Redis的频道,并实现监听器的回调方法。当有新的消息发布到频道时,监听器会被触发。 3. 监听器回调方法中,消费者从有序集合中获取分数最小的消息,即代表最早发送的消息。然后,从有序集合中删除该消息。 4. 消费者消费该消息,并处理相应的业务逻辑。 5. 重复步骤3和4,直到消费完所有消息。 通过以上步骤,消息的消费顺序可以得到保证。消费者每次消费分数最小的消息,即最早发送的消息,保证了消息的有序性。 需要注意的是,如果存在多个消费者同时监听同一个频道,那么每个消费者都会收到相同的消息,并且根据消息的分数自行消费。这时,每个消费者可以采用分布式锁等机制来保证在同一时刻只有一个消费者能够消费消息,以避免重复消费的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值