MyBatis 使用 Redis 緩存
1. 前言
在MyBatis 緩存一節中,我們介紹了 MyBatis 的多級緩存。MyBatis 的二級緩存可在多個會話中共享緩存,但是這也加大了內存的使用空間,如果二級緩存空間占有量過多勢必會導致程序運行空間的不足,因此我們需要將二級緩存轉移到專業的緩存服務器上。
Redis 是一個高性能的 kv 數據庫,被廣泛的使用在緩存服務上,MyBatis 項目開發者提供了 Redis 緩存的實現。本小節我們將一起來學習如何在 MyBatis 中集成 Redis 緩存。
2. 準備
2.1 添加依賴
在項目的 pom.xml 文件中添加上 mybatis-redis 依賴:
<dependency>
<groupId>org.mybatis.caches</groupId>
<artifactId>mybatis-redis</artifactId>
<version>1.0.0-beta2</version>
</dependency>
mybatis-redis 目前還只有 beta 版,相信不久后就可以到正式版了。
2.2 Redis服務器
請確保你擁有一臺可用的 Redis 服務器,并能夠正常運行。如下:
127.0.0.1:6379> ping
PONG
2.3 Redis配置文件
在 src/main/resources 目錄下新增 redis.properties 配置文件,并向其中添加如下配置:
host=localhost
port=6379
connectionTimeout=5OOO
soTimeout=5OOO
password=123456
database=O
clientName=
注意,請根據自己的環境來修改配置,如密碼和主機。
3. 使用
3.1 配置
在對應的 mapper 配置文件中,如 UserMapper.xml 文件添加上對應的緩存配置。如下:
<cache type="org.mybatis.caches.redis.RedisCache" />
3.2 調用
配置好以后,我們就可以直接在程序中調用了。
SqlSession session1 = sqlSessionFactory.openSession();
UserMapper userMapper1 = session1.getMapper(UserMapper.class);
User user1 = userMapper1.selectUserById(1);
System.out.println(user1);
SqlSession session2 = sqlSessionFactory.openSession();
UserMapper userMapper2 = session2.getMapper(UserMapper.class);
User user2 = userMapper2.selectUserById(1);
System.out.println(user2);
注意,User 對象必須實現Serializable
接口才可被緩存。 比如:
public class User implements Serializable {}
當緩存成功,程序會有如下輸出,表示緩存擊中。
20:58:12.462 [main] DEBUG com.imooc.mybatis.mapper.UserMapper - Cache Hit Ratio [com.imooc.mybatis.mapper.UserMapper]: 1.0
User{id=1, username='peter', age=18, score=100}
20:58:12.499 [main] DEBUG com.imooc.mybatis.mapper.UserMapper - Cache Hit Ratio [com.imooc.mybatis.mapper.UserMapper]: 1.0
User{id=1, username='peter', age=18, score=100}
提示: 在第一次運行時,會向 Redis 中存放數據,不會使用到緩存,第二次運行時則才會使用到緩存。
4. 小結
- Redis 緩存十分常見,MyBatis 集成 Redis 緩存也異常方便,但是在實際生產環境下如此應用的都不多,而是直接選擇其它方式來使用 Redis 緩存。