redis默认建立16个数据库的原因

45次阅读
没有评论

共计 1404 个字符,预计需要花费 4 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章给大家分享的是有关 redis 默认建立 16 个数据库的原因的内容。丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,一起跟随丸趣 TV 小编过来看看吧。

在实际的开发工作中,我们通常会使用 redis 数据库做缓存、分布式锁 / 消息队列等。但是我们通常会有这样一个疑问,为什么在搭建配置好 redis 服务器之后,默认建立了 16 个数据库?

下面我们就来为大家介绍一下这个疑问。

redis 默认建立 16 个数据库的原因

一、16 个数据库的由来

redis 是一个字典结构的存储服务器,一个 redis 实例提供了多个用来存储数据的字典,客户端可以指定将数据存储在哪个字典中。这与在一个关系数据库实例中可以创建多个数据库类似(如下图所示),所有 可以将其中的每个字典都理解成一个独立的数据库。

redis 默认建立 16 个数据库的原因

redis 默认支持 16 个数据库,可以通过调整 redis 的配置文件 redis/redis.conf 中的 databases 来修改这一个值,设置完毕后重启 redis 便完成配置。

redis 默认建立 16 个数据库的原因

客户端与 redis 建立链接后会默认选择 0 号数据库,不过可以随时使用 select 命令更换数据库。

#  切换数据库操作:切换到 1
127.0.0.1:6379  SELECT 1
127.0.0.1:6379[1] 
127.0.0.1:6379[1] 
#  切换到 0
127.0.0.1:6379[1]  SELECT 0
127.0.0.1:6379 
#  从 1 号库中获取 username
127.0.0.1:6379[1]  get username 。

(学习视频分享:redis 视频教程)

在实际项目中则可以通过以 redis 配置文件的形式指定数据库,如下图所示

redis 默认建立 16 个数据库的原因

二、正确理解 redis 的“数据库”概念

由于 redis 不支持自定义数据库的名字,所有每个数据库都以编号命名。开发者则需要自己记录存储的数据与数据库的对应关系。另外 redis 也不支持为每个数据库设置不同的访问密码,所有一个客户端要么可以访问全部数据库,要么全部数据库都没有权限访问。要正确理解 redis 的“数据库”概念,不得不提到一个命令:
清空 redis 实例中所有数据库中的数据
127.0.0.1:6379 FLUSH ALL
清空 redis 某个数据库中数据 不会清空其他库的数据
127.0.0.1:6379 FLUSH db0
该命令可以清空实例下的所有数据库数据,这与我们所熟知的关系型数据库所不同。关系型数据库多个库常用于存储不同应用程序的数据,且没有方式可以同时清空实例下的所有库数据。所有对于 redis 来说这些 db 更像是一种命名空间,且不适宜存储不同应用程序的数据。比如可以使用 0 号数据库存储开发环境中的数据,使用 1 号数据库存储测试环境中的数据,但不适宜使用 0 号数据库存储 A 应用的数据而使用 1 号数据库存储 B 应用的数据,不同的环境应该使用不同的 redis 实例存储数据。redis 非常轻量,一个空的 redis 实例占用的内在只有 1M 左右,所有不用担心多个 redis 实例会额外占用很多内存。

三、集群情况下是否支持一个实例多个 db?

以上所说的都是基于单体 redis 的情况。而在集群的情况下不支持使用 select 命令来切换 db,因为 redis 集群模式下只有一个 db0

感谢各位的阅读!关于“redis 默认建立 16 个数据库的原因”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计1404字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)