import com.lambdaworks.redis.RedisClient;
import com.lambdaworks.redis.RedisURI;
import com.lambdaworks.redis.api.sync.RedisCommands;
import com.lambdaworks.redis.pubsub.api.async.RedisAsyncCommands;
import com.lambdaworks.redis.pubsub.events.MessageListener;
import com.lambdaworks.redis.resource.ClientResources;
public class RedissonQueueExample {
public static void main(String[] args) {
// 创建RedisClient和RedisConnection
RedisClient redisClient = RedisClient.create(RedisURI.create("redis://127.0.0.1:6379"));
RedisAsyncCommands<String, String> asyncCommands = redisClient.connect().async();
ClientResources clientResources = ClientResources.create();
// 创建Redisson的RQueue对象
RQueue<String> queue = redisson.create(clientResources).getQueue("myQueue");
// 添加消息监听器
queue.addListener(String.class, new MessageListener<String>() {
@Override
public void onMessage(String message, long replyIndex) {
System.out.println("Received message: " + message);
}
});
// 异步发布消息
asyncCommands.publish("myQueue", "Hello, Redisson!");
// 关闭连接
asyncCommands.close();
redisClient.shutdown();
}
}
这个例子展示了如何使用Redisson的RQueue来监听一个Redis队列的消息。我们首先创建了RedisClient和RedisConnection,然后通过Redisson的create方法创建RQueue对象。我们为这个队列添加了一个监听器,当有消息发送到队列时,监听器会异步接收到消息并打印出来。最后,我们通过Redis的发布/订阅功能发送一条消息到队列中,并在结束时关闭客户端连接。