redis 发布订阅 性能测试

准备环境

ip服务器redis版本是否主从
10.29.190.244.0.8是/主节点
10.28.36.205 4.0.8是/从节点

环境如上,已经自建了两台redis,并且已经实现主从同步。

一、主从同步下,发布订阅功能是否能正常使用

1、开启五个redis客户端,其中两个主节点,三个从节点

主节点2 订阅configserver频道

主节点3 订阅configserver频道

127.0.0.1:6379> subscribe configserver
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "configserver"
3) (integer) 1

从节点1 订阅configserver频道

从节点2 订阅configserver频道

从节点3 订阅configserver频道

127.0.0.1:6379> subscribe configserver
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "configserver"
3) (integer) 1

2、主节点一发送消息,测试其他节点能否收到订阅

主节点发布 "test subscribe"消息

127.0.0.1:6379> publish configserver "test subscribe"
(integer) 2

主节点2 主节点3 打印

1) "message"
2) "configserver"
3) "test subscribe"

正常接收到消息

从节点1 从节点2 从节点3 打印

1) "message"
2) "configserver"
3) "test subscribe"

正常接收到消息

说明主从同步也一样可以支持发布订阅的功能。具体性能还需进一步测试。

二、发布订阅性能测试

1、创建100个线程,订阅test2

public class RedisSubScribeTask implements Runnable {
    private String Name;

    public RedisSubScribeTask(String name) {
        Name = name;
    }

    @Override
    public void run() {
        RedisDaoImpl redis = new RedisDaoImpl();
        redis.init();
        Jedis jedis = redis.pool.getResource();
        if (jedis != null) {
            RedisMsgSubListener redisMsgSubListener = new RedisMsgSubListener();
            System.out.println("线程" + Name + "启动");
            jedis.subscribe(redisMsgSubListener, "test2");
        }
    }
}


public static void main(String[] args) {

    for (int i = 0; i <= 100; i++) {
        RedisSubScribeTask redisSubScribeTask = new RedisSubScribeTask(String.valueOf(i));
        new Thread(redisSubScribeTask).start();
    }

}
public class RedisMsgSubListener extends JedisPubSub {

    public void onMessage(String channel, String message) {
        System.out.println(channel + " is:" + message);
    }

    public void onPMessage(String pattern, String channel, String message) {
    }

    public void onSubscribe(String channel, int subscribedChannels) {
    }

    public void onUnsubscribe(String channel, int subscribedChannels) {
    }

    public void onPUnsubscribe(String pattern, int subscribedChannels) {
    }
    
} 
2、定义main方法,发布消息
public static void main(String[] args) {
    RedisDaoImpl redis = new RedisDaoImpl();
    redis.init();
    redis.pool.getResource().publish("test2", "test");
}

3、测试结果为秒回

4、将线程改为300个,测试结果也为秒回

5、将连件数升为500,依旧没有延迟

info clients
# Clients
connected_clients:500
client_longest_output_list:0
client_biggest_input_buf:0
blocked_clients:0
127.0.0.1:6379>

6、连接数升为1000,其余两个为主从同步。看是否存在延迟

info clients
# Clients
connected_clients:1002
client_longest_output_list:0
client_biggest_input_buf:0
blocked_clients:0

7、发现依旧没有延迟。并且主从同步的订阅test2的消息,也正常接受。

127.0.0.1:6379> subscribe test2
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "test2"
3) (integer) 1
1) "message"
2) "test2"
3) "test"
1) "message"
2) "test2"
3) "test"

8、针对1000个客户端,并且进行连续发布100个消息

for (int i = 0; i <= 100; i++) {
 redis.pool.getResource().publish("test2", "test" + i);
// try {
// Thread.sleep(1000);
// } catch (InterruptedException e) {
// e.printStackTrace();
// }
 }

从节点完全打印完成大概耗时2s,性能还算可以。

1) "message"
2) "test2"
3) "test99"
1) "message"
2) "test2"
3) "test100"  

8、按照现在redis三个区部署,每个区大概60台虚机链接,这样的性能是足够满足我们的业务场景的。

