1.软文推荐

2.软文推荐

3.软文推荐

Redis 通常在项目中用的最多的功能是缓存,然而今天为你介绍它的另一个功能,轻量级的消息队列。

Redis 发布订阅

Redis 提供了发布订阅功能,可以用于消息的传输,Redis 的发布订阅机制包括三个部分,发布者,订阅者和 Channel(称之为频道或主题)。

发布者将消息发布到指定频道,订阅该频道的订阅者就能够接受到这条消息,如果有多个订阅者,那么他们会接受到相同的消息。

功能实现 发布消息

Redis 采用 PUBLISH 命令发送消息,其返回值为接收到该消息的订阅者的数量。

订阅频道

Redis 采用 SUBSCRIBE 命令订阅某个频道,其返回值包括客户端订阅的频道,目前已订阅的频道数量,以及接收到的消息,其中subscribe表示已经成功订阅了某个频道。

模式匹配

模式匹配功能允许客户端订阅符合某个模式的频道,Redis采用PSUBSCRIBE订阅符合某个模式所有频道,用“ * ”表示模式,“ * ”可以被任意值代替。

假设客户端同时订阅了某种模式和符合该模式的某个频道,那么发送给这个频道的消息将被客户端接收到两次,只不过这两条消息的类型不同,一个是 message 类型,一个是 pmessage 类型,但其内容相同。

取消订阅

Redi s采用 UNSUBSCRIBE 和 PUNSUBSCRIBE 命令取消订阅,其返回值与订阅类似。由于Redis的订阅操作是阻塞式的,因此一旦客户端订阅了某个频道或模式,就将会一直处于订阅状态直到退出。在 SUBSCRIBE,PSUBSCRIBE,UNSUBSCRIBE 和 PUNSUBSCRIBE 命令中,其返回值都包含了该客户端当前订阅的频道和模式的数量,当这个数量变为0时,该客户端会自动退出订阅状态。

SpringBoot+Redis 实现发布订阅

pringboot 如何整合 redis 我这里就不讲了,相信对你来说也没有一点问题。我们直接上代码

消息监听配置
@Configuration
public class RedisSubConfig {

    public static final String SUB_KEY = "chat";//频道channel

    /**
     * redis消息监听器容器
     * 可以添加多个监听不同话题的redis监听器,只需要把消息监听器和相应的消息订阅处理器绑定,该消息监听器
     * 通过反射技术调用消息订阅处理器的相关方法进行一些业务处理
     * @param connectionFactory
     * @param listenerAdapter
     * @return
     */
    @Bean
    RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory, MessageListenerAdapter listenerAdapter) {

        RedisMessageListenerContainer container = new RedisMessageListenerContainer();
        container.setConnectionFactory(connectionFactory);

        //订阅了一个频道
        container.addMessageListener(listenerAdapter, new PatternTopic(RedisSubConfig.SUB_KEY));
        return container;
    }

    /**
     * 消息监听器适配器,绑定消息处理器,利用反射技术调用消息处理器的业务方法
     * @param receiver
     * @return
     */
    @Bean
    MessageListenerAdapter listenerAdapter(RedisReceiver receiver) {
        return new MessageListenerAdapter(receiver, "receiveMessage");
    }

    /**
     * redis 读取内容的template
     * @param connectionFactory
     * @return
     */
    @Bean
    StringRedisTemplate template(RedisConnectionFactory connectionFactory) {
        return new StringRedisTemplate(connectionFactory);
    }
}
接收消息
@Service
public class RedisReceiver {

    public void receiveMessage(String message) {
        System.out.println("接收消息:" + message);
    }
}
采用定时器发布消息
@EnableScheduling //开启定时器功能
@Component
public class MessageSender {

    @Autowired
    private StringRedisTemplate stringRedisTemplate;

    @Scheduled(fixedRate = 5000) //间隔5s 通过StringRedisTemplate对象向redis消息队列chat频道发布消息
    public void sendMessage(){
        stringRedisTemplate.convertAndSend("chat""hello "+ new Date());
    }
}

运行结果

本文来源:www.lxlinux.net/9728.html,若引用不当,请联系修改。

相关文章 8

1

域名申请多少钱(永久域名要多少钱) 47秒前

目录:1、域名注册需要多少钱?2、注册一个域名大概需要多少钱?3、公司域名注册多少钱?4、阿里域名注册多少费用?域名注册需要多少钱...

2

JAVA的反射机制大总结 2分钟前

JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和...

3

阿里云redis(阿里云redis外网访问) 3分钟前

目录:1、怎么看阿里云redis使用率2、阿里云redis集群数据集中在db0未分散到所有节点问题解决3、为什么阿里云还提供了redismysql的数据库怎么...

4

Linux系统查看MySQL端口命令 5分钟前

在Linux系统中MySQL的默认端口是3306但是如果在安装过程中更改MySQL端口之后如何查看MySQL端口?下面良许教程网为打击分享一下Linux系统查看...

5

关于iaclouds的信息 7分钟前

目录:1、五言古诗2、把中文翻译成拉丁文3、新年大吉 万事须心 步步高升 财源滚滚 祝福以跟你走 请把现在好听音乐歌曲介绍留下4、Mons...

6

Linux系统inode节点深入讲解 9分钟前

inode是Linux系统中储存文件信息的区域,也被称为索引节点,下面良许教程网为大家详细讲解一下Linux系统inode的具体内容。 1 inode简介 理解...

7

服务器双11活动(双11官方活动) 10分钟前

目录:1、移动云云主机双十一有啥活动?2、梦幻西游手游双11活动怎么做 双11活动任务详解3、阿里云服务器现在有什么优惠活动?移动云云...

8

配置在线Yum源具体方法 13分钟前

yum,全称Yellow dog Updater, Modified,是一个专门为了解决包的依赖关系而存在的软件包管理器。就好像 Windows 系统上可以通过 360 软件管家实现...