Redis实践总结

栏目: 数据库 · 发布时间: 5年前

内容简介:1、不支持持久化 VS 支持持久化,RDB、AOF,同时配置时,从AOF文件加载持久化文件。2、简单key-value形式 VS 多种数据结构3、多线程+锁 VS 单线程+事件轮询机制

1、不支持持久化 VS 支持持久化,RDB、AOF,同时配置时,从AOF文件加载持久化文件。

2、简单key-value形式 VS 多种数据结构

3、多线程+锁 VS 单线程+事件轮询机制

4、伪分布式,客户端分发 VS P2P模式,没有中心节点,在redis cluster架构下,每个 redis 要放开两个端口号,比如一个是6379,另外一个就是加10000的端口号16379。16379端口号是用来进行节点间通信的,也就是cluster bus。cluster bus的通信用来进行故障检测,配置更新,故障转移授权。

5、Slab Allocation,预先分配一系列大小固定的组,然后根据数据大小选择最合适的块存储。避免了内存碎片。缺点是不能变长,浪费了一定空间,memcached默认情况下下一个slab的最大值为前一个的1.25倍。 VS malloc/free,由于malloc首先以链表的方式搜索已管理的内存中可用的空间分配,导致内存碎片比较多。

6、哈希环算法 VS 哈希槽算法,无损伸缩。

Redis如何设计?

单线程 -> CPU并非性能瓶颈,不需要考虑锁操作,避免上下为切换。

多路复用 -> 多路复用可以处理并发的连接。非阻塞IO 内部实现采用epoll,采用了epoll+自己实现的简单的事件框架。epoll中的读、写、关闭、连接都转化成了事件,然后利用epoll的多路复用特性,绝不在io上浪费一点时间。

RDB -> fork+写时复制

lru过期键回收 -> Redis 默认会每秒进行十次过期扫描,过期扫描不会遍历过期字典中所有的 key,而是 采用了一种简单的贪心策略。1、从过期字典中随机 20 个 key; 2、删除这 20 个 key 中已经过期的 key; 3、如果过期的 key 比率超过 1/4,那就重复步骤 1; 同时,为了保证过期扫描不会出现循环过度,导致线程卡死现象,算法还增加了扫描时间的上限,默认不会超过 25ms。

内存不足回收机制 -> 当实际内存超过配置的maxmemory,可选策略valatile-lru、volatile-ttl、volatile-random、allkeys-lru、allkeys-random。

同步策略 -> 主从增量同步,主从刚刚连接的时候,进行全量同步;全同步结束后,进行增量同步。

常用数据结构

string、list、set、zset、hash、hyperloglog

主从配置

slaveof

哨兵如何配置?

配置文件sentinel monitor mymaster 127.0.0.1 6379 1 启动命令redis-sentinal redis.sentinal.conf

主机挂了如何恢复?

主机挂-等待-哨兵投票-从机变主机-主机恢复,变为从机

主机挂了如何选定主机?

优先级、同步偏移量、结点id

Redis Cluster如何进行动态扩容?

先增加结点到集群redis-trib.rb add-node ... 然后重新分配slot到该节点redis-trib.rb reshard... 然后增加从结点、然后复制增加的主节点cluster replicate <主节点的ID>

Redis分布式锁如何实现?缺点是什么?

tryLock(){

SET Key UniqId Seconds } release(){

EVAL( //LuaScript if redis.call("get",KEYS[1]) == ARGV[1] then return redis.call("del",KEYS[1]) else return 0 end ) } 由于Redis集群数据同步为异步,假设在Master节点获取到锁后未完成数据同步情况下Master节点crash,此时在新的Master节点依然可以获取锁,所以多个Client同时获取到了锁。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Python编程无师自通

Python编程无师自通

[美] 科里·奥尔索夫(Cory Althoff) / 宋秉金 / 人民邮电出版社 / 2019-1-1 / 59

畅销Python编程类入门书,美国亚马逊Kindle编程类排行榜榜一。 作者从文科毕业,通过自学编程转行为专业程序员,在硅谷工作多年后成功技术创业。本书不仅教读者如何使用Python语言编程,还会介绍其他书中所忽略的、编程初学者应该了解并掌握的其他所有知识点。 本书作者是一名自学成才的程序员,经过一年的自学,掌握了编程技能并在eBay找到了一份软件工程师的工作。本书是作者结合个人经验写......一起来看看 《Python编程无师自通》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

URL 编码/解码
URL 编码/解码

URL 编码/解码

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具