redis数据库都有哪些,rediscli 查找有多少数据库
来源:整理 编辑:黑码技术 2024-06-03 08:39:30
本文目录一览
1,rediscli 查找有多少数据库
redis默认的数据库是0~15一共16个数据库,可以通过配置再改多或改少数据库。可以使用select来选择要查看的数据库。
2,Redis有哪些数据类型
Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。redis目前支持5种数据类型,分别是:string(字符串)list(列表)hash(字典)set(集合)sorted set(有序集合)
3,redis是什么
Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的APIredis是一个key-value存储系统。和memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。redis 是一个高性能的key-value数据库。 redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用。它提供了python,ruby,erlang,php客户端,使用很方便。redis提供五种数据类型:string,hash,list,set及zset(sorted set)。redis使用了两种文件格式:全量数据和增量请求。
4,nosql数据库有哪些
nosql数据库有哪些?1. In-Memory KV Store : Redis2. Disk-Based KV Store: Leveldb3. Document Store: Mongodb4. Column Table Store: HBasenosql太火,冒出太多产品了,保守估计也成百上千了。 互联网公司常用的基本集中在以下几种,每种只举一个比较常见或者应用比较成功的例子吧。 1. in-memory kv store : redis in memory key-value store,同时提供了更加丰富的数据结构和运算的能力,成功用法是替代memcached,通过checkpoint和commit log提供了快速的宕机恢复,同时支持replication提供读可扩展和高可用。 2. disk-based kv store: leveldb 真正基于磁盘的key-value storage, 模型单一简单,数据量不受限于内存大小,数据落盘高可靠,google的几位大神出品的精品,lsm模型天然写优化,顺序写盘的方式对于新硬件ssd再适合不过了,不足是仅提供了一个库,需要自己封装server端。 3. document store: mongodb 分布式nosql,具备了区别mysql的最大亮点:可扩展性。mongodb 最新引人的莫过于提供了sql接口,是目前nosql里最像mysql的,只是没有acid的特性,发展很快,支持了索引等特性,上手容易,对于数据量远超内存限制的场景来说,还需要慎重。 4. column table store: hbase 这个富二代似乎不用赘述了,最大的优势是开源,对于普通的scan和基于行的get等基本查询,性能完全不是问题,只是只提供裸的api,易用性上是短板,可扩展性方面是最强的,其次坐上了hadoop的快车,社区发展很快,各种基于其上的开源产品不少,来解决诸如join、聚集运算等复杂查询。
5,python中的redis有多少个数据库
跟Python没有关系,是redis的问题1、redis 中的每一个数据库,都由一个 redisDb 的结构存储。其中,redisDb.id 存储着 redis 数据库以整数表示的号码。redisDb.dict 存储着该库所有的键值对数据。redisDb.expires 保存着每一个键的过期时间。2、当redis 服务器初始化时,会预先分配 16 个数据库(该数量可以通过配置文件配置),所有数据库保存到结构 redisServer 的一个成员 redisServer.db 数组中。当我们选择数据库 select number 时,程序直接通过 redisServer.db[number] 来切换数据库。有时候当程序需要知道自己是在哪个数据库时,直接读取 redisDb.id 即可。3、既然我们知道一个数据库的所有键值都存储在redisDb.dict中,那么我们要知道如果找到key的位置,就有必要了解一下dict 的结构了:typedef struct dict // 特定于类型的处理函数dictType *type;// 类型处理函数的私有数据void *privdata;// 哈希表(2个)dictht ht[2];// 记录 rehash 进度的标志,值为-1 表示 rehash 未进行int rehashidx;// 当前正在运作的安全迭代器数量int iterators;} dict;由上述的结构可以看出,redis 的字典使用哈希表作为其底层实现。dict 类型使用的两个指向哈希表的指针,其中 0 号哈希表(ht[0])主要用于存储数据库的所有键值,而1号哈希表主要用于程序对 0 号哈希表进行 rehash 时使用,rehash 一般是在添加新值时会触发,这里不做过多的赘述。所以redis 中查找一个key,其实就是对进行该dict 结构中的 ht[0] 进行查找操作。4、既然是哈希,那么我们知道就会有哈希碰撞,那么当多个键哈希之后为同一个值怎么办呢?redis采取链表的方式来存储多个哈希碰撞的键。也就是说,当根据key的哈希值找到该列表后,如果列表的长度大于1,那么我们需要遍历该链表来找到我们所查找的key。当然,一般情况下链表长度都为是1,所以时间复杂度可看作o(1)。二、当redis 拿到一个key 时,如果找到该key的位置。了解了上述知识之后,我们就可以来分析redis如果在内存找到一个key了。1、当拿到一个key后, redis 先判断当前库的0号哈希表是否为空,即:if (dict->ht[0].size == 0)。如果为true直接返回NULL。2、判断该0号哈希表是否需要rehash,因为如果在进行rehash,那么两个表中者有可能存储该key。如果正在进行rehash,将调用一次_dictRehashStep方法,_dictRehashStep 用于对数据库字典、以及哈希键的字典进行被动 rehash,这里不作赘述。3、计算哈希表,根据当前字典与key进行哈希值的计算。4、根据哈希值与当前字典计算哈希表的索引值。5、根据索引值在哈希表中取出链表,遍历该链表找到key的位置。一般情况,该链表长度为1。6、当 ht[0] 查找完了之后,再进行了次rehash判断,如果未在rehashing,则直接结束,否则对ht[1]重复345步骤。到此我们就找到了key在内存中的位置了。
文章TAG:
redis 数据 数据库 哪些 redis数据库都有哪些 查找有多少数据库