游乐游手机版
首页/数据库/文章详情

SpringBoot连接Redis并动态切换数据库db0至db15的实战步骤详解配置方法指南实例总结经验

时间:2026-06-29 07:09
Redis 数据库默认划分为 16 个逻辑库,编号从 db0 到 db15。你可以将其视为 16 个相互隔离的“表空间”,不同业务模块的数据可以分别存放在不同的数据库中,便于管理、隔离与安全控制。例如,用户会话数据存放于 db0,缓存数据存放于 db1,配置信息存放于 db2。读取数据时只需指定对应

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 实例中灵活切换多个数据库,极具实用价值。

来源:https://blog.csdn.net/weixin_43564627/article/details/93754608
上一篇MySQL数据库删除语句的正确写法与操作步骤详解 下一篇快速上手Go数据库操作:使用database/sql包连接数据库的五个步骤详解
本站内容用于信息整理与展示,如有侵权或内容问题请及时联系处理。

相关推荐

补充同频道和同主题内容,方便继续浏览更多相关内容。

同类最新

继续查看同栏目最近更新的文章。

更多
金仓数据库逻辑备份实战:全库导出与模式替换全流程
数据库 · 2026-07-03

金仓数据库逻辑备份实战:全库导出与模式替换全流程

在长期的运维实践中,我越来越体会到,备份就像一份保险——平时看似无用,但关键时刻却是唯一的救命稻草。逻辑备份看似简单,可真正执行恢复时,各种陷阱接连浮现:表名大小写不一致、Schema 未正确切换、Owner 属性未同步修改……任何一个环节处理不当,最终恢复出的数据库就会与预期相去甚远。 本文将深入

金仓数据库sys_rman物理备份全流程演练与误覆盖恢复
数据库 · 2026-07-03

金仓数据库sys_rman物理备份全流程演练与误覆盖恢复

干运维这行,逻辑备份和物理备份我都接触过,但说句实在话,真正能在生产环境里扛住事儿的,还得是物理备份。逻辑备份导出的是 SQL 语句,数据量一大,那速度慢得让人抓狂,而且最关键的是,它没法做时间点恢复。物理备份不一样,它直接拷贝数据文件,再配上 WAL 归档日志,想恢复到过去哪一秒都行,这是它最硬核

Windows下将MySQL注册为系统自启服务教程
数据库 · 2026-07-03

Windows下将MySQL注册为系统自启服务教程

先说一个关键前提:务必以管理员身份运行终端,否则 mysqld --install 这条命令几乎不可能成功。问题不在于命令写错,而是 Windows 系统的用户账户控制(UAC)机制会在中途拦截——在普通 CMD 或 PowerShell 窗口执行这条命令,要么直接提示 Access is deni

Mac版Navicat中快速对比两个数据库的表结构异同
数据库 · 2026-07-03

Mac版Navicat中快速对比两个数据库的表结构异同

直接说结论:Mac 版 Navicat 和 Windows 版在表结构比对逻辑上完全一致。但默认配置下,它确实无法承受“全库一键比对上万张表”的压力。要想避免卡死、内存溢出、进度条永远停在 0%,你必须手动将表分批处理,或者利用前缀过滤来控制扫描范围。 为什么 Mac 上点击「结构同步」后界面会卡住

MySQL中UNION操作推荐用UNION ALL的原因
数据库 · 2026-07-03

MySQL中UNION操作推荐用UNION ALL的原因

MySQL中UNION与UNION ALL性能对比:别再被“保险”迷惑,差距远超预期 先给出核心结论:UNION ALL 的性能通常比 UNION 高出不止一个数量级。原因在于,UNION 在合并结果集后会自动触发去重操作,这往往伴随着隐式排序,进而产生临时表和文件排序。而 UNION ALL 则直