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同时获取到了锁。


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

查看所有标签

猜你喜欢:

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

《10%创业家》

《10%创业家》

[美] 帕特里克•J.麦金尼斯 / 李文远 / 广东人民出版社 / 2017-4 / 45.00

还在打工和创业之间苦苦挣扎吗?麦金尼斯用亲身经历告诉你,不用辞职,只需投入10%的时间和资源,就能获得100%的财务自由。你不需要雄厚的资本,也不必占用工作时间,只要准确掌握本书所授的方法,就能立即开始创业。 麦金尼斯是世界银行风投顾问,同时也是一名10%创业家。在本书中,他结合自身的创业咨询经历,为读者讲解了移动互联时代的5种创业模式,还提供了创业基因测试、10%创业计划、自传模板等个性化......一起来看看 《《10%创业家》》 这本书的介绍吧!

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

URL 编码/解码

SHA 加密
SHA 加密

SHA 加密工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具