IDC

93.7%的程序员!竟然都不知道Redis为什么默认16个数据库?

作者:admin 2021-04-09 我要评论

本文转载自微信公众号「UP技术控」,作者conan5566。转载本文请联系UP技术控公众号。 背景 在实际项目中redis常被应用于做缓存,分布式锁/消息队列等。但是在搭...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

本文转载自微信公众号「UP技术控」,作者conan5566。转载本文请联系UP技术控公众号。 

背景

在实际项目中redis常被应用于做缓存,分布式锁/消息队列等。但是在搭建配置好redis服务器后很多朋友应该会发现和有这样的疑问,为什么redis默认建立了16个数据库。

16个数据库的由来

redis是一个字典结构的存储服务器,一个redis实例提供了多个用来存储数据的字典,客户端可以指定将数据存储在哪个字典中。这与在一个关系数据库实例中可以创建多个数据库类似,所有可以将其中的每个字典都理解成一个独立的数据库。redis默认支持16个数据库,可以通过调整redis的配置文件redis/redis.conf中的databases来修改这一个值,设置完毕后重启redis便完成配置。

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

  1. # 切换数据库操作:切换到1 
  2.  
  3. 127.0.0.1:6379> SELECT 1 
  4.  
  5. OK 
  6.  
  7. 127.0.0.1:6379[1]> 
  8.  
  9. 127.0.0.1:6379[1]> 
  10.  
  11. # 切换到0 
  12.  
  13. 127.0.0.1:6379[1]> SELECT 0 
  14.  
  15. OK 
  16.  
  17. 127.0.0.1:6379> 
  18.  
  19. # 从1号库中获取username 
  20.  
  21. 127.0.0.1:6379[1]> get username 。 

在实际项目中则可以通过以redis配置文件的形式指定数据库。

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

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


本文转载自网络,原文链接:https://mp.weixin.qq.com/s/dmimXTQ9T3Xh-cRpgencOA

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • 太棒了!Python和Excel过了这么久终于

    太棒了!Python和Excel过了这么久终于

  • Java编程内功-数据结构与算法「线索化

    Java编程内功-数据结构与算法「线索化

  • 在Java中使用异步编程

    在Java中使用异步编程

  • Kafka性能篇:为何Kafka这么"

    Kafka性能篇:为何Kafka这么"

腾讯云代理商
海外云服务器