MAC OS下SSM项目集成Redis(非Mybatis二级缓存)

    昨天学习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中。

MAC OS下SSM项目集成Redis(非Mybatis二级缓存)_第1张图片
pom.xml

3.开始整合

    首先在resources目录下新建redis.properties,并添加相应redis属性,包括host地址,端口,密码等。

MAC OS下SSM项目集成Redis(非Mybatis二级缓存)_第2张图片
redis.properties

    在java目录下新建utils工具类包,同时新建工具类JedisUtils,主要进行Redis缓存操作。

MAC OS下SSM项目集成Redis(非Mybatis二级缓存)_第3张图片
JedisUtils.java

    同时新建FastJsonUtils工具类,主要用于Json序列化和反序列化。相应代码参考项目源码。工具类新建完成,接下来在applicationContext-dao.xml中添加redis数据源等相关配置。


MAC OS下SSM项目集成Redis(非Mybatis二级缓存)_第4张图片
applicationContext-dao.xml

    接下来在ServiceImpl中实现结合业务逻辑实现缓存设置,一般情况下这个操作是在Dao中实现的,但是由于项目中使用了Mapper映射,所以添加在Service,个人感觉最好还是添加在Dao中。

MAC OS下SSM项目集成Redis(非Mybatis二级缓存)_第5张图片
serviceImpl实现

一切就绪,接下来开始项目Debug,第一次查询,Redis缓存中是没有的,所以需要直接从Mysql中查询

MAC OS下SSM项目集成Redis(非Mybatis二级缓存)_第6张图片
第一次查询

第二次查询,缓存中存在了第一次查询之后set进去的数据,所以直接从缓存中读取,而不是从Mysql中读取。

MAC OS下SSM项目集成Redis(非Mybatis二级缓存)_第7张图片
第二次查询

    这样Demo就跑成功了,效果也达到了,感兴趣的同学也可以尝试设置下key时效以及结合增删改的业务去操作Redis缓存。

    以上项目源码地址:https://github.com/outman-dd/ssmdemo

你可能感兴趣的:(MAC OS下SSM项目集成Redis(非Mybatis二级缓存))