Redis核心知识
2021-09-27 12:37:48 0 举报
AI智能生成
Redis核心知识
作者其他创作
大纲/内容
存储着所有数据
对象内存
通过参数client-output-buffer-limit控制
客户端缓冲
根据repl-backlog-size参数控制
复制积压缓冲区
用于在Redis重写AOF文件期间保存最近的写入命令
AOF缓冲区
缓冲内存
可采用数据对齐和安全重启等方式规避内存碎片的问题
内存碎片
内存消耗
惰性删除
定时任务删除
内存回收策略
缩减键值对象的长度
共享对象池
字符串优化
编码优化(使用ziplist编码能节约内存但会提高耗时-空间换时间)
控制键的数量(如使用hash结构重构字符串结构)
内存优化
8.内存
Jedis
Redis-py
Redisson
9.客户端
慢查询(slowquery)
管道(pipeline)
10.辅助功能
缓存无底洞
缓存穿透
缓存雪崩
缓存失效
热点倾斜
热点key重建
缓存数据库双写不一致
11.缓存问题隐患
vm.overcommit_memory=1
vm.swapiness=1
关闭THP特性
调大ulimit
调大TCP Backlog
12.参数优化
单线程
纯内存访问
支持数据持久化
非阻塞IO(epoll)
特性
缓存
队列
网站访问统计
分布式Session
应用排行榜
社交关系图
分布式锁
应用场景
主从断线重连后采取部分复制(Psync)
Redis Sentinel Stable
2.8
Redis Cluster
3.0
GEO
3.2
提供模块系统方便第三方拓展
非阻塞del和flushal/flushdb功能
RDB和AOF混合持久化模式
Redis Cluster兼容NAT和Docker
4.0
多线程等
6.0
版本新特性
1.特性及应用场景
整型(int)
embstr编码的简单动态字符串
raw编码的简单动态字符串
字符串(String)
双端链表(LinkedList)
压缩表(Ziplist)
列表(List)
哈希表(Hashtable)
压缩表(ziplist)
哈希(Hash)
整型集合(intset)
哈希表(hashtable)
集合(Set)
跳跃表(Skiplist)
有序集合(ZSet)
基本数据类型
Bitmap
Hyperloglog
其他数据类型
2.数据结构及内部编码
手动触发
自动触发
Snapshot 快照
RDB
日志文件追加记录
存储数据安全性更高,持久化效率低
AOF
3.持久化
同步RDB文件
复制缓冲区
原理
部分复制(Psync2.8版本之后)
全量复制(Sync)
类型
主-从(单节点)
主-从(多节点)
星型
主-从(主)-从
树型
拓扑
4.复制
Redis Sentinel
Redis Cluster(集群自带高可用)
keepalived
5.高可用
集群
TwemProxy
CodisProxy
中间件分片
业务程序
客户端分片
方案
一致性哈希算法
虚拟槽分区(1024个槽)
集群内部数据节点独立运作,无需相互通信
Codis
Gossip协议--集群数据节点内部相互通信
Raft算法--集群内选主
虚拟槽分区(16384个槽)
6.分布式
RDB持久化
AOF文件重写
Fork子进程
持久化阻塞
keys*
smembers
lrange
hgetall
命令阻塞
7.阻塞
Redis核心知识
0 条评论
回复 删除
下一页