Redis 订阅与发布

Redis是一个key-value的存储系统,提供的key-value类似与Memcached而数据结构又多于memcached,而且性能优异.广泛用于缓存,临时存储等,不仅如此redis pubsub还可以实现发布–订阅功能,实时推送给订阅端。

1.实现发布功能

package cn.slimsmart.redis.spring.data.redis.pubsub;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

public class JedisPubSubTest {
	static JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
	static {
		jedisPoolConfig.setMaxTotal(10);
		jedisPoolConfig.setMaxIdle(2);
	}
	static JedisPool pool = new JedisPool(jedisPoolConfig, "127.0.0.1", 6379, 5000);

	public static void main(String[] args) {
		Jedis jedis = pool.getResource();
		try {
			jedis.publish("test_channel", "hello word!");
		} finally {
			pool.returnResource(jedis);
		}
		pool.destroy();
	}
}

2.实现发布订阅功能
继续JedisPubSub类实现对订阅到消息后的处理。

package cn.slimsmart.redis.spring.data.redis.pubsub;

import redis.clients.jedis.JedisPubSub;

public class JedisPubSubListener extends JedisPubSub {
	@Override
	public void onMessage(String channel, String message) {
		// 取得订阅的消息后的处理
		System.out.println(channel + "    " + message);
	}

	@Override
	public void onPMessage(String pattern, String channel, String message) {
		// 取得按表达式的方式订阅的消息后的处理
	}

	@Override
	public void onPSubscribe(String pattern, int subscribedChannels) {
		// 初始化按表达式的方式订阅时候的处理
	}

	@Override
	public void onPUnsubscribe(String pattern, int subscribedChannels) {
		// 取消按表达式的方式订阅时候的处理
	}

	@Override
	public void onSubscribe(String channel, int subscribedChannels) {
		// 初始化订阅时候的处理
	}

	@Override
	public void onUnsubscribe(String channel, int subscribedChannels) {
		// 取消订阅时候的处理
	}
}

3.测试订阅功能

package cn.slimsmart.redis.spring.data.redis.pubsub;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

public class JedisTest {
	static JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
	static {
		jedisPoolConfig.setMaxTotal(10);
		jedisPoolConfig.setMaxIdle(2);
	}
	static JedisPool pool = new JedisPool(jedisPoolConfig, "127.0.0.1", 6379, 5000);
	public static void main(String[] args) {
		Jedis jedis = pool.getResource();
		try {
			JedisPubSubListener pubsub = new JedisPubSubListener();
			//订阅
			jedis.subscribe(pubsub, "hq_xq_pubsub");
		} finally {
			pool.returnResource(jedis);
		}
		pool.destroy();
	}
}

测试的时候先启动JedisTest 类,然后再启动JedisPubSubTest类。主要运行原理就是socket。

关于spring-data-redis实现发布订阅,请参考文章:

Spring Data Redis实现一个订阅/发布系统

你可能感兴趣的:(redis)