昨天学习Redis的基础命令之后,觉得是该练习一把Redis的实战了,于是开始集成到之前的SSM项目中。在项目集成Redis之前,学习了网上很多的文章,很多是把Redis作为Mybatis的二级缓存集成的。但是Mybatis的二级缓存,对细粒度小的数据缓存实现不友好,二级缓存是针对Mapper的,当Mapper的二级缓存中有一个数据发生改变,那么所有数据都得清空。所以,针对这个局限性,将Redis缓存跟业务结合,然后根据业务需求添加相应的缓存。
这个项目以之前的SSM项目为基础,之前的项目可以参考http://www.jianshu.com/p/8dfeac968748
1.开发环境
JDK 1.8
IDEA 2017.1
Tomcat 9.0.0.M21
Maven 3.5.0
MySql 5.7.18
Redis 3.2.9
Redis的安装可以参考网上的教程。
2.导入依赖包
在这个项目中,我们需要用到的jar包有Spring和Redis整合的jar包,Redis客户端jar包Jedis,同时也用到了Fastjson和Guava包,Fastjson用于数据Json序列化,Common工具类方便操作,如不添加也可以使用Serializable序列化,Guava包主要用于操作Redis的key。以上中的Redis客户端Jedis也可以使用RedisTemplate替换,RedisTemplate是Spring下的封装好的可以操作Redis的对象,具有Spring Style。首先添加以上jar包依赖到pom.xml中。
pom.xml3.开始整合
首先在resources目录下新建redis.properties,并添加相应redis属性,包括host地址,端口,密码等。
redis.properties在java目录下新建utils工具类包,同时新建工具类JedisUtils,主要进行Redis缓存操作。
JedisUtils.java同时新建FastJsonUtils工具类,主要用于Json序列化和反序列化。相应代码参考项目源码。工具类新建完成,接下来在applicationContext-dao.xml中添加redis数据源等相关配置。
applicationContext-dao.xml接下来在ServiceImpl中实现结合业务逻辑实现缓存设置,一般情况下这个操作是在Dao中实现的,但是由于项目中使用了Mapper映射,所以添加在Service,个人感觉最好还是添加在Dao中。
serviceImpl实现一切就绪,接下来开始项目Debug,第一次查询,Redis缓存中是没有的,所以需要直接从Mysql中查询
第一次查询第二次查询,缓存中存在了第一次查询之后set进去的数据,所以直接从缓存中读取,而不是从Mysql中读取。
第二次查询这样Demo就跑成功了,效果也达到了,感兴趣的同学也可以尝试设置下key时效以及结合增删改的业务去操作Redis缓存。
以上项目源码地址:https://github.com/outman-dd/ssmdemo
网友评论