基本能实现毫秒级配置更新。

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
<h3>回答1:</h3><br/>Spring Boot 中使用 Redis 发布订阅功能可以实现消息的推送和订阅。通过使用 Redis发布订阅功能,可以在不同的应用之间进行消息传递。Spring Boot 提供了与 Redis 集成的工具,方便使用 Redis 发布订阅功能。 <h3>回答2:</h3><br/>Spring Boot是一种轻量级的Java框架,可以用于创建基于Spring的应用程序,在Spring中使用Redis发布订阅功能非常容易。Redis是一种流行的内存数据库,支持发布订阅模式,可以在不同的客户端之间传递信息。下面将详细介绍Spring Boot中如何使用Redis发布订阅功能。 Redis是一种支持键值对的内存数据库,也支持发布订阅模式。在Redis发布订阅模式中,客户端可以订阅一个或多个频道,当发布者将消息发布到这些频道时,订阅者会接收到相应的消息。可以使用Spring Boot中的Spring Data Redis来操作Redis,在Redis中使用发布订阅模式,需要借助Spring Boot的事件机制。由于Redis发布订阅模式是一种事件驱动模式,因此可以使用Spring Boot的事件机制来处理Redis中的发布订阅事件。 首先,在 Spring Boot 项目中引入 Spring Data Redis 的依赖。 然后,在Spring Boot应用程序中配置Redis连接信息,如IP、端口、密码等等。可以在Spring Boot的application.properties配置文件中添加以下配置项: spring.redis.host=127.0.0.1 spring.redis.port=6379 spring.redis.password=password 接下来,需要定义一个订阅者的bean类,该类需要实现org.springframework.data.redis.connection.MessageListener接口。该接口中有一个onMessage()方法,当接收到消息后会执行该方法。在该方法中,可以定义自己的业务逻辑处理。 @Configuration public class RedisConfig { @Bean RedisMessageListenerContainer messageListenerContainer(RedisConnectionFactory connectionFactory) { RedisMessageListenerContainer container = new RedisMessageListenerContainer(); container.setConnectionFactory(connectionFactory); container.addMessageListener(new MyMessageListener(), new ChannelTopic("channel")); return container; } static class MyMessageListener implements MessageListener { @Override public void onMessage(Message message, byte[] pattern) { String channel = new String(message.getChannel()); String content = new String(message.getBody()); System.out.println("收到消息:" + content + ",频道:" + channel); } } } 在上面的代码中,我们自定义一个RedisConfig类,其中定义了一个messageListenerContainer()方法用来创建RedisMessageListenerContainer对象。该对象可以添加一个订阅者,同时指定要订阅的频道,这里我们订阅的是"channel"频道。然后定义了一个静态内部类MyMessageListener,实现org.springframework.data.redis.connection.MessageListener接口,并重写onMessage()方法,用于处理接收到的消息。 最后,我们需要在Spring Boot的主类上添加@EnableRedisRepositories和@EnableScheduling注解,使用@EnableRedisRepositories注解启用Spring Data Redis的存储库,使用@EnableScheduling注解启用定时任务。 @SpringBootApplication @EnableRedisRepositories @EnableScheduling public class SpringbootRedisApplication { public static void main(String[] args) { SpringApplication.run(SpringbootRedisApplication.class, args); } } 最终,当Redis中有消息发布订阅的"channel"频道时,MyMessageListener中的onMessage()方法会被自动调用,从而实现了发布订阅模式的功能。 <h3>回答3:</h3><br/>Spring Boot 是一个流行的 Java 开发框架,而 Redis 则是一个开源的内存数据存储库。两者的结合可以为开发人员提供更好的性能和可扩展性。在 Spring Boot 中使用 Redis 可以实现发布订阅机制。 发布订阅模式是 Redis 中的一种消息传递机制,它允许负责订阅 Redis 频道的客户端在消息被发布时得到通知,从而可以执行相应的处理逻辑。在 Spring Boot 中,我们可以使用 Redis 的 Jedis 客户端实现发布订阅模式。 我们需要首先配置 RedisTemplate,这是一个 Spring 提供的用于操作 Redis 的类库,它存储 Redis 连接工厂和序列化器等相关信息。然后,我们需要使用 RedisTemplate 的 pubSub 选项建立一个订阅器。我们可以通过这个订阅器向一个或多个频道发送消息。Jedis 也提供了一些与监听 Redis 频道和消息相关的方法。我们可以在 Redis 提供的回调函数中进行自定义处理逻辑。 例如,下面是一个使用 Spring Boot 和 Redis 实现发布订阅模式的示例代码: 1. 依赖注入 RedisTemplate: @Autowired private RedisTemplate<String, Object> redisTemplate; 2. 订阅 Redis 消息: //订阅指定频道 public void subscribe(String channel) { redisTemplate.execute((RedisCallback<Object>) connection -> { connection.subscribe((message, pattern) -> { //处理消息 System.out.println("订阅到消息:" + message + ",频道:" + pattern); }, channel.getBytes()); return null; }); } 3. 发布 Redis 消息: //发布消息到指定频道 public void publish(String channel, Object message) { redisTemplate.convertAndSend(channel, message); } 使用 Redis 实现发布订阅模式可以实现不同系统之间的消息传递,同时也可以在需要实时处理某些事件或者需要多个应用程序之间共享数据的场景下使用。然而,需要注意使用 Redis 时,并发性能和高可用性等方面的问题,以及消息传递的顺序和消息传递过程中可能出现的消息丢失等问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

王老狮

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

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

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

打赏作者

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

抵扣说明:

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

余额充值