前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Redis为什么要分16个库

Redis为什么要分16个库

作者头像
Spark学习技巧
发布2020-12-28 10:12:45
3.3K0
发布2020-12-28 10:12:45
举报
文章被收录于专栏:Spark学习技巧Spark学习技巧

原文链接 :https://www.jianshu.com/p/acfbcc74b701

在实际的项目中,Redis常被用作缓存、分布式锁、消息队列等的解决方案。但是在搭建好Redis服务后,Redis默认创建了16个数据库(db0~db15),而在Redis集群下只有一个db0数据库。如下图所示。

redis单机

一、16个数据库的由来

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

在这里插入图片描述

我们讲过Redis默认支持16个数据库,这可以通过修改Redis的配置文件/redis/redis.conf中的databases字段的值,设置完毕并重启Redis即可完成配置。

此外,客户端与Redis建立连接之后,默认会选择0号数据库即db0,但可以使用select命令更换存储的数据库。

更换db

也可以通过修改配置文件的方式选择默认数据库。

二、正解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的区别如下:

1、key批量操作支持有限:例如mget、mset必须在一个slot;

代码语言:javascript
复制
2、Key事务和Lua支持有限:操作的key必须在一个节点;
3、key是数据分区的最小粒度:不支持bigkey分区;
4、不支持多个数据库:集群模式下只有一个db0;
5、复制只支持一层:不支持树形复制结构。

四、总结
  • Redis实例默认创建了16个数据库,且不支持自定义命名,以dbX的方式命名(db0~db15);
  • 默认数据库的数量可以在配置文件中修改;
  • 应以命名空间的方式理解Redis数据库db,多个应用程序不应使用同一个Redis的不同库,而应一个应用程序对应一个Redis实例,不同的数据库可用于存储不同环境的数据。
  • Redis集群下只有db0,不支持多db。
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-12-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 浪尖聊大数据 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 三、集群环境下的Redis实例
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档