云数据库Redis版也提供了与Redis相同的消息发布(publish)与订阅(subscribe)功能。即一个客户端发布消息,其他多个客户端订阅消息。
场景介绍
云数据库Redis版发布的消息是“非持久”的,即消息发布者只负责发送消息,而不管消息是否有接收方,也不会保存之前发送的消息,即发布的消息“即发即失”;消息订阅者也只能得到订阅之后的消息,频道(channel)中此前的消息将无从获得。
此外,消息发布者(即publish客户端)无需独占与服务器端的连接,您可以在发布消息的同时,使用同一个客户端连接进行其他操作(例如List操作等)。但是,消息订阅者(即subscribe客户端)需要独占与服务器端的连接,即进行 subscribe 期间,该客户端无法执行其他操作,而是以阻塞的方式等待频道(channel)中的消息;因此消息订阅者需要使用单独的服务器连接,或者需要在单独的线程中使用(参见如下示例)。
代码示例
消息发布者 (即publish client)
package message.kvstore.aliyun.com;
import redis.clients.jedis.Jedis;
public class KVStorePubClient {
private Jedis jedis;
public KVStorePubClient(String host,int port, String password){
jedis = new Jedis(host,port);
//KVStore的实例密码
String authString = jedis.auth(password);
if (!authString.equals(“OK”))
{
System.err.println(“AUTH Failed: " + authString);
return;
}
}
public void pub(String channel,String message){
System.out.println(” >>> 发布(PUBLISH) > Channel:"+channel+" > 发送出的Message:"+message);
jedis.publish(channel, message);
}
public void close(String channel){
System.out.println(" >>> 发布(PUBLISH)结束 > Channel:"+channel+" > Message:quit");
//消息发布者结束发送,