多数据库
# 50.多数据库
MySQL 等关系型数据库支持新建数据库,也就是可以多个数据库一起运行;在 Redis 中也有类似的机制。
# 多数据库
一个 Redis 实例提供了多个用来存储数据的字典,客户端可以指定将数据存储在哪个字典中。这与我们熟知的在一个关系数据库实例中可以创建多个数据库类似,所以可以将其中的每个字典都理解成一个独立的数据库。
每个数据库对外都是以一个从 0 开始的递增数字命名,Redis 默认支持 16 个数据库,可以通过配置参数 databases 来修改这一数字。
客户端与 Redis 建立连接后会自动选择 0 号数据库,不过可以随时使用 SELECT 命令更换数据库,如要选择 1 号数据库:
redis> SELECT 1
OK
2
如何查看当前是哪个数据库呢?如果切换为 1 数据库后,在命令行会有一个 [1]
的索引号:
127.0.0.1:6379[1]>
除此之外,在使用编程语言交互时,可以查看相应库包的 API,例如 Java 有一个框架 Jedis,就可以连接 Redis 并操作数据,其中有个方法可以查看当前数据库:jedis.getDB()
这些以数字命名的数据库又与我们理解的数据库,还是有区别的:
首先 Redis 不支持自定义数据库的名字,每个数据库都以编号命名,开发者必须自己记录哪些数据库存储了哪些数据。
另外 Redis 也不支持为每个数据库设置不同的访问密码,所以一个客户端要么可以访问全部数据库,要么连一个数据库也没有权限访问。
最重要的一点是多个数据库之间并不是完全隔离的,比如 FLUSHALL 命令可以清空一个 Redis 实例中所有数据库中的数据。
综上所述,这些数据库更像是一种命名空间,而不适宜存储不同应用程序的数据:比如可以使用 0 号数据库存储某个应用生产环境中的数据,使用 1 号数据库存储测试环境中的数据;也不适宜使用 0 号数据库存储 A 应用的数据而使用 1 号数据库存储 B 应用的数据。
不同的应用应该使用不同的 Redis 实例存储数据。由于 Redis 非常轻量级,一个空 Redis 实例占用的内存只有 1MB 左右,所以不用担心多个 Redis 实例会额外占用很多内存。
# 查看数据库中键的数量
我们可以使用 DBSIZE 查看当前数据库中键的数量:
redis> DBSIZE
(integer) 9
2
# 移动数据
有时候我们想将某个 key,移动到另一个数据库,此时可以使用 move 命令:
MOVE key db #移动 key 到某个数据库
# 清空数据库
flushdb 命令会清空当前数据库的所有键,慎用!
flushdb
flushall 命令则会情况所有数据库的所有内容,慎用!
flushall