目录
一. 前言
二. 16 个数据库的由来
三. 正解 Redis 数据库概念
四. 集群环境下的 Redis 实例
五. 总结
一. 前言
在实际的项目中,Redis 常被用作缓存、分布式锁、消息队列等的解决方案。但是在搭建好Redis 服务后,Redis 默认创建了16个数据库(db0 - db15),而在 Redis 集群下只有一个 db0 数据库。如下图所示:
二. 16 个数据库的由来
Redis 是一个类似于字典结构的存储服务器,一个 Redis 实例提供了多个用来存储数据的字典,在客户端可以指定将数据存储于哪个字典中。这与在一个关系数据库实例中创建多个数据库类似,所以,可以将 Redis 中的每个字典都理解为一个独立的数据库。
我们讲过 Redis 默认支持16个数据库,这可以通过修改 Redis 的配置文件 /redis/redis.conf 中的databases 字段的值,设置完毕并重启 Redis 即可完成配置。
此外,客户端与 Redis 建立连接之后,默认会选择0号数据库即 db0,但可以使用 select 命令更换存储的数据库。
也可以通过修改配置文件的方式选择默认数据库:
三. 正解 Redis 数据库概念
可以看到,Redis 的数据库都以 db+编号 的方式命名,这是因为 Redis 不支持自定义数据库名。开发者则需要自己记录存储的数据与数据库之间的对应关系。此外,Redis 不支持为每个数据库设置不同的访问密码,即客户端要么可以访问全部的数据库,要么所有的数据库都不能被访问。
Redis 中存在这么一个命令 flushall,该命令可以清空当前 Redis 实例下所有数据库的数据。这与类似于 MySql 的关系型数据库不同,关系型数据库的每个数据库常用于存储不同应用程序的数据,且不提供清除当前实例下所有数据库数据的方法。
因此,对于 Redis 来说,用命名空间的方式理解 Redis 提供的 db0-db15 数据库会更合适,且一个 Redis 实例不适合存储多个应用程序的数据。比如,我们可以这么做:使用 db0 数据库存储应用程序在生产环境的数据,用 db1 数据库存储测试环境的数据。但是,不适合用 db0 数据库存储应用程序 A 的数据,用 db1 存储应用程序B的数据。不同的应用程序应使用不同的 Redis 实例。此外,我们不必担心使用过多的 Redis 实例造成数据库服务压力过大,因为 Redis 是非常轻量级的,一个空的 Redis 实例占用的内存只有 1MB 左右。
四. 集群环境下的 Redis 实例
在单体 Redis 的情况下可以使用 select 命令来实现数据库的切换,但在集群环境下,Redis 不支持使用 select 命令来切换数据库,这是因为在集群环境下只有一个 db0 数据库。
集群与单体 Redis 的区别如下:
- key 批量操作支持有限:例如 mget、mset 必须在一个 slot;
- Key 事务和 Lua 支持有限:操作的 key 必须在一个节点;
- key 是数据分区的最小粒度:不支持 bigkey 分区;
- 不支持多个数据库:集群模式下只有一个 db0;
- 复制只支持一层:不支持树形复制结构。
五. 总结
1. Redis 实例默认创建了16个数据库,且不支持自定义命名,以 dbX 的方式命名(db0 - db15)。
2. 默认数据库的数量可以在配置文件中修改。
3. 应以命名空间的方式理解 Redis 数据库 db,多个应用程序不应使用同一个 Redis 的不同库,而一个应用程序对应一个 Redis 实例,不同的数据库可用于存储不同环境的数据。
4. Redis集群下只有 db0,不支持多 db。