Redis 数据库默认划分为 16 个逻辑库,编号从 db0 到 db15。你可以将其视为 16 个相互隔离的“表空间”,不同业务模块的数据可以分别存放在不同的数据库中,便于管理、隔离与安全控制。例如,用户会话数据存放于 db0,缓存数据存放于 db1,配置信息存放于 db2。读取数据时只需指定对应的数据库编号,即可获取相应类型的数据,实现彼此隔离。
SpringBoot 连接 Redis 数据库的完整配置指南
在 SpringBoot 项目中集成 Redis 相当简便,通常需要完成以下三个步骤:依赖引入、参数配置及连接验证。
第一步:引入 Maven 依赖
org.springframework.boot
spring-boot-starter-redis
1.3.8.RELEASE
第二步:配置 application.properties 连接参数
在配置文件中指定 Redis 的连接信息,例如数据库索引(默认0)、主机地址、端口号、密码以及连接池参数。以下是一份常用配置示例:
# Redis数据库索引(默认为0)
spring.redis.database=0
# Redis服务器地址
spring.redis.host=localhost
# Redis服务器连接端口
spring.redis.port=6379
# Redis服务器连接密码(默认为空)
spring.redis.password=
# 连接池最大连接数(使用负值表示没有限制) 默认 8
spring.redis.lettuce.pool.max-active=8
# 连接池最大阻塞等待时间(使用负值表示没有限制) 默认 -1
spring.redis.lettuce.pool.max-wait=-1
# 连接池中的最大空闲连接 默认 8
spring.redis.lettuce.pool.max-idle=8
# 连接池中的最小空闲连接 默认 0
spring.redis.lettuce.pool.min-idle=0
第三步:编写测试用例验证连接是否成功
以下是一个基于 JUnit 的简单测试类,通过 StringRedisTemplate 写入一个键值对,再读取出来打印到日志。若能正常输出 "大湿胸",即表示 Redis 连接成功。
@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest(classes = Application.class)
public class TestCRedis {
protected static Logger LOGGER = LoggerFactory.getLogger(TestCRedis.class);
@Autowired
private StringRedisTemplate stringRedisTemplate;
@Test
public void t1() {
ValueOperations stringStringValueOperations = stringRedisTemplate.opsForValue();
stringStringValueOperations.set("test", "大湿胸");
String testkey = stringStringValueOperations.get("test");
LOGGER.info(testkey);
}
}
执行 TestCRedis.t1(),若控制台打印出 "大湿胸",即表明 Redis 连接配置正确无误。
Redis 动态切换数据库的实战方法
在实际开发中,经常需要在一个请求或循环内动态切换至不同的 Redis 数据库。下面演示如何借助 LettuceConnectionFactory 修改当前连接的数据索引,并执行相应操作。需要注意的是,每次切换数据库后都需调用 resetConnection() 以刷新连接状态。
package com.niceteam.web.bm;
import com.niceteam.common.excel.ExcelDownloadUtil;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.data.redis.core.ValueOperations;
import org.springframework.test.context.junit4.SpringRunner;
@RunWith(SpringRunner.class)
@SpringBootTest
public class NiceteamWebBasemanagerApplicationTests {
private static Logger log = LoggerFactory.getLogger(ExcelDownloadUtil.class);
@Autowired
private StringRedisTemplate stringRedisTemplate;
@Test
public void contextLoads() {
for (int i = 0; i <= 2; i++) {
LettuceConnectionFactory lettuceConnectionFactory =
(LettuceConnectionFactory) stringRedisTemplate.getConnectionFactory();
lettuceConnectionFactory.setDatabase(i);
stringRedisTemplate.setConnectionFactory(lettuceConnectionFactory);
lettuceConnectionFactory.resetConnection();
ValueOperations valueOperations = stringRedisTemplate.opsForValue();
valueOperations.set(i + "", i + "");
String test = (String) valueOperations.get(i + "");
log.info(test);
System.out.println("拿到的数据" + test);
}
}
}
上述代码会在 db0、db1、db2 三个库中依次写入并读取数据。通过动态调整 setDatabase() 和 resetConnection(),即可在同一 StringRedisTemplate 实例中灵活切换多个数据库,极具实用价值。
