mybatis 整合redis作为二级缓存

核心关键在于定义一个RedisCache实现mytis实现的Cache接口

 1 **
 2  * @author tele
 3  * @Description RedisCache由于需要传入id, 由mybatis进行创建,所以如果需要为RedisCache注入RedisTemplateUtil,直接使用@Autowired无效
 4  * @create 2019-09-07
 5  */
 6 public class RedisCache implements Cache {
 7 
 8     private static RedisTemplateUtil templateUtil;
 9 
10     public static void setTemplateUtil(RedisTemplateUtil templateUtil) {
11         RedisCache.templateUtil = templateUtil;
12     }
13 
14     //这个id实际是传入的mapper全限定名
15     private final String id;
16 
17     public RedisCache(final String id) {
18         if (id == null) {
19             throw new IllegalArgumentException("Cache instances require an ID");
20         }
21         this.id = id;
22     }
23 
24     public String getId() {
25         return id;
26     }
27 
28     public void putObject(Object key, Object value) {
29         templateUtil.set(key, value);
30     }
31 
32     public Object getObject(Object key) {
33         return templateUtil.get(key);
34     }
35 
36     public Object removeObject(Object key) {
37         return null;
38     }
39 
40     public void clear() {
41         templateUtil.clear();
42     }
43 
44     public int getSize() {
45         return templateUtil.getSize();
46     }
47 
48     public ReadWriteLock getReadWriteLock() {
49         return null;
50     }
51 }

定义中间类,注入工具类

 1 @Component
 2 public class RedisCacheTransfer {
 3     @Autowired
 4     private RedisTemplateUtil redisTemplateUtil;
 5 
 6     @Autowired
 7     public void setRedisTemplateUtil(){
 8         RedisCache.setTemplateUtil(redisTemplateUtil);
 9     }
10 }

工具类

 1 /**
 2  * @author tele
 3  * @Description
 4  * @create 2019-09-09
 5  */
 6 @Component
 7 public class RedisTemplateUtil {
 8     @Autowired
 9     private RedisTemplate template;
10 
11 
12     public Object get(Object key) {
13         return template.opsForValue().get(key);
14     }
15 
16     public void set(Object key,Object value){
17         template.opsForValue().set(key, value);
18     }
19 
20     public int getSize() {
21       int size = (int) template.execute((RedisCallback<Integer>) connection -> {
22             return connection.dbSize().intValue();
23       });
24       return size;
25     }
26 
27     public void clear() {
28         template.execute((RedisCallback)  connection -> {
29             connection.flushDb();
30             return null;
31         });
32     }
33 }

在对应的mapper.xml中添加cache标签

测试的时候还是先加载ClassPathXmlContext,然后获得sqlSession,注意mybatis的增删改,flushCache=true,可如果你没有调用commit并不会清空缓存

applicationContext.xml

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <beans xmlns="http://www.springframework.org/schema/beans"
 3        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 4        xmlns:context="http://www.springframework.org/schema/context"
 5        xmlns:p="http://www.springframework.org/schema/p"
 6        xmlns:tx="http://www.springframework.org/schema/tx"
 7        xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/cache http://www.springframework.org/schema/cache/spring-cache.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd">
 8 
 9     <context:component-scan base-package="cn.tele"/>
10 
11     <context:property-placeholder location="classpath:redis.properties,db.properties"/>
12 
13 
14     <!--数据源-->
15     <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
16         <property name="jdbcUrl" value="${db.url}"/>
17         <property name="driverClass" value="${db.driver}"/>
18         <property name="user" value="${db.username}"/>
19         <property name="password" value="${db.password}"/>
20         <property name="initialPoolSize" value="${db.initialPoolSize}"/>
21         <property name="maxPoolSize" value="${db.maxPoolSize}"/>
22         <property name="maxIdleTime" value="${db.maxIdleTime}"/>
23         <property name="idleConnectionTestPeriod" value="${db.idleConnectionTestPeriod}"/>
24         <property name="testConnectionOnCheckout" value="true"/>
25       </bean>
26 
27 
28     <!--mybatis-->
29     <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
30         <property name="mapperLocations" value="classpath*:cn/tele/bean/**/*.xml"/>
31         <property name="dataSource" ref="dataSource"/>
32         <property name="configurationProperties">
33             <props>
34                 <prop key="cacheEnabled">true</prop>
35                 <prop key="jdbcTypeForNull">NULL</prop>
36                 <prop key="lazyLoadingEnabled">true</prop>
37                 <prop key="aggressiveLazyLoading">false</prop>
38             </props>
39         </property>
40     </bean>
41 
42     <!--扫描mapper-->
43     <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
44         <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
45         <property name="basePackage" value="cn.tele"/>
46     </bean>
47 
48 
49     <!--redis连接池属性设置-->
50     <bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig">
51         <property name="maxIdle" value="${redis.maxIdle}"/>
52         <property name="maxTotal" value="${redis.maxTotal}"/>
53     </bean>
54 
55     <bean id="jedisConnFactory"
56           class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"
57           p:poolConfig-ref="poolConfig"  p:port="${redis.port}" p:hostName="${redis.host}"/>
58 
59     <bean id="redisTemplate"
60           class="org.springframework.data.redis.core.StringRedisTemplate"
61           p:connection-factory-ref="jedisConnFactory">
62         <!--序列化策略-->
63         <property name="keySerializer">
64             <bean class="org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer">
65                 <constructor-arg type="java.lang.Class" value="java.lang.String"/>
66             </bean>
67         </property>
68 
69         <property name="valueSerializer">
70             <bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer">
71 
72             </bean>
73         </property>
74 
75         <property name="hashKeySerializer">
76             <bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer"/>
77         </property>
78 
79         <property name="hashValueSerializer">
80             <bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer"/>
81         </property>
82     </bean>
83 </beans>
posted @ 2019-09-16 20:05  tele  阅读(856)  评论(0编辑  收藏  举报