ssm+redis整合之redis连接池注入

Posted L_O_V_E_Java

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ssm+redis整合之redis连接池注入相关的知识,希望对你有一定的参考价值。

package com.tp.soft.redis;

import javax.annotation.Resource;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;

public class RedisCacheTransfer {
    
    @Autowired
    public void setJedisConnectionFactory(JedisConnectionFactory jedisConnectionFactory) {
        RedisCacheAn.setJedisConnectionFactory(jedisConnectionFactory);
    }

}

 

spring-redis注入

<bean id="jedisConnectionFactory" class="com.tp.soft.redis.RedisCacheTransfer">
        <property name="jedisConnectionFactory" ref="connectionFactory"></property>
    </bean>

 

二级缓存引入类

package com.tp.soft.redis;

import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;

import org.apache.ibatis.cache.Cache;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.connection.jedis.JedisConnection;
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;
import org.springframework.data.redis.serializer.JdkSerializationRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializer;

/*
 * 使用第三方缓存服务器,处理二级缓存
 */
public class RedisCacheAn implements Cache {
    private final ReadWriteLock readWriteLock = new ReentrantReadWriteLock();

    private String id;
    
    private static JedisConnectionFactory jedisConnectionFactory;
    
    public RedisCacheAn(final String id) {
        if (id == null) {
            throw new IllegalArgumentException("Cache instances require an ID");
        }
        this.id = id;

    }

    public String getId() {
        return this.id;
    }

    public void putObject(Object key, Object value) {
        JedisConnection conn = null;
        try{
            conn = jedisConnectionFactory.getConnection();
            RedisSerializer<Object> serializer = new JdkSerializationRedisSerializer();
            conn.set(serializer.serialize(key), serializer.serialize(value));
        }catch (Exception e) {
            e.printStackTrace();
        }finally{
            if(conn != null){
                conn.close();
            }
        }

    }

    public Object getObject(Object key) {
        JedisConnection conn = null;
        Object res = null;
        try{
            conn = jedisConnectionFactory.getConnection();
            RedisSerializer<Object> serializer = new JdkSerializationRedisSerializer();
            byte[] bs = conn.get(serializer.serialize(key));
            res = serializer.deserialize(bs);
        }catch (Exception e) {
            e.printStackTrace();
        }finally{
            if(conn != null){
                conn.close();
            }
        }
        return res;
    }

    public Object removeObject(Object key) {
        JedisConnection conn = null;
        Object res = null;
        try{
            conn = jedisConnectionFactory.getConnection();
            RedisSerializer<Object> serializer = new JdkSerializationRedisSerializer();
            conn.expire(serializer.serialize(key), 0);
        }catch (Exception e) {
            e.printStackTrace();
        }finally{
            if(conn != null){
                conn.close();
            }
        }
        return res;

    }

    public void clear() {
        JedisConnection conn = null;
        try{
            conn = jedisConnectionFactory.getConnection();
            conn.flushDb();
            conn.flushAll();
        }catch (Exception e) {
            e.printStackTrace();
        }finally{
            if(conn != null){
                conn.close();
            }
        }
    }

    public int getSize() {
        JedisConnection conn = null;
        int res = 0;
        try{
            conn = jedisConnectionFactory.getConnection();
            res = Integer.parseInt(conn.dbSize().toString());
        }catch (Exception e) {
            e.printStackTrace();
        }finally{
            if(conn != null){
                conn.close();
            }
        }
        return res;
    }

    public ReadWriteLock getReadWriteLock() {
        return readWriteLock;
    }

    public static void setJedisConnectionFactory(JedisConnectionFactory jedisConnectionFactory) {
        RedisCacheAn.jedisConnectionFactory = jedisConnectionFactory;
    }


}

 

以上是关于ssm+redis整合之redis连接池注入的主要内容,如果未能解决你的问题,请参考以下文章

java 整合redis缓存 SSM 后台框架 rest接口 shiro druid maven b

ssm整合redis

java 整合redis缓存 SSM 后台框架 rest接口 shiro druid maven bootstrap html5

Redis之实战篇(与Mybatis整合)

smm中整合es,kafka,redis

SSM整合redis