Redis Single
开发过程中,图简单省事,Redis 一般会采用单机模式部署
Spring Boot 应用连接 Redis 配置很简单
spring: redis: database: 8 port: 6379 password: ****** timeout: 1000 host: 10.106.22.184如上配置连接的是 Redis 的DB8数据库。有些时候为了节省资源,开发环境与测试环境会共用 Redis,用不同的库进行隔离,比如开发环境用DB8,测试环境用DB9
#测试环境 spring: redis: database: 9 port: 6379 password: ****** timeout: 1000 host: 10.106.22.184我们用同个应用,用开发配置启动一个实例,用测试配置也启动一个实例,看彼此之间是否做到数据隔离了
开发环境配置:application-dev.yml
spring: redis: database: 8 port: 6379 password: ****** timeout: 1000 host: 10.106.22.184 server: port: 8081测试环境配置:application-test.yml
spring: redis: database: 9 port: 6379 password: ****** timeout: 1000 host: 10.106.22.184 server: port: 8082新增两个接口,一个往 Redis 的 List 中写数据,一个从 Redis 的List 中读数据
/** * @author 青石路 */ @RestController @RequestMapping("db") public class DBController { private static final String LIST_KEY = "qsl:elem:list"; @Resource private RedisTemplate<String, Object> redisTemplate; @GetMapping("add") public String listAdd(@RequestParam("elem") String elem) { redisTemplate.opsForList().leftPush(LIST_KEY, elem); return elem; } @GetMapping("rangeAll") public List<Object> rangeAll() { return redisTemplate.opsForList().range(LIST_KEY, 0, -1); } }我们先调开发环境的add接口
http://localhost:8081/db/add?elem=123
再调测试环境的rangeAll接口
http://localhost:8082/db/rangeAll
并未查询到开发环境的数据,是不是开发环境数据写入 Redis 失败了呢?我们再调下开发环境的rangeAll接口
http://localhost:8081/db/rangeAll
说明开发环境的 Redis 数据是写入成功的,也说明
Redis 的数据库之间是彼此隔离的
其实我们验证的时候没必要这么麻烦,直接通过 Redis 客户端连接 Redis 进行操作验证即可
在DB8上添加的数据,并不会在DB9查到
Redis Cluster
生产环境会追求 Redis 高性能的同时,还会要求其高可用,往往会采用集群模式部署。为了各个环境一致,那么开发环境与测试环境的 Redis 也采用集群模式部署
开发、测试、生产,环境尽量保持一致,因为环境不一致导致的问题,排查起来真的很头疼!!!
但有时候,服务器资源确实不充裕,那么开发环境与测试环境往往会共用一套 Redis 集群,用数据库隔离;应用配置稍微调整下即可
开发环境配置:application-dev.yml
spring: redis: database: 8 password: hello-#redis timeout: 10000 cluster: nodes: 10.106.0.219:26379,10.106.0.220:26379,10.106.0.221:26379 server: port: 8081测试环境配置:application-test.yml
spring: redis: database: 9 password: hello-#redis timeout: 10000 cluster: nodes: 10.106.0.219:26379,10.106.0.220:26379,10.106.0.221:26379 server: port: 8082是不是 so easy ?我们先调测试环境的rangeAll接口
http://localhost:8082/db/rangeAll
此时,测试环境是没有数据的,我们再调开发环境的add接口
http://localhost:8081/db/add?elem=cluster123
添加成功后,我们再调测试环境的rangeAll接口
对,你们没看错,查出数据了!!!
直接用 Redis 客户端看看
我们选DB8,会报错
ERR SELECT is not allowed in cluster mode
不只是DB8,除了DB0之外的库都不能选,莫非 Redis 集群模式只支持DB0? 我们去翻一下官方说明:cluster-spec,里面有这么一段说明
明确指出
Redis 集群不像单机,它不支持多数据库;不允许使用 SELECT 命令
也就是说,集群模式下,配置文件中的
spring: redis: database: 9无效,连接的始终是DB0库,还隔离个毛的数据
集群模式,为什么只支持DB0
跟 Redis 的设计理念有关,Redis 设计上最求简单性和一致性,集群模式下如果还支持多数据库,你们觉得还会简单,一致性还容易保证吗?
更细致的原因,我们可以问问大模型,以下是 DeepSeek 的回答