Redis知识点笔记总结

Posted GoAI

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Redis知识点笔记总结相关的知识,希望对你有一定的参考价值。

🐳本文参考:Redis详细总结笔记_poizxc2014的博客-CSDN博客

📝Redis学习资料推荐:

Redis笔记(基础+进阶)_爪洼ing的博客-CSDN博客

Redis全面实战教程_challenge-linge的博客-CSDN博客

Redis知识点总结_烧煤的快感的博客-CSDN博客_redis的知识点

📒Redis面试题总结参考:

Redis面试题(2020最新版)_ThinkWon的博客_redis面试题


前言:Redis简单介绍

1、什么是redis

Redis是一个基于内存的使用C语言编写的key-value开源的NOSQL存储系统。不支持SQL语句。

2、Redis持久化数据的方式有哪些

  •         1、RDB 触发式的序列化           Save 5 2 (5秒钟 有两个动作便会触发序列化)
    •         2、AOF 日志形式的序列化        默认:一秒钟存储一次

3、解决IT行业数据读取瓶颈的终极方案

        读写分离

4.Redis如何实现读写分离?

        Redis本身支持读写分离,主节点可以读数据、可以写数据、从节点只能读数据。配置redis的主从复制机制可实现读写分离。

        在从节点的配置文件中: 配置 slaveof 主机名 端口

5.介绍哨兵机制

        哨兵机制解决了当主节点宕机导致的业务数据无法写入redis的问题。

        在redis的主从复制结构中,若没有哨兵机制,主节点宕机,将无法写数据到redis集群。

        配置哨兵机制,当主节点宕机后,哨兵会在原本为从节点的服务器中选取一个作为主节点,接受外部数据的写入。以此实现当主节点宕机后redis依然可以写入数据的功能。

6.Redis常用操作

redis字符串操作必须掌握

Hash必须掌握

List必须掌握

Set 必须掌握

对Key的常用操作

Redis类型介绍思维导图:

正文目录

一、NoSQL

二、Redis简介

1、基本信息

2、Redis的应用场景

①Redis的典型应用场景:

②Redis不适用的场景

三、Redis安装

1.上传并解压

2.安装C语言编译环境

3.修改安装位置

4.编译安装

5.启动Redis服务器

①默认启动

②定制配置项启动

6.客户端登录

四、Redis常用数据结构

1.总体结构

2.string类型

3.list类型

4.set类型

5.hash类型

 6.zset类型

 7.Geospatial

8.HyperLogLogs

9.bitmap

10.常用数据类型应用场景

五、Redis命令行操作

1.Redis命令的小套路

2.基本操作

①切换数据库

②查看数据库长度

③清空全库

3.KEY操作

4.string操作

5.list操作

6.set操作

7.hash操作

8.zset操作

9.Geospatial

①添加地理位置

②查询已添加的地理位置

③删除已添加的地理位置

④获取指定地区的坐标值

 ⑤计算两地之间的直线距离

⑥以给定坐标为中心,在指定半径内查找元素

 ⑦在指定元素周围查找其他元素

10.hyperloglogs

①基数概念

②hyperloglogs命令

11.bitmap位图

六、Redis持久化机制

1.RDB

①机制描述

②触发时机

③相关配置

④思考

2.AOF

①机制描述

②AOF基本配置

③AOF重写

3.持久化文件损坏修复

4.扩展阅读:两种持久化机制的取舍

①RDB

②AOF

③RDB和AOF并存

④使用建议

七、Redis事务控制

1.Redis事务控制的相关命令

2.命令队列执行失败的两种情况

①加入队列时失败

②执行队列时失败

③Redis为什么不支持回滚

3.悲观锁和乐观锁

八、Redis主从复制机制

1.读写分离的好处:

2.搭建步骤

①思路

②步骤

③启动Redis主从复制集群

3.主从关系

①查看主从关系

②设定主从关系

4.初步测试

5.哨兵模式

①作用

②相关概念

③配置方式

九、发布订阅

1.订阅一个频道

2.在一个频道上发布信息

十、Jedis

1.一个对比

2.Redis准备

①理解Redis配置文件中bind配置项含义

 ②查看Linux系统本机IP

③将Redis配置文件中的bind配置项设置为本机IP。

3.Jedis

十一、总结


正文

