1. 什么是Redis

 Redis是开源的、基于内存的键值对数据库。

2. Redis 的基本操作

 set key value => mset, setbit, hset

 get key => mget(multiple), getbit, hget(hash),  hmgetall

 del key

 exists, type, keys 匹配, incr, decr, append, strlen, lpush, lpop, rpop, rpush, Irang

3. Redis 的 sentinel 上投票选举问题

 介绍:sentinel 模式主要为 Redis 提供了主从技术支持。

 Redis 提供 sentinel 是一个独立的进程,通过向多个 Redis 服务器发送命令而监控多个运行中的 Redis 实例(周期性发送PING),每个实例返回运行状态,如果检测到 master 泵机,将 slave 切换成 master,再通过发布订阅模式通知其他从服务器切换主机(修改配置文件)。

 除此之外,Redis 还可以使用多哨兵模式进行监控,各个哨兵之间还会进行监控。哨兵进程使用流言协议接收 master 是否下线的信息,并使用投票协议来决定是否执行故障迁移以及选用哪个服务器作为主服务器。

 故障切换(failover)是当单一哨兵检测到 master 泵机,发生主观下线。第一个哨兵发现后会向其他哨兵间歇性发送 “is master down by addr <ip><port>”获取响应信息,如果发现的哨兵到达一定数量(quorum预设值),即到达一致,进行failover操作,切换成功后会发生订阅模式,各个邵明把自己监控的从服务器切换主机,发生客观下线

 Failover:failover前等待0-5秒让其他哨兵实例准备。查找slave,选一个状态良好,权重最低的slave为master。该slave提升为master后,等待其他哨兵提升,都成功后,对slave配置文件进行修改,告知slave跟随新的master,一个一个同步。

 Leader 选举:master的选举以及slave的重配置和同步中涉及到重选 leader作为调度,通过更改配置文件中的参数实现配置,在“can-failover”的哨兵中按照runid字典顺序排序,选举最小的哨兵作为leader。

4. Redis 单线程结构优缺点?

 优势:避免线程切换产生切换CPU的时间;避免锁的开销。

 缺点:无法发挥多核CPU的性能;

 

 redis 使用 io 复用的 Epoll 和输入缓冲区把命令按照队列先进先出,让单线程高效处理多个请求。

5. Redis 的缺点导致那些命令在Redis上不可用?

 Keys、hgetall、scan等

6. Redis vs Memcached

 速度快,支持数据类型多,可以持久化数据。

7. Redis集群方案

 1. 代理twemproxy & codis:一致性hash算法转接redis

 2. 自带集群:hash槽,16384个哈希槽,每个key通过CRC16校验后 mod 16394来决定放哪个槽。主从复制,异步,不能保证强一致性

 也可以在自己的业务逻辑层写=。=

Redis 知识整理的更多相关文章

  1. Redis知识整理

    Redis知识整理 转自:https://www.cnblogs.com/rjzheng/p/9096228.html 1.单线程模型 Redis客户端对服务端的每次调用都经历了发送命令,执行命令,返 ...

  2. Redis 知识 整理

    简介 安装 启动 注意事项 使用命令 通用命令 数据结构 字符串(string) 哈希(hash) 队列(list) 集合(set) 有序集合(zset) 位图(bitcount) 事务 订阅与发布 ...

  3. Redis相关知识整理

    Redis相关知识整理 1. Redis和MySQL的区别?a).mysql是关系型数据库,而redis是NOSQL,非关系型数据库.mysql将数据持久化到硬盘,读取数据慢,而redis数据先存储在 ...

  4. [Redis知识体系] 一文全面总结Redis知识体系

    本系列主要对Redis知识体系进行详解.@pdai Redis教程 - Redis知识体系详解 知识体系 学习资料 知识体系 知识体系 相关文章 首先,我们通过学习Redis的概念基础,了解它适用的场 ...

  5. js事件(Event)知识整理

    事件(Event)知识整理,本文由网上资料整理而来,需要的朋友可以参考下   鼠标事件 鼠标移动到目标元素上的那一刻,首先触发mouseover 之后如果光标继续在元素上移动,则不断触发mousemo ...

  6. Kali Linux渗透基础知识整理(四):维持访问

    Kali Linux渗透基础知识整理系列文章回顾 维持访问 在获得了目标系统的访问权之后,攻击者需要进一步维持这一访问权限.使用木马程序.后门程序和rootkit来达到这一目的.维持访问是一种艺术形式 ...

  7. Kali Linux渗透基础知识整理(二)漏洞扫描

    Kali Linux渗透基础知识整理系列文章回顾 漏洞扫描 网络流量 Nmap Hping3 Nessus whatweb DirBuster joomscan WPScan 网络流量 网络流量就是网 ...

  8. wifi基础知识整理

    转自 :http://blog.chinaunix.net/uid-9525959-id-3326047.html WIFI基本知识整理 这里对wifi的802.11协议中比较常见的知识做一个基本的总 ...

  9. 数据库知识整理<一>

    关系型数据库知识整理: 一,关系型数据库管理系统简介: 1.1使用数据库的原因: 降低存储数据的冗余度 提高数据的一致性 可以建立数据库所遵循的标准 储存数据可以共享 便于维护数据的完整性 能够实现数 ...

随机推荐

  1. PHP 以最快的方式判断字符串是否以某给定字符串开始

    好久没搞代码了,最近找工作,重操旧业,在整理以前写的框架的时候发现,之前的自动加载部分执行速度上还是有可优化空间的,就是如果类名是以 risen\ 开始的(我的框架中的类都在此命名空间下),那么可直接 ...

  2. linux下如何查看某软件是否已安装

      因为linux安装软件的方式比较多,所以没有一个通用的办法能查到某些软件是否安装了.总结起来就是这样几类: 1.rpm包安装的,可以用rpm -qa看到,如果要查找某软件包是否安装,用 rpm - ...

  3. Promise的那些事儿

    在JavaScript中,异步操作非常多见,然而在Promise之前,我们是在类似以下的做法中处理多重异步回调,每一层里都要调另一个异步函数,形成了所谓的"回调地狱", Promi ...

  4. html5css练习 旋转

    <!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8&qu ...

  5. 2018 CCPC网络赛 几道数学题

    1002 Congruence equation 题目链接  : http://acm.hdu.edu.cn/showproblem.php?pid=6439 题解 : https://www.zyb ...

  6. Spring boot 源码分析(前言)

    开坑达人 & 断更达人的我又回来了 翻译的坑还没填完,这次再开个新坑= = 嗯,spring boot的源码分析 本坑不打算教你怎么用spring boot = = 也不打算跟你讲这玩意多方便 ...

  7. 信步漫谈之Quartz—分布式调度(整合spring早期版本【低于spring3.1】)

    一.环境 使用的jar包:spring2.5.6.quartz1.8.6 二.注意点 因为spring内置的quartz版本变化,所以存在spring和quartz版本接口兼容情况,如下: 1)spr ...

  8. postgresql 自定义聚合函数

    方法1 CREATE OR REPLACE FUNCTION public.sfun_test1( results numeric[], val numeric) RETURNS numeric[] ...

  9. Linux can双机通信(2440+MCP2515 && 51+SJA1000)

    2012-01-12 22:43:24 上图: 自收发成功完成后,那么双机通信就比较容易了.关键就是CAN波特率.ID标识.滤波设置正确即可双机通信了.

  10. 创建我的vue项目

    vue-cli 全局安装 1.命令行执行:npm install --global vue-cli: ------也可以用这个命令下载新版本 2.安装完成以后 可以输入命令 :vue 回车,可以看到针 ...