JedisClient操作redis 单机版和集群版

Posted wanerhu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JedisClient操作redis 单机版和集群版相关的知识,希望对你有一定的参考价值。

一、在pom文件中添加依赖

<!-- https://mvnrepository.com/artifact/redis.clients/jedis -->
<dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>3.0.1</version>
</dependency>

二、准备JedisClient接口

public interface JedisClient 

    String set(String key, String value);
    String get(String key);
    Boolean exists(String key);
    Long expire(String key, int seconds);
    Long ttl(String key);
    Long incr(String key);
    Long hset(String key, String field, String value);
    String hget(String key, String field);
    Long hdel(String key, String... field);

三、实现

1.单机版

public class JedisClientPool implements JedisClient 
	
	@Autowired
	private JedisPool jedisPool;

	@Override
	public String set(String key, String value) 
		Jedis jedis = jedisPool.getResource();
		String result = jedis.set(key, value);
		jedis.close();
		return result;
	

	@Override
	public String get(String key) 
		Jedis jedis = jedisPool.getResource();
		String result = jedis.get(key);
		jedis.close();
		return result;
	

	@Override
	public Boolean exists(String key) 
		Jedis jedis = jedisPool.getResource();
		Boolean result = jedis.exists(key);
		jedis.close();
		return result;
	

	@Override
	public Long expire(String key, int seconds) 
		Jedis jedis = jedisPool.getResource();
		Long result = jedis.expire(key, seconds);
		jedis.close();
		return result;
	

	@Override
	public Long ttl(String key) 
		Jedis jedis = jedisPool.getResource();
		Long result = jedis.ttl(key);
		jedis.close();
		return result;
	

	@Override
	public Long incr(String key) 
		Jedis jedis = jedisPool.getResource();
		Long result = jedis.incr(key);
		jedis.close();
		return result;
	

	@Override
	public Long hset(String key, String field, String value) 
		Jedis jedis = jedisPool.getResource();
		Long result = jedis.hset(key, field, value);
		jedis.close();
		return result;
	

	@Override
	public String hget(String key, String field) 
		Jedis jedis = jedisPool.getResource();
		String result = jedis.hget(key, field);
		jedis.close();
		return result;
	

	@Override
	public Long hdel(String key, String... field) 
		Jedis jedis = jedisPool.getResource();
		Long result = jedis.hdel(key, field);
		jedis.close();
		return result;
	


  (2)集群版

public class JedisClientCluster implements JedisClient 
	
	@Autowired
	private JedisCluster jedisCluster;

	@Override
	public String set(String key, String value) 
		return jedisCluster.set(key, value);
	

	@Override
	public String get(String key) 
		return jedisCluster.get(key);
	

	@Override
	public Boolean exists(String key) 
		return jedisCluster.exists(key);
	

	@Override
	public Long expire(String key, int seconds) 
		return jedisCluster.expire(key, seconds);
	

	@Override
	public Long ttl(String key) 
		return jedisCluster.ttl(key);
	

	@Override
	public Long incr(String key) 
		return jedisCluster.incr(key);
	

	@Override
	public Long hset(String key, String field, String value) 
		return jedisCluster.hset(key, field, value);
	

	@Override
	public String hget(String key, String field) 
		return jedisCluster.hget(key, field);
	

	@Override
	public Long hdel(String key, String... field) 
		return jedisCluster.hdel(key, field);
	

  四、配置文件

<!-- redis单机版 -->
	<!-- <bean id="jedisPool" class="redis.clients.jedis.JedisPool">
		<constructor-arg name="host" value="192.168.206.132"/>	
		<constructor-arg name="port" value="7001"/>	
	</bean>
	<bean id="jedisClientPool" class="com.taotao.jedis.JedisClientPool"/> -->
	<!-- redis集群 -->
	<bean id="jedisCluster" class="redis.clients.jedis.JedisCluster">
		<constructor-arg>
			<set>
				<bean class="redis.clients.jedis.HostAndPort">
					<constructor-arg name="host" value="192.168.206.132"/>
					<constructor-arg name="port" value="7001"/>
				</bean>
				<bean class="redis.clients.jedis.HostAndPort">
					<constructor-arg name="host" value="192.168.25.132"/>
					<constructor-arg name="port" value="7002"/>
				</bean>
				<bean class="redis.clients.jedis.HostAndPort">
					<constructor-arg name="host" value="192.168.25.132"/>
					<constructor-arg name="port" value="7003"/>
				</bean>
				<bean class="redis.clients.jedis.HostAndPort">
					<constructor-arg name="host" value="192.168.206.132"/>
					<constructor-arg name="port" value="7004"/>
				</bean>
				<bean class="redis.clients.jedis.HostAndPort">
					<constructor-arg name="host" value="192.168.206.132"/>
					<constructor-arg name="port" value="7005"/>
				</bean>
				<bean class="redis.clients.jedis.HostAndPort">
					<constructor-arg name="host" value="192.168.206.132"/>
					<constructor-arg name="port" value="7006"/>
				</bean>
			</set>
		</constructor-arg>
	</bean>
	<bean id="jedisClientCluster" class="com.taotao.jedis.JedisClientCluster"/>

  

五、测试

   @Test
    public void testJedis()
        //初始化spring容器
        ApplicationContext applicationContext=new ClassPathXmlApplicationContext("classpath:spring/applicationContext-redis.xml");
        //从容器中获得jedisclient对象
        JedisClient jedisClient = applicationContext.getBean(JedisClient.class);
        //使用JedisClient操作redis
        jedisClient.set("ok", "test666");
        String result = jedisClient.get("ok");
        System.out.println(result);
    

 六、向业务逻辑中添加缓存

注:添加缓存不能影响正常的业务逻辑

  查询时,业务中应该先去缓存中查询

  如果缓存中没有,在数据库查询

  将数据库查询到的结果添加到缓存中

  推荐使用的数据类型为hash

如下代码:

public List<TbContent> getContentList(long cid) 
        //查询缓存
        try 
            String json = jedisClient.hget(CONTENT_KEY, cid + "");
            //判断json是否为空
            if (StringUtils.isNotBlank(json)) 
                //把json转换成list
                List<TbContent> list = JsonUtils.jsonToList(json, TbContent.class);
                return list;
            
         catch (Exception e) 
            e.printStackTrace();
        
        //根据cid查询内容列表
        TbContentExample example = new TbContentExample();
        //设置查询条件
        Criteria criteria = example.createCriteria();
        criteria.andCategoryIdEqualTo(cid);
        //执行查询
        List<TbContent> list = contentMapper.selectByExample(example);
        //向缓存中添加数据
        try 
            jedisClient.hset(CONTENT_KEY, cid + "", JsonUtils.objectToJson(list));
         catch (Exception e) 
            e.printStackTrace();
        
        return list;
    

七、缓存同步

  对内容信息做增删改操作后只需要把对应缓存删除即可

        //缓存同步
        jedisClient.hdel(CONTENT_KEY, content.getCategoryId().toString());

 

以上是关于JedisClient操作redis 单机版和集群版的主要内容,如果未能解决你的问题,请参考以下文章

使用Spring Data Redis操作Redis(单机版)

Redis入门——Jedis的基本使用

浅谈redis——单机版redis特性记录

Spring boot 整合redis单机版

redis在java客户端的操作

Redis做为单机缓存使用建议