一、NoSQL

NoSQL是Not only SQL的缩写,大意为“不只是SQL”,说明这项技术是传统关系型数据库的补充而非替代。在整个NoSQL技术栈中MemCache、Redis、MongoDB被称为NoSQL三剑客。那么时代为什么需要NoSQL数据库呢?我们来做个对比:

关系型数据库NoSQL数据库
数据存储位置硬盘内存
数据结构高度组织化结构化数据没有预定义的模式
数据操作方式SQL所有数据都是键值对,没有声明性查询语言
事务控制严格的基础事务ACID原则基于乐观锁的松散事务控制
访问控制细粒度的用户访问权限控制简单的基于IP绑定或密码的访问控制
外键支持不支持
索引支持不支持

所以NoSQL数据库的最大优势体现为:高性能、高可用性和可伸缩性。

二、Redis简介

1、基本信息绍:

Redis中文官网介绍:
  1. Redis是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库、

  2. 缓存和消息中间件。 它支持多种类型的数据结构,如字符串(strings),

  3. 散列(hashes),列表(lists),集合(sets),有序集合(sorted sets)

  4. 与范围查询,bitmaps,hyperloglogs和地理空间(geospatial) 索引半径查询。

  5. Redis 内置了复制(replication),LUA脚本(Lua scripting),

  6. LRU驱动事件(LRU eviction),事务(transactions)和不同级别的

  7. 磁盘持久化(persistence), 并通过Redis哨兵(Sentinel)和自动分区(Cluster)

  8. 提供高可用性(high availability)。

下面是几点补充:

  • Redis的名字是Remote Dictionary Server的缩写。

  • 开发语言是ANSI C。

  • 支持多种不同语言的客户端。

  • 官方给出的性能参考(在并发量50的情况下):

    • GET: 110000/s:读的速度每秒11万次
    • SET: 81000/s: 写的速度每秒8万次

中文官网:CRUG网站

英文官网:Redis

Redis命令参考文档网址:Redis 命令参考 — Redis 命令参考

2、Redis的应用场景

①Redis的典型应用场景:

[1]缓存

使用Redis可以建立性能非常出色的缓存服务器,查询请求先在Redis中查找所需要的数据,如果能够查询到(命中)则直接返回,大大减轻关系型数据库的压力。

[2]数据临时存储位置

使用token(令牌)作为用户登录系统时的身份标识,这个token就可以在Redis中临时存储。

[3]分布式环境下解决Session不一致问题时的Session库

Spring提供了一种技术解决分布式环境下Session不一致问题,叫SpringSession。而Redis就可以为SpringSession提供一个数据存储空间。

[4]流式数据去重

在Redis中有一种数据类型是set,和Java中的Set集合很像,不允许存储重复数据。借助这个特性我们可以在Redis中使用set类型存储流式数据达到去重的目的。

②Redis不适用的场景

[1]直接查询value

Redis是一个严格的Key-value数据库,所有数据都必须通过key去找到value,Redis没有提供直接根据查询条件匹配value的方法。

[2]用多键一值表示特定关系

Redis中一个key对应一个value,没有多个key对应同一个value的情况。

[3]事务中回滚

Redis不支持回滚。如果一个命令在加入队列时没有检测出问题,那么队列执行时不会因为某一条命令失败而回滚。

三、Redis安装

1.上传并解压

redis-4.0.2.tar.gz

2.安装C语言编译环境

[建议先将虚拟机备份快照]

yum install -y gcc-c++


如果不能联网,可以使用下面步骤安装:

1.上传gcc-c++.rpm.packages目录到Linux系统

2.拍摄快照

3.进入rpm包所在目录

4.执行安装 rpm -Uvh *.rpm --nodeps --force

5.验证安装效果 gcc -v

3.修改安装位置

vim redis解压目录/src/Makefile

PREFIX?=/usr/local/redis

就Redis自身而言是不需要修改的,这里修改的目的是让Redis的运行程序不要和其他文件混杂在一起。

4.编译安装

编译:进入Redis解压目录执行make命令

[建议再次将虚拟机备份快照]

安装:make install

5.启动Redis服务器

①默认启动

[root@rich ~]# /usr/local/redis/bin/redis-server
7239:C 07 Mar 18:59:12.144 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
7239:C 07 Mar 18:59:12.144 # Redis version=4.0.2, bits=64, commit=00000000, 
modified=0, pid=7239, just started
7239:C 07 Mar 18:59:12.144 # Warning: no config file specified, 
using the default config. In order to specify a config file 
use /usr/local/redis/bin/redis-server /path/to/redis.conf
7239:M 07 Mar 18:59:12.145 * Increased maximum number of 
open files to 10032 (it was originally set to 1024).
                _._      
           _.-``__ ''-._       
      _.-``    `.  `_.  ''-._           Redis 4.0.2 (00000000/0) 64 bit
  .-`` .-```.  ```\\/    _.,_ ''-._  
 (    '      ,       .-`  | `,    )     Running in standalone mode
 |`-._`-...-` __...-.``-._|'` _.-'|     Port: 6379
 |    `-._   `._    /     _.-'    |     PID: 7239
  `-._    `-._  `-./  _.-'    _.-'  
 |`-._`-._    `-.__.-'    _.-'_.-'| 
 |    `-._`-._        _.-'_.-'    |           http://redis.io   
  `-._    `-._`-.__.-'_.-'    _.-' 
 |`-._`-._    `-.__.-'    _.-'_.-'| 
 |    `-._`-._        _.-'_.-'    | 
  `-._    `-._`-.__.-'_.-'    _.-' 
      `-._    `-.__.-'    _.-'  
          `-._        _.-'   
              `-.__.-'    
7239:M 07 Mar 18:59:12.148 # WARNING: The TCP backlog setting of 
511 cannot be enforced because /proc/sys/net/core/somaxconn is 
set to the lower value of 128.
7239:M 07 Mar 18:59:12.148 # Server initialized
7239:M 07 Mar 18:59:12.148 # WARNING overcommit_memory is set to 0! 
Background save may fail under low memory condition. To fix this issue add 
'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or
 run the command 'sysctl vm.overcommit_memory=1' for this to take effect.
7239:M 07 Mar 18:59:12.148 # WARNING you have Transparent Huge Pages 
(THP) support enabled in your kernel. This will create latency and 
memory usage issues with Redis. To fix this issue run the command 'echo never > 
/sys/kernel/mm/transparent_hugepage/enabled' as root, and add it to 
your /etc/rc.local in order to retain the setting after a reboot. 
Redis must be restarted after THP is disabled.
7239:M 07 Mar 18:59:12.148 * Ready to accept connections

停止Redis服务器可以在另外一个命令行窗口执行下面命令:

/usr/local/redis/bin/redis-cli shutdown
7239:M 07 Oct 19:00:53.208 # User requested shutdown...
7239:M 07 Oct 19:00:53.208 * Saving the final RDB snapshot before exiting.
7239:M 07 Oct 19:00:53.214 * DB saved on disk
7239:M 07 Oct 19:00:53.214 # Redis is now ready to exit, bye bye...

②定制配置项启动

[1]准备配置文件

cp redis解压目录/redis.conf /usr/local/redis/

[2]修改配置项

配置项名称作用取值
daemonize控制是否以守护进程形式运行Redis服务器yes
logfile指定日志文件位置"/var/logs/redis.log"
dirRedis工作目录/usr/local/redis

注意:/var/logs目录需要我们提前创建好

[3]让Redis根据指定的配置文件启动

  • 格式
redis-server文件路径 redis.conf文件路径
  • 举例
/usr/local/redis/bin/redis-server /usr/local/redis/redis.conf

6.客户端登录

/usr/local/redis/bin/redis-cli

127.0.0.1:6379> ping
PONG
127.0.0.1:6379> exit

四、Redis常用数据结构

1.总体结构

KEYVALUE
string
list
set
hash
zset

Redis中的数据,总体上是键值对,不同数据类型指的是键值对中值的类型。

2.string类型

Redis中最基本的类型,它是key对应的一个单一值。二进制安全,不必担心由于编码等问题导致二进制数据变化。所以redis的string可以包含任何数据,比如jpg图片或者序列化的对象。Redis中一个字符串值的最大容量是512M。

3.list类型

Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。它的底层是双向链表,所以它操作时头尾效率高,中间效率低(额外花费查找插入位置的时间)。

在Redis中list类型是按照插入顺序排序的字符串链表。和数据结构中的普通链表一样,我们可以在其头部(left)和尾部(right)添加新的元素。在插入时,如果该键并不存在,Redis将为该键创建一个新的链表。与此相反,如果链表中所有的元素均被移除,那么该键也将会被从数据库中删除。List中可以包含的最大元素数量是2^32-1个。

list是一个有序可以重复的数据类型。

4.set类型

Redis的set是string类型的无序集合。它是基于哈希表实现的。set类型插入数据时会自动去重。最大可以包含2^32-1个元素。

5.hash类型

本身就是一个键值对集合。可以当做Java中的Map<String,String>对待。每一个hash可以存储2^32-1个键值对。

 6.zset类型

Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。zset的成员是唯一的,但分数(score)却可以重复。

 7.Geospatial

Redis 在 3.2 推出 Geo 类型,该功能可以推算出地理位置信息,两地之间的距离。 

8.HyperLogLogs

用于大数据量基数统计,速度非常快,占用内存非常小。每个HyperLogLog键只需要花费12KB内存,就可以计算接近 2^64个不同元素的基数。比如计算网站UV(User view,用户访问数量,一个用户一天访问同一个URL地址多次合并为一次)。

9.bitmap

直接对string的二进制位进行操作的一组命令

10.常用数据类型应用场景

数据类型应用场景
string分布式Session存储
分布式数据库ID
计数器:统计网站访问量
hash存储对象信息(购物车中的商品信息)
存储表的信息
list实现队列、栈操作
汇总日志
粉丝列表
关注的人列表
set签到
打卡
点赞
zset排行榜
百度热点搜索
geospatial获取地理位置信息
两地之间的距离
hyperloglogs基数统计
bitmaps统计用户访问次数

五、Redis命令行操作

1.Redis命令的小套路

  • NX:not exist
  • EX:expire
  • M:multi

2.基本操作

①切换数据库

Redis默认有16个数据库。
115 # Set the number of databases. The default database is DB 0, you can select
116 # a different one on a per-connection basis using SELECT <dbid> where
117 # dbid is a number between 0 and 'databases'-1
118 databases 16
使用select进行切换,数据库索引从0开始
127.0.0.1:6379> select 2
OK
127.0.0.1:6379[2]> select 0
OK
127.0.0.1:6379> 

②查看数据库长度

数据库长度就是这个数据库中存储了多少条数据

127.0.0.1:6379> dbsize
(integer) 3

③清空全库

    127.0.0.1:6379> flushall

3.KEY操作

在实际操作中对于Key的定义大家注意下面几点:

  • Key不要太长,超过1024字节将消耗过多内存,降低查询效率。尽管Redis支持的Key最大长度为512MB。
  • Key仍然要做到见名知意。
  • 在同一个项目中遵循同一个命名规范,习惯上多个单词用“:”分开。例如:“user:token:session:id”
  • Redis命令不区分大小写,Key区分大小写
●KEYS PATTERN
    把匹配PATTERN的key返回。PATTERN中可以使用“*”匹配多个字符,使用“?”匹配单个字符
●TYPE KEY
    返回KEY对应的值的类型
●MOVE KEY DB
    把一组键值对数据移动到另一个数据库中
●DEL KEY [KEY ...]
    根据KEY进行删除,至少要指定一个KEY
●EXISTS KEY [KEY ...]
    检查指定的KEY是否存在。指定一个KEY时,存在返回1,不存在返回0。可以指定多个,返回存在的KEY的数量。
●RENAME KEY NEWKEY
    重命名一个KEY,NEWKEY不管是否是已经存在的都会执行,如果NEWKEY已经存在则会被覆盖。
●RENAMENX KEY NEWKEY
    只有在NEWKEY不存在时能够执行成功,否则失败
●TTL KEY
    以秒为单位查看KEY还能存在多长时间
    正数:剩余的存活时间(单位:秒)
    -1:永不过期
    -2:不存在的Key
●EXPIRE KEY SECONDS
    给一个KEY设置在SECONDS秒后过期,过期会被Redis移除。
●PERSIST KEY
    移除过期时间,变成永久key

4.string操作

●SET KEY VALUE [EX SECONDS] [PX MILLISECONDS] [NX|XX]
    给KEY设置一个string类型的值。
    EX参数用于设置存活的秒数。
    PX参数用于设置存活的毫秒数。
    NX参数表示当前命令中指定的KEY不存在才行。
    XX参数表示当前命令中指定的KEY存在才行。
●GET KEY
    根据key得到值,只能用于string类型。
●APPEND KEY VALUE
    把指定的value追加到KEY对应的原来的值后面,返回值是追加后字符串长度
●STRLEN KEY
    直接返回字符串长度
●INCR KEY
    自增1(要求:参与运算的数据必须是整数且不能超过整数Integer范围)
●DECR KEY
    自减1(要求:参与运算的数据必须是整数且不能超过整数Integer范围)
●INCRBY KEY INCREMENT
    原值+INCREMENT(要求:参与运算的数据必须是整数且不能超过整数Integer范围)
●DECRBY KEY DECREMENT
    原值-DECREMENT(要求:参与运算的数据必须是整数且不能超过整数Integer范围)
●GETRANGE KEY START END
    从字符串中取指定的一段,索引从0开始
    START是开始取值的索引
    END是结束取值的索引
●SETRANGE KEY OFFSET VALUE
    从offset(从0开始的索引)开始使用VALUE进行替换
    包含offset位置
●SETEX KEY SECONDS VALUE
    设置KEY,VALUE时指定存在秒数
●SETNX KEY VALUE
    新建字符串类型的键值对
●MSET KEY VALUE [KEY VALUE ...]
    一次性设置一组多个键值对
●MGET KEY [KEY ...]
    一次性指定多个KEY,返回它们对应的值,没有值的KEY返回值是(nil)
●MSETNX KEY VALUE [KEY VALUE ...]
    一次性新建多个值
●GETSET KEY VALUE
    设置新值,同时能够将旧值返回

5.list操作

●LPUSH key value [value ...]
    针对key指定的list,从左边放入元素
●RPUSH key value [value ...]
    针对key指定的list,从右边放入元素
●LRANGE key start stop
    根据list集合的索引打印元素数据
    正着数:0,1,2,3,...
    倒着数:-1,-2,-3,...
●LLEN key
    返回list集合的长度
●LPOP key
    从左边弹出一个元素。
    弹出=返回+删除。
●RPOP key
    从右边弹出一个元素。
●RPOPLPUSH source destination
    从source中RPOP一个元素,LPUSH到destination中
●LINDEX key index
    根据索引从集合中取值
●LINSERT key BEFORE|AFTER pivot value
    在pivot指定的值前面或后面插入value
    如果pivot值有重复的,那么就从左往右数,以第一个遇到的pivot为基准
    BEFORE表示放在pivot前面
    AFTER表示放在pivot后面
●LPUSHX key value
    只能针对存在的list执行LPUSH
●LREM key count value
    根据count指定的数量从key对应的list中删除value
    具体执行时从左往右删除,遇到一个删一个,删完为止
●LSET key index value
    把指定索引位置的元素替换为另一个值
●LTRIM key start stop
    仅保留指定区间的数据,两边的数据被删除

6.set操作

●SADD key member [member ...]
    给key指定的set集合中存入数据,set会自动去重
●SMEMBERS key
    返回可以指定的set集合中所有的元素
●SCARD key
    返回集合中元素的数量
●SISMEMBER key member
    检查当前指定member是否是集合中的元素
    返回1:表示是集合中的元素
    返回2:表示不是集合中的元素
●SREM key member [member ...]
    从集合中删除元素
●SINTER key [key ...]
    将指定的集合进行“交集”操作
    集合A:a,b,c
    集合B:b,c,d
    交集:b,c
●SINTERSTORE destination key [key ...]
    取交集后存入destination
●SDIFF key [key ...]
    将指定的集合执行“差集”操作
    集合A:a,b,c
    集合B:b,c,d
    A对B执行diff:a
    相当于:A-交集部分
●SDIFFSTORE destination key [key ...]
●SUNION key [key ...]
    将指定的集合执行“并集”操作
    集合A:a,b,c
    集合B:b,c,d
    并集:a,b,c,d
●SUNIONSTORE destination key [key ...]
●SMOVE source destination member
    把member从source移动到destination

【测试数据
SADD testset a b c d e f g h i j k l m n o p q r s t u v w x y z aa bb cc dd ee

 ff gg hh ii jj kk ll mm nn oo pp qq rr ss tt uu vv ww xx yy zz


●SSCAN key cursor [MATCH pattern] [COUNT count]
    基于游标的遍历。cursor是游标值,第一次显示第一块内容时,游标取值为0;根据后续返回的新的游标值获取下一块数据。直到游标值变成0,说明数据遍历完成。
●SRANDMEMBER key [count]
    从集合中随机返回count个数量的元素,count不指定就返回1个(数据有可能重复出现)
●SPOP key [count]
    从集合中随机弹出count个数量的元素,count不指定就弹出1个(保证不会有重复数据出现)

7.hash操作

●HSET key field value
    插入新数据返回1
    修改旧数据返回0
●HGETALL key
●HGET key field
●HLEN key
●HKEYS key
●HVALS key
●HEXISTS key field
●HDEL key field [field ...]
●HINCRBY key field increment
●HMGET key field [field ...]
●HMSET key field value [field value ...]
●HSETNX key field value
    要求field是新建的

8.zset操作

●ZADD key [NX|XX] [CH] [INCR] score member [score member ...]
●ZRANGE key start stop [WITHSCORES]
●ZCARD key
●ZSCORE key member
●ZINCRBY key increment member
●ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]
    在分数的指定区间内返回数据
    min参数可以通过 -inf 表示负无穷
    max参数可以通过 +inf 表示正无穷

    默认是闭区间
    可以通过 (min (max 形式指定开区间,例如:(50 (80
●ZRANK key member
    先对分数进行升序排序,返回member的排名。排名从0开始
●ZREM key member [member ...]

9.Geospatial

查询经纬度数据:http://www.jsons.cn/lngcode

①添加地理位置

GEOADD key longitude latitude member [longitude latitude member ...]

规则:
1.两极无法直接添加,一般会下载城市数据,直接通过 Java 程序一次性导入。
2.取值范围
有效的经度从 -180 度到 180 度。
有效的纬度从 -85.05112878 度到 85.05112878 度。
当坐标位置超出指定范围时,该命令将会返回一个错误。
3.已经添加的数据,是无法再次往里面添加的。
192.168.109.100:6379> GEOADD "china:city" 114.085947 22.547 shenzhen
(integer) 1
192.168.109.100:6379> GEOADD "china:city" 113.280637 23.125178 guangzhou
(integer) 1 

②查询已添加的地理位置

Geo类型在Redis内部其实是使用zset类型存储的,所以可以使用zset的命令进行常规操作。

192.168.109.100:6379> ZRANGE china:city 0 -1 
1) "shenzhen"
2) "guangzhou"
192.168.109.100:6379> ZRANGE china:city 0 -1 WITHSCORES
1) "shenzhen"
2) "4046433733682118"
3) "guangzhou"
4) "4046533764066819"

③删除已添加的地理位置

192.168.109.100:6379> ZREM china:city guangzhou
(integer) 1 

④获取指定地区的坐标值

192.168.109.100:6379> GEOPOS china:city shenzhen
1) 1) "114.08594459295272827"
   2) "22.54699993773966327"

 ⑤计算两地之间的直线距离


192.168.109.100:6379> GEODIST china:city guangzhou shenzhen km
"104.6426"
单位:
m 表示单位为米[默认值]。
km 表示单位为千米。
mi 表示单位为英里。
ft 表示单位为英尺。
如果用户没有显式地指定单位参数, 那么 GEODIST 默认使用米作为单位。 

⑥以给定坐标为中心,在指定半径内查找元素

192.168.109.100:6379> GEORADIUS china:city 110 20 1000 km WITHCOORD WITHDIST
1) 1) "shenzhen"
   2) "509.4622"
   3) 1) "114.08594459295272827"
      2) "22.54699993773966327"
2) 1) "guangzhou"
   2) "485.7406"
   3) 1) "113.28063815832138062"
      2) "23.12517743834835215"

WITHCOORD表示显示经纬度
WITHDIST表示显示到中心的距离


 ⑦在指定元素周围查找其他元素

192.168.109.100:6379> GEORADIUSBYMEMBER china:city shenzhen 300 km 

WITHCOORD WITHDIST
1) 1) "shenzhen"
   2) "0.0000"
   3) 1) "114.08594459295272827"
      2) "22.54699993773966327"
2) 1) "guangzhou"
   2) "104.6426"
   3) 1) "113.28063815832138062"
      2) "23.12517743834835215"

10.hyperloglogs

①基数概念

一个集合中不重复元素的个数。例如:集合1,2,5,1,7,2,5中元素个数是7,但是基数是4。而hyperloglogs的主要功能就是进行基数统计。

②hyperloglogs命令

  • [1]添加

192.168.109.100:6379> PFADD user:access:1 tom jerry andy jim andy jerry tom
(integer) 1
192.168.109.100:6379> PFADD user:access:2 andy jerry tom bob kate
(integer) 1
192.168.109.100:6379> PFADD user:access:3 mary harry tom jerry
(integer) 1

  • [2]统计

192.168.109.100:6379> PFCOUNT user:access:1 user:access:2 user:access:3
(integer) 8

  • [3]合并

192.168.109.100:6379> PFMERGE user:access:merge user:access:1 user:access:2 

user:access:3
OK
192.168.109.100:6379> PFCOUNT user:access:merge
(integer) 8

11.bitmap位图

直接对数据的二进制位进行操作

192.168.109.100:6379[5]> set a hello
OK
192.168.109.100:6379[5]> GETBIT a 0
(integer) 0
192.168.109.100:6379[5]> GETBIT a 1
(integer) 1
192.168.109.100:6379[5]> GETBIT a 2
(integer) 1
192.168.109.100:6379[5]> GETBIT a 3
(integer) 0
192.168.109.100:6379[5]> GETBIT a 4
(integer) 1
192.168.109.100:6379[5]> GETBIT a 5
(integer) 0
192.168.109.100:6379[5]> SETBIT a 5 1
(integer) 0
192.168.109.100:6379[5]> get a
"lello"
192.168.109.100:6379[5]> BITCOUNT a
(integer) 22

setbit设置指定比特位

getbit获取指定比特位

bitcount统计所有比特位中1的数量

六、Redis持久化机制

官网描述

Redis工作时数据都存储在内存中,万一服务器断电,则所有数据都会丢失。针对这种情况,Redis采用持久化机制来增强数据安全性。说白了就是把内存里的数据保存到硬盘上。

1.RDB

①机制描述

在满足特定触发条件时把内存中的数据本身作为一个快照保存到硬盘上的文件中。Redis默认开启RDB机制。

②触发时机

[1]基于默认配置

save 900 1

save 300 10

save 60 10000

含义

配置含义
save 900 1900秒内至少有一次修改则触发保存操作
save 300 10300秒内至少有10次修改则触发保存操作
save 60 1000060秒内至少有1万次修改则触发保存操作

[2]使用保存命令

save或bgsave

[3]使用flushall命令

这个命令也会产生dump.rdb文件,但里面是空的,没有意义

[4]服务器关闭

如果执行SHUTDOWN命令让Redis正常退出,那么此前Redis就会执行一次持久化保存。

③相关配置

配置项取值作用
save""禁用RDB机制
dbfilename文件名,例如:dump.rdb设置RDB机制下,数据存储文件的文件名
dirRedis工作目录路径指定存放持久化文件的目录的路径。注意:这里指定的必须是目录不能是文件名

④思考

RDB 机制能够保证数据的绝对安全吗?

  • 机制本身并不能保证绝对安全
  • 但是作为总体机制的一部分,RDB(或AOF)机制能够起到它独特的作用;整体机制综合来看是可靠的

2.AOF

①机制描述

根据配置文件中指定的策略,把生成数据的命令保存到硬盘上的文件中。一个AOF文件的内容可以参照下面的例子:

*2
$6
SELECT
$1
0
*3
$3
set
$3
num
$2
10
*2
$4
incr
$3
num
*2
$4
incr
$3
num
*2
$4
incr
$3
num

 生成上面文件内容的Redis命令是:

set num 10
incr num
incr num
incr num

②AOF基本配置

配置项取值作用
appendonlyyes启用AOF持久化机制
no禁用AOF持久化机制[默认值]
appendfilename"文件名"AOF持久化文件名
dirRedis工作目录路径指定存放持久化文件的目录的路径。注意:这里指定的必须是目录不能是文件名
appendfsyncalways每一次数据修改后都将执行文件写入操作,是最安全的方式但是速度缓慢。
everysec每秒执行一次写入操作。折中。
no由操作系统在适当的时候执行写入操作,Redis性能最好,数据保存次数最少。

::: warning

当 AOF 和 RDB 机制并存时,Redis 会优先采纳 AOF 机制。使用 AOF 持久化文件恢复内存中的数据。而 AOF 刚刚开启时 appendonly.aof 持久化文件中没有任何数据。拿空的 appendonly.aof 持久化文件恢复内存,就会导致以前所有数据都丢失。

:::

③AOF重写

对比下面两组命令:

AOF重写前AOF重写后
set count 1
incr count
incr count
incr count
set count 4

两组命令执行后对于count来说最终的值是一致的,但是进行AOF重写后省略了中间过程,可以让AOF文件体积更小,缩短数据恢复时间。而Redis会根据AOF文件的体积来决定是否进行AOF重写。参考的配置项如下:

配置项含义
auto-aof-rewrite-percentage 100文件体积增大100%时执行AOF重写
auto-aof-rewrite-min-size 64mb文件体积增长到64mb时执行AOF重写

实际工作中不要进行频繁的AOF重写,因为CPU、内存资源和硬盘资源二者之间肯定是CPU、内存资源更加宝贵,所以不应该过多耗费CPU性能去节省硬盘空间。另外数据恢复也不是高频操作,所以节约数据恢复时间价值也不是非常大。

3.持久化文件损坏修复

Redis服务器启动时如果读取了损坏的持久化文件会导致启动失败,此时为了让Redis服务器能够正常启动,需要对损坏的持久化文件进行修复。这里以AOF文件为例介绍修复操作的步骤。

  • 第一步:备份要修复的appendonly.aof文件

  • 第二步:执行修复程序

    /usr/local/redis/bin/redis-check-aof --fix /usr/local/redis/appendonly.aof

  • 第三步:重启Redis

注意:所谓修复持久化文件仅仅是把损坏的部分去掉,而没法把受损的数据找回。

4.扩展阅读:两种持久化机制的取舍

①RDB

[1]优势

适合大规模的数据恢复,速度较快

[2]劣势

会丢失最后一次快照后的所有修改,不能绝对保证数据的高度一致性和完整性。Fork的时候,内存中的数据被克隆了一份,大致2倍的膨胀性需要考虑,但上述成立有条件,Linux也有优化手段

②AOF

[1]优势

选择appendfsync always方式运行时理论上能够做到数据完整一致,但此时性能又不好。文件内容具备一定可读性,能够用来分析Redis工作情况。

[2]劣势

持久化相同的数据,文件体积比RDB大,恢复速度比RDB慢。效率在同步写入时低于RDB,不同步写入时与RDB相同。

③RDB和AOF并存

Redis重启的时候会优先载入AOF文件来恢复原始的数据,因为在通常情况下AOF文件保存的数据集要比RDB文件保存的数据集要完整

RDB的数据不实时,同时使用两者时服务器重启也只会找AOF文件。那要不要只使用AOF呢?作者建议不要,因为RDB更适合用于备份数据库(AOF在不断变化不好备份)、快速重启,而且不会有AOF可能潜在的bug,留着作为一个万一的手段。

④使用建议

如果Redis仅仅作为缓存可以不使用任何持久化方式。

其他应用方式综合考虑性能和完整性、一致性要求。

RDB文件只用作后备用途,建议只在Slave上持久化RDB文件,而且只要15分钟备份一次就够了,只保留save 900 1这条规则。如果Enalbe AOF,好处是在最恶劣情况下也只会丢失不超过两秒数据,启动脚本较简单只load自己的AOF文件就可以了。代价一是带来了持续的IO,二是AOF rewrite的最后将rewrite过程中产生的新数据写到新

以上是关于Redis知识点笔记总结的主要内容,如果未能解决你的问题,请参考以下文章

数据结构学习笔记——基数排序 | 排序算法总结

数据结构学习笔记——基数排序 | 排序算法总结

数据结构学习笔记——基数排序和排序算法总结

Redis学习--- 三种特殊数据类型(GeospatialHyperloglogBitmap)

Redis超详细的笔记总结,收藏!

Redis学习笔记13Redis数据类型之HyperLogLogs类型