您好,登录后才能下订单哦!
这篇文章给大家分享的是有关redis默认建立16个数据库的原因的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
在实际的开发工作中,我们通常会使用redis数据库做缓存、分布式锁/消息队列等。但是我们通常会有这样一个疑问,为什么在搭建配置好redis服务器之后,默认建立了16个数据库?
下面我们就来为大家介绍一下这个疑问。
一、16个数据库的由来
redis是一个字典结构的存储服务器,一个redis实例提供了多个用来存储数据的字典,客户端可以指定将数据存储在哪个字典中。这与在一个关系数据库实例中可以创建多个数据库类似(如下图所示),所有 可以将其中的每个字典都理解成一个独立的数据库。
redis默认支持16个数据库,可以通过调整redis的配置文件redis/redis.conf中的databases来修改这一个值,设置完毕后重启redis便完成配置。
客户端与redis建立链接后会默认选择0号数据库,不过可以随时使用select命令更换数据库。
# 切换数据库操作:切换到1 127.0.0.1:6379> SELECT 1 OK 127.0.0.1:6379[1]> 127.0.0.1:6379[1]> # 切换到0 127.0.0.1:6379[1]> SELECT 0 OK 127.0.0.1:6379> # 从1号库中获取username 127.0.0.1:6379[1]> get username 。
(学习视频分享:redis视频教程)
在实际项目中则可以通过以redis配置文件的形式指定数据库,如下图所示
二、正确理解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个数据库的原因”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。