您的位置:首页 > 汽车 > 时评 > 初识redis:类型补充

初识redis:类型补充

2024/12/28 13:34:08 来源:https://blog.csdn.net/m0_62319039/article/details/141531655  浏览:    关键词:初识redis:类型补充

Redis最关键的五个数据类型:String List Hash Set Zset 我们已经学完了,接下来我们再了解一下不是那么重要的,但是仍然有用的类型。

Stream

Redis Stream 是 Redis 5.0 版本引入的一种新的数据类型,它提供了一种存储时间顺序消息的方式,非常适合用来构建消息队列、日志聚合、事件源等系统。

可以简单的把stream看成是一个队列(阻塞队列)

geospatial

用来储存坐标(经纬度)。

存储一些点之后,可以让用户给一个坐标,去从刚刚存储的点里面查找,比如按照半径、按照矩形区域。这个功能在地图的应用中十分重要。

HyperLogLog

估算集合中的元素个数。之前不是有操作可以完成吗,为什么还要加上这个HyperLogLog呢/

Set就有这样的应用场景,统计服务器的UV(用户访问次数),使用set当然可以统计UV,但是最大的问题在于,如果UV数量非常大,set就会消耗很多的内存空间。

而HyperLogLog则最多花费12kb的空间,就可以完成记录。Set之所以要花费很大的空间,是因为需要把每个元素都储存。而HyperLogLog不存储元素的内容,但是能够记录“元素的特征”,从而在新增元素的时候,能够知道当前新增的元素是一个已经存在的还是第一次出现的元素。

Bitmaps

使用bit位来表示整数,效率非常高,但是会丢失精度。

Bitfields

位域。理解成一串二进制的序列(字节数组),同时可以把这个字节数组中的某几个位赋予特定的含义,并且可以进行读取、修改、算术运算的相关操作。

并且位域非常节省空间。

渐进式遍历

keys* 会一次性的把所有redis中的所有key都获取到,这个操作极其危险,可能会一下子得到很多key,从而阻塞服务器。通过渐进式遍历就可以做到获取所有的key又不会阻塞服务器。

渐进式遍历是每执行一次命令,只会获取到其中的一小部分,保证这一次的查询操作不会造成卡顿。想要得到所有的key就需要多次遍历。

SCAN

SCAN cursor [MATCH pattern] [COUNT count]

SCAN 渐进式遍历icon-default.png?t=N7T8http://t.csdnimg.cn/uqfYi

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com