redis整理:常用命令,雪崩击穿穿透原因及方案,分布式锁实现思路,分布式锁redission(更新中)
redis个人整理笔记
reids常见数据结构
基本类型
String: 普通key-value
Hash: 类似hashMap
List: 双向链表
Set: 不可重复
SortedSet: 不可重复,有序,hash+跳表
特殊类型
GEO:地理位置
BitMap:
HyperLog
redis通用命令
keys:所有key
del:删除
exists:判断是否存在
expire: 设置有效期
ttl:查看key剩余失效时间
数据类型
string类型
特性:
string:普通字符串
int:可以自增自减
float:可以自增自减
最大空间不能超过512m
常见命令:
set:无则添加,有则覆盖
get:获取key的值
mset:批量添加键值对
mget:批量获取key的值
incr:让一个整形自增
incrBy:让整形自增指定步长
incrByFloat:让一个浮点类型的数字自增并指定步长
setNx:无则新增,有则不执行
setEx:添加一个string类型的键值对,并且指定有效期
hash类型
特性:
hash类型,也叫散列,其value是一个无序字典,类似java中hashMap
常见命令:
hset:添加或则修改hash类型的key的值
hget:获取value值
hmset:批量hash新增
hmget:批量hash查询
hgetAll:获取一个hash类型中的所有key-vlues键值对
hkeys:获取一个hash类型的key中所有的key
hvals:获取一个hash类型的key中所有的值
hincrby:让一个hash类型的key的字段值自增并指定步长
hsetnx:添加一个hash类型的值,有则不添加,前提这个key不存在,否则不知想
list类型
特性:
类似java中的linkedList,可以看作一个双向链表,既可以支持正向检索,也可反向
有序
元素可以重复
插入和删除块
查询速度一般
常用来存储一个有序数据例如,点赞,评论列表
常见命令
lpush:向列表左侧插入一个或多个元素
lpop:移除并返回左侧第一个元素,没有则返回nil
rpush:列表右侧插入一个或者多个元素
lrange 返回一个角标范围内的所有元素
blpop和brpop,没有元素时等待指点时间,而不是之家返回nil
场景
1.模拟栈
入口和出口在同一边,先进后出
2.模拟队列
入口和出口不在同一边,先进先出
3.阻塞队列
入口出口不在同一边,出队时候才有blpop或者brpop
set类型
特性:
可以看作value为null的hashMap
无序
元素不可重复
查找快
支持交并差
常见命令
sadd:添加一个或者多个元素
srem:移除指定元素
scard:返回个数
sismember,判断元素是否存在
smembers:获取所有元素
sinter k1 k2 :求交集
sdiff k1 k2 :求差集
sunion k1 k2 : 求并集
sortedSet类型
特性
可排序的set集合,每个元素有个score属性,可以基于score对元素进行排序,底层是跳表加hash表
可排序
元素不重复
查询速度块
常用来实现排行榜
常见命令
zadd: 添加一个或多个如果已存在则更新score值
zrem :删除指定一个元素
zscore:获取指定key的分值
zrank:获取指定元素的排名
zcard,获取元素个数
zcount key min mak:统计分值在指定范围内的所有元素的个数
zincrby:指定步长自增
zrange:获取指定排名范围内元素
zrangebyscore:获取指定分值范围内的元素
zdiff,zinter,zunion:求差集,交集并集
所有的排名默认都是升序
redis应用场景
基于list实现点赞列表
基于sortedset实现排行榜
基于set实现共同关注,共同好友
基于bitmap实现签到数据统计
基于hyperLogLog实现Uv统计
geohash实现地理位置
Lua脚本+setnx实现分布式锁
计数器
热点数据查询缓存
共享session
时效性数据,短信验证码
全局唯一id
分布式锁
缓存作用及成本
作用:
降低后端负载
提高读写效率,降低响应时间
成本:
数据一致性成本
代码维护性成本
运维成本
缓存更新策略
低一致性:
超时时间机制,内存默认淘汰机制
高一致性:
主动更新,超时剔除作为兜底,修改直接删除缓存,提高一致性,先删除数据库数据,再删除缓存数据,查询时候在添加缓存
缓存穿透,击穿,雪崩
穿透:
出现原因:
请求缓存数据库中不存在的值
解决方案:
缓存短时间空值/布隆过滤器/增加id复杂度/做好基础格式校验/加强用户权限校验/做好限流
击穿:
出现原因:
热点数据失效,大并发打入数据库
解决方案
互斥锁:
互斥更新只允许一个线程去查库重建缓存,其他等待递归,没有额外的内存消耗,保证一致性,实现简单,线程需要等待性能影响,可能会死锁
逻辑过期:
线程无序等待,但是不保证一致性,有额外的内存消耗,实现复杂
雪崩:
出现原因:
大批量key同时失效,并发同时打入数据库/reids宕机
解决方案:
随机秒数稀释缓存失效时间
redis高可用
分布式锁
实现思路
利用setnx获取锁,并设置过期时间,保存线程标识
释放锁先判断线程标识是否与自己一致,一致则删除(原因:不加标识如果线程阻塞,锁超时释放,则其他线程获取到该锁,如果没有唯一标识则可能会删别人的锁,造成并发问题)
特性
利用setNx满足互斥
利用超时时间避免死锁
利用redis集群保证高可用高并发
出现问题
不可重入:同一个线程无法多次获取同一把锁
不可重试:获取锁只尝试一次没有重试机制的话会造成500人1秒并发进行抢购100商品,可能会出现商品还有剩余
超时释放:如果线程执行较长,导致锁释放,存在隐患
主从一致性:如果redis主从存在延迟,当主节点宕机,如果存在数据部分未同步,主从出现了切换,存在隐患.
redission分布式锁框架(更新中)
redis整理:常用命令,雪崩击穿穿透原因及方案,分布式锁实现思路,分布式锁redission(更新中)的更多相关文章
- Jedis对Redis的常用命令操作
本篇主要总结一些Jedis对Redis的常用命令操作: 1.对key操作命令 2.对String操作命令 3.对List操作命令 4.对Set操作命令 5.对Hash操作命令 6.排序操作指令 一.项 ...
- Linux下安装redis以及常用命令
https://blog.csdn.net/zgf19930504/article/details/51850594 安装: 1.获取redis资源 wget http://download.redi ...
- Redis的常用命令与Java整合及高级应用篇
一,redis是什么? 首先数据库分为关系型数据库和非关系型数据库,关系型数据库是采用关系模型来组织数据的数据库,简单来说就是二维表格模型,同时保证事务的一致性. 相反非关系型数据库采用key ...
- 05_NoSQL数据库之Redis数据库:Redis的常用命令,键值相关命令和服务器相关命令
Redis常用命令 Redis提供了丰富的命令对数据库和各种数据库类型进行操作,这些命令可以再Linux终端使用. 键值相关命令: Keys:返回满足给定pattern的所有key 用表达式*表 ...
- 【redis】常用命令
三.常用命令 1)连接操作命令 quit:关闭连接(connection) auth:简单密码认证 help cmd: 查看cmd帮助,例如:help quit ...
- Redis(2):常用命令详解
redis命令不区分大小写 通用命令:1. 获得符合规则的键名列表: keys pattern 其中pattern符合glob风格 ? (一个字符) * (任意个字符) [] (匹配其中的任意一 ...
- centos7 yum安装redis及常用命令
redis是什么 Redis是一种基于内存的数据结构存储,可持久化的日志型.Key-Value数据库.使用关系型数据库的站点达到一定并发量的时候,往往在磁盘IO上会有瓶颈,这时候配合redis就有一定 ...
- Redis 实战 —— 04. Redis 数据结构常用命令简介
字符串 P39 Redis 的字符串是一个有字节组成的序列,可以存储以下 3 种类型的值:字节串(byte string).整数.浮点数. 在需要的时候, Redis 会将整数转换成浮点数.整数的取值 ...
- redis的常用命令01
启动redis的命令: redis-server redis.windows.conf把redis设置成windows下的服务的命令:输入命令后刷新会出现redis的服务:redis-server - ...
随机推荐
- 一位资深IT技术员的心声
引言 我对于本科时光的印象,还停留在那所普通 211 大学的建筑物之间,我坐在大学的时光长廊里,满眼望去,都是经历的过的故事.可毕业后回首,却很少有人能说,自己从来没有迷茫过.迷茫,仿佛就是一团乌云, ...
- VBS病毒实验
实验目的 探讨VBS病毒实现原理,为更好的深入防御和查杀病毒 实验原理 VBS病毒发生机理 实验内容 编写简单VBS病毒,并实现功能,学习VBS病毒发生机理 实验环境描述 VPC1(虚拟PC) 操作系 ...
- [数分笔记]Dedekind切割定理的证明
1.定理内容 Dedekind切割定理:设是实数集的一个切割,则或者有最大数,或者有最小数. 2.证明过程 设是中所有有理数所构成的集合,是中所有有理数所构成的集合 从而构成一个有理数集的切割 有三种 ...
- 【C# .Net GC】条件自动垃圾回收 HandleCollector类
条件自动回收 达到指定条件后自动执行GC回收垃圾. GC中的方法AddMemoryPressure和RemoveMemoryPressure 本机资源有时会消耗大量内存,但用于包装它的托管对象只占用很 ...
- 教程1--安装Git软件
在https://git-scm.com/下载git for windows,双击安装即可. (1)单击Next (2)选择安装目录 (3)勾选创建桌面快捷方式.Git Bash.Git GUi.已经 ...
- k8s全方位监控-prometheus-配置文件介绍以及基于文件服务发现
1.scrape_configs 参数介绍 # 默认的全局配置 global: scrape_interval: 15s # 采集间隔15s,默认为1min一次 evaluation_interval ...
- mataplotlib篇(开篇)
今日内容概要 matplotlib画各种图形 数据操作补充 数据清洗 网络爬虫 今日内容详细 matplotlib画各种图形 # 首先导入模块 import numpy as np import pa ...
- c/c++(c++和网络编程)日常积累(二)
Linux下C编程通过宏定义打开和关闭调试信息 https://www.cnblogs.com/robinsons/p/3667032.html https://blog.csdn.net/u0134 ...
- 基于 vite2 + Vue3 写一个在线帮助文档工具
提起帮助文档,想必大家都会想到 VuePress等,我也体验了一下,但是感觉和我的思路不太一样,我希望的是那种可以直接在线编辑文档,然后无需编译就可以直接发布的方式,另外可以在线写(修改)代码并且运行 ...
- petite-vue源码剖析-ref的工作原理
ref内部的工作原理十分简单,其实就是将指令ref.:ref或v-bind:ref标识的元素实例存储到当前作用域的$refs对象中,那么我们就可以通过this.$refs获取对应的元素实例.但由于作用 ...