本文目录一览:
- 1、怎样理解redis中的hash
- 2、redis用hash实现读写锁
- 3、redis集群使用一致性hash吗
- 4、JedisPool和ShardedJedisPool有什么区别
Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合) 。
Hash 哈希 在Redis中,哈希类型是指键值本身又是一个键值对 结构 , 形如value=http://data.evianbaike.com/Redis/{{field1,value1} , ...{fieldN,valueN}} , 添加命令:hset key field value 。
Redis的Hash槽分配不是 一致性Hash,一致性Hash是成一个hash环,当节点加入或者失效的时候,在环上顺时针找到对应节点 。而Redis集群属于手动分配 线性Hash槽,需要手动指定 , 并且尽量做到各个节点solt平均分配 。
描述: hash 是一个键值(key = value)对集合 。Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象 。常用命令:hget,hset,hgetall 等 。应用场景:存储部分变更数据,如商品信息等 。
redis用hash实现读写锁SETNX不同:SETNX(SETifNoteXists),该命令在key不存在时设置key的值,如果key存在,不做任何操作 。Redishash数据结构可以存储多个键值对 , 所以我们可以使用Redishash实现分布式锁 。
ARGV[1]代表的就是锁key的默认生存时间,默认30秒 。
锁应该是一个对象 , 记录持有锁的线程信息、当前重入次数 。所以应该使用Redis的Hash结构来存储锁对象 。
hscan命令返回的是一组键-值对(field-value pairs) 和一个新的游标 。因此,只要新的游标不为0,就可以继续在hash对象中遍历键-值对 。具体实现可以参考Redis官方文档,或者查阅Redis相关书籍资料 。
所以使用 ziplist 也是很快的,也就是说添加删除平均还是 O(1)。
redis集群使用一致性hash吗1、使用 。设定一个圆环上 0-2^32-1 的点,每个点对应一个缓存区,每个键值对存储的位置也经哈希计算后对应到环上节点 。
2、Redis Cluster 不使用一致性哈希 , 而是使用不同形式的分片 每个键在概念上都是我们所谓的 哈希槽的一部分。Redis Cluster 有 16384 个哈希槽,计算哈希值是多少 给定密钥的插槽 , 我们只需取密钥的 CRC16 模 16384 。
3、我们都知道在集群模式下key是需要进行路由的,那就需要有路由策略 , Redis Cluster并没有使用一致性hash的方案,而是使用分配slot的方式进行key路由 。
4、Redis 集群模式本身没有使用一致性 hash 算法,而是使用 slots 插槽 。
5、由于Redis Cluster(集群)采用哈希分区规则,所以先介绍下常见的哈希分区规则 。常见的哈希规则: 节点取余分区规则、一致性哈希分区(Consistent hashing)、虚拟槽(Virtual slot)分区 。
JedisPool和ShardedJedisPool有什么区别简单说一下 , 除了一些公司自主开发的集群外 。常用的一般有三种:使用redis-trib.rb , 这个是安装redis时就自带的一种集群,采用了服务端分片的方式 。Jedis使用JedisCluster类来访问 。使用Jedis带的客户端分片ShardedJedisPool类 。
用的是什么集群方式,JedisSentinelPool 还是ShardedJedisPool 。如果用的是前者,配置是需要连接sentinel端口的(默认26379),不是连接redis端口(6379) 。或者把spring相关配置文件贴出来一下 。
【redis hash rehash redis用什么hash算法】JedisClusterConnectionHandler是cache类的一个窗口 , cache类似数据管理层,而Handler就类似于操控数据提供服务的Service层 。
推荐阅读
- redis缓存和redis数据库是一个东西吗 redis属于缓存吗
- redisson使用场景 redisnosql场景介绍
- redis的缓存策略 redis缓存数据策略
- 如何查看我曾经玩过的服务器列表? 我玩过的服务器怎么知道