Redis学习基础
- 性能测试工具:Redis-benchmark
- Redis基础知识:
- redis的数据类型:
- 特殊数据类型:
性能测试工具:Redis-benchmark
- 官方自带的测试工具
- 参数:
- 简单练习:
redis-benchmark -h localhost -p 6379 -c 100 -n 10000
Redis基础知识:
- redis默认有16个数据库:
- 默认使用第0个数据库,可以使用select进行切换数据库
- 清除数据库:flushdb
- 清楚所有数据库:flushall
- 默认使用第0个数据库,可以使用select进行切换数据库
redis的数据类型:
redis-key:
- string类型:
- 可以是字符串、整数或浮点数;对整个字符串或字符串的一部分进行操作;对整数或浮点数进行自增或自减操作。
追加字符串,如果数据库里没有key,就相当于set
========================================================================
====================================================================================
====================================================================================
========================================================================================
====================================================================================
- 可以是字符串、整数或浮点数;对整个字符串或字符串的一部分进行操作;对整数或浮点数进行自增或自减操作。
- list
- 一个链表,链表上的每个节点都包含一个字符串;对链表的两端进行push和pop操作,读取单个或多个元素;根据值查找或删除元素。
- 一个链表,链表上的每个节点都包含一个字符串;对链表的两端进行push和pop操作,读取单个或多个元素;根据值查找或删除元素。
- **hash散列类型:**map集合 key-map的形式
- 包含键值对的无序散列表,包含方法有添加、获取、删除单个元素
- 包含键值对的无序散列表,包含方法有添加、获取、删除单个元素
- set集合
- 包含字符串的无序集合,字符串的集合,包含基础的方法有看是否存在添加、获取、删除;还包含计算交集、并集、差集等
- set集合中的值是不能重复的
- zset有序集合
- 和散列一样,用于存储键值对;字符串成员与浮点数分数之间的有序映射;元素的排列顺序由分数的大小决定;包含方法有添加、获取、删除单个元素以及根据分值范围或成员来获取元素
- 和散列一样,用于存储键值对;字符串成员与浮点数分数之间的有序映射;元素的排列顺序由分数的大小决定;包含方法有添加、获取、删除单个元素以及根据分值范围或成员来获取元素
特殊数据类型:
-
geospatial(地理位置) 用于朋友的定位,附近的人,打车的距离
- Redis geospatial indexes let you store coordinates and search for them. This data structure is useful for finding nearby points within a given radius or bounding box.
添加数据:GEOADD 命令 - 将指定的地理空间位置(纬度、经度、名称)添加到指定的key中
有效的经度从-180度到180度。
有效的纬度从-85.05112878度到85.05112878度。
当坐标位置超出上述指定范围时,该命令将会返回一个错误。
- Redis geospatial indexes let you store coordinates and search for them. This data structure is useful for finding nearby points within a given radius or bounding box.
-
GEOPOS 命令 - 从key里返回所有给定位置元素的位置(经度和纬度)
-
GEODIST 命令 - 返回两个给定位置之间的距离
如果两个位置之间的其中一个不存在, 那么命令返回空值。
指定单位的参数 unit 必须是以下单位的其中一个:- m 表示单位为米
- km 表示单位为千米
- mi 表示单位为英里
- ft 表示单位为英尺。
如果用户没有显式地指定单位参数, 那么 GEODIST 默认使用米作为单位。
-
GEORADIUS 命令 - 以给定的经纬度为中心, 找出某一半径内的元素(应用:附近的人)
范围可以使用以下其中一个单位:- m 表示单位为米。
- km 表示单位为千米。
- mi 表示单位为英里。
- ft 表示单位为英尺。
在给定以下可选项时, 命令会返回额外的信息: - WITHDIST: 在返回位置元素的同时, 将位置元素与中心之间的距离也一并返回。 距离的单位和用户给定的范围单位保持一致。
- WITHCOORD: 将位置元素的经度和维度也一并返回。
- WITHHASH: 以 52 位有符号整数的形式, 返回位置元素经过原始 geohash 编码的有序集合分值。 这个选项主要用于底层应用或者调试, 实际中的作用并不大。
命令默认返回未排序的位置元素。 通过以下两个参数, 用户可以指定被返回位置元素的排序方式: - ASC: 根据中心的位置, 按照从近到远的方式返回位置元素。
- DESC: 根据中心的位置, 按照从远到近的方式返回位置元素。
在默认情况下, GEORADIUS 命令会返回所有匹配的位置元素。 虽然用户可以使用 COUNT 选项去获取前 N 个匹配元素, 但是因为命令在内部可能会需要对所有被匹配的元素进行处理, 所以在对一个非常大的区域进行搜索时, 即使只使用 COUNT 选项去获取少量元素, 命令的执行速度也可能会非常慢。 但是从另一方面来说, 使用 COUNT 选项去减少需要返回的元素数量, 对于减少带宽来说仍然是非常有用的。
-
GEORADIUSBYMEMBER 命令 - 找出位于指定范围内的元素,中心点是由给定的位置元素决定
- 这个命令和 GEORADIUS 命令一样, 都可以找出位于指定范围内的元素, 但是 GEORADIUSBYMEMBER 的中心点是由给定的位置元素决定的, 而不是像 GEORADIUS 那样, 使用输入的经度和纬度来决定中心点
-
GEOHASH 命令 - 返回一个或多个位置元素的 Geohash 表示
- 返回一个或多个位置元素的 Geohash 表示。
- 该命令将返回11个字符的Geohash字符串
geo的底层实现原理是基于zset的,删除操作使用zset实现的
-
Hyperlogog
- Redis HyperLogLog 是用来做基数统计的算法,HyperLogLog 的优点是,在输入元素的数量或者体积非常非常大时,计算基数所需的空间总是固定 的、并且是很小的。在 Redis 里面,每个 HyperLogLog 键只需要花费 12 KB 内存,就可以计算接近 2^64 个不同元素的基 数。这和计算基数时,元素越多耗费内存就越多的集合形成鲜明对比。但是,因为 HyperLogLog 只会根据输入元素来计算基数,而不会储存输入元素本身,所以 HyperLogLog 不能像集合那样,返回输入的各个元素。
- 什么是基数:比如数据集 {1, 3, 5, 7, 5, 7, 8}, 那么这个数据集的基数集为 {1, 3, 5 ,7, 8}, 基数(不重复元素)为5。 基数估计就是在误差可接受的范围内,快速计算基数。
-
Bitmaps
位存储
用于疫情感染人数标记、统计用户活跃不活跃、登录未登录、打卡…两个状态的数据都可以使用
模拟一周打卡情况:
0:未打卡 1:打卡