redis发布订阅java代码实现

具体源码:github源代码Java实现

发布订阅概念:

订阅,取消订阅和发布实现了发布/订阅消息范式(引自wikipedia),发送者(发布者)不是计划发送消息给特定的接收者(订阅者)。而是发布的消息分到不同的频道,不需要知道什么样的订阅者订阅。订阅者对一个或多个频道感兴趣,只需接收感兴趣的消息,不需要知道什么样的发布者发布的。这种发布者和订阅者的解耦合可以带来更大的扩展性和更加动态的网络拓扑。

发布订阅消息格式

消息是一个有三个元素的多块响应 。

第一个元素是消息类型:

subscribe: 表示我们成功订阅到响应的第二个元素提供的频道。第三个参数代表我们现在订阅的频道的数量。
unsubscribe:表示我们成功取消订阅到响应的第二个元素提供的频道。第三个参数代表我们目前订阅的频道的数量。当最后一个参数是0的时候,我们不再订阅到任何频道。当我们在Pub/Sub以外状态,客户端可以发出任何redis命令。
message: 这是另外一个客户端发出的发布命令的结果。第二个元素是来源频道的名称,第三个参数是实际消息的内容。

Java代码实现

启动订阅客户端,可以启动一个或者多个,实例如下:

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPubSub;

/**
 * Created by clq on 2017/8/20.
 */
public class Sub {
    public static void main(String []args) {
        Jedis jedis = new Jedis("127.0.0.1", 6379);
        jedis.subscribe(new JedisPubSub() {
            @Override
            public void onMessage(String channel, String message) {
                System.out.println(message);
                super.onMessage(channel, message);
            }
        }, "topic:clq.biz");
    }
}

启动发布程序

import redis.clients.jedis.Jedis;

/**
 * Created by clq on 2017/8/20.
 */
public class Pub {
    public static void main(String[] args) {
        Jedis jedis = new Jedis("127.0.0.1", 6379);
        jedis.publish("topic:clq.biz", "Hellow World!");
    }
}
好的,这是 Java Redis 发布订阅代码配置示例: 首先,在订阅者端,我们可以使用 Jedis 的 subscribe() 方法来订阅一个或多个频道,例如: ``` import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPubSub; public class Subscriber { public static void main(String[] args) { Jedis jedis = new Jedis("localhost"); jedis.subscribe(new JedisPubSub() { @Override public void onMessage(String channel, String message) { System.out.println(String.format("Received message: %s from channel: %s", message, channel)); } }, "channel1", "channel2"); } } ``` 在这个示例中,我们使用 Jedis 的 subscribe() 方法来订阅两个频道:channel1 和 channel2。我们使用匿名内部类来实现 JedisPubSub 类的 onMessage() 方法,该方法用于处理接收到的消息,并将其打印到控制台上。 接下来,在发布者端,我们可以使用 Jedis 的 publish() 方法来向指定频道发布消息,例如: ``` import redis.clients.jedis.Jedis; public class Publisher { public static void main(String[] args) { Jedis jedis = new Jedis("localhost"); jedis.publish("channel1", "hello, world!"); } } ``` 在这个示例中,我们同样使用 Jedis 的 publish() 方法来向频道 channel1 发布一条消息:hello, world!。 需要注意的是,发布者和订阅者可以在同一台机器上,也可以在不同的机器上。只要它们都连接到同一个 Redis 服务器,并且订阅订阅了发布者所发布的频道,订阅者就可以接收到发布者所发布的消息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值