redis简介

redis是一种非关系性数据库,单进程工作模型,通常用来做KV存储,同memcached一样,所有数据加载至内存工作因此工作效率非常快,但他会将内存中的数据同步至磁盘当中,使得数据不会像memcached的一样,断电后丢失数据。

自身支持多种数据结构(此处列出常用数据结构)

string:单一的kv存储

hash:支持hash计算后的存储

list:列表存储

set:无序集合

sortset:有序集合

另外redis还支持作为消息队列使用

支持不严格的事务,redis的事务属于将多个语句打包一次性执行,但如果在执行过程中发现单个语句发生了错误,不会进行回滚,而会继续往下执行,但好在redis给我们提供了一个watch功能,如果在一次事务中,事务所需要修改到的数据如果发生了改变,执行时会拒绝执行。在事务执行时,redis不会接收任何其他指令,直到事务完成以后再执行其他操作。

redis像磁盘中同步数据的方式有两种,RDB(snapshot)和AOF(appendonlyfile),RDB类似于我们在mysql中的备份策略,定期的向磁盘进行同步。AOF类似于mysql中的二进制文件一样,将语句追加至文件中。

redis常用场景,一般作为kv存储使用或者在需要使用消息队列时用到。

redis同样支持主从复制,一主多从,并且支持链式复制,主从服务器都异步同步数据,因此同步过程中从服务器仍能接受读请求,主仍能接受读写请求,

同步方式:在从服务链接到主服务器会发出同步指令,主服务器收到后会将内存中所有数据同步至RDB(快照)文件中,在发送给从服务器,从服务器在接受到后加载至内存中,以完成同步。

尽管如此redis还是和mysql一样,面临主节点意外down机后,不能进行自动主从切换。redis直接提供了解决方案,在redis中有个叫sentinel的组件,他负责监控主节点存活状态,如果主节点无法联系,会选举出从节点变更为主节点。

下面演示一下redis主从,以及基于sentinel实现主节点down机后自动切换

准备了3个节点,一主一从一sentinel

做好时间同步,配置好epel源,直接安装

[root@localhost ~]# vi /etc/redis.conf

编辑主服务器配置文件,这里做实验使用只需要修改主配置文件监听在自己的IP地址上。

redis简介

编辑从配置文件添加

redis简介

slaveof  [主ip] [主port]                    #主服务器IP 和端口

启动服务

redis简介

登录主服务器,查看是否以有从服务器,接着可以插入些key 看同步是否成功

redis简介

插入两条数据

redis简介

在从服务器上验证~说明此事同步成功。

接着我们来配置sentinel节点。

[root@localhost ~]# vi /etc/redis-sentinel.conf 

编辑配置文件

修改以下几行

sentinel monitor mymaster 192.168.20.108  6379 1

mymaster指明集群名称,可以随便给,后面是主节点IP和端口,最后的1代表几个sentinel认为主节点down了过后就可以进行切换,可以理解为票数。(避免sentinel节点自己于主节点通讯不正常,但能联系到其他从节点,进行错误的切换,在常用情况下应该配置基数个节点的sentinel以避免发生上诉情况)

sentinel down-after-milliseconds mymaster 1000                #此行可不做修改,但这里定义的是多久联系不到主节点,就认为需要切换,默认是30分钟,太长了,我们这里实验用 修改为1分钟

protected-mode no          #在redis3.2过后添加的安全选项,如果没有BINDip,且没有认证方式启动,会自动启动保护模式,远程登陆进去无法做任何操作,这里我们给他指定为不启用保护模式

daemonize yes                #后台运行

[root@localhost ~]# redis-server /etc/redis-sentinel.conf –sentinel             #启动服务

redis简介

链接至sentinel,并且查看是否有主服务器相应信息,这里看到了已经找到主服务器了,接着我去把主服务器关掉

redis简介

关机后立即之前的从服务器就立即变到主的了~


原创文章,作者:N24_Ghost,如若转载,请注明出处:http://www.178linux.com/71265

(0)
N24_GhostN24_Ghost
上一篇 2017-03-17 15:26
下一篇 2017-03-17 19:28

相关推荐

  • Redis基于Sentinel哨兵高可用方案

    下载最新redis版本,当前最新版本为  2.8.19  2014-12-30 安装redis 首页地址:http://redis.io/ 最新稳定版下载地址: http://download.redis.io/releases/redis-2.8.19.tar.gz # tar -xvf redis-2.8.19.tar.gz # cd…

    2015-03-03
  • Centos7 编译安装 zabbix3.0

    服务安装配置: 系统版本:CentOS Linux release 7.2.1511 (Core)   zabbix 安装 关闭firewall:   systemctl stop firewalld.service #停止firewall systemctl disable firewalld.service #禁止firewall开机…

    Linux干货 2016-06-23
  • 用户管理

    用户管理 用户通过uid来识别,用户的uid是全局唯一,Linux用户分三大类: 用户类别可以分为 管理员 系统用户 普通用户 ——管理员的id为0,系统用户的id为1-499,一般用户的id为500- 组也是一样(centos6.9和centos7.3 id编号有所不同)上述是centos6.9的id编号。 管理员账户:root,可…

    2017-06-01
  • tar,cpio,rpm,yum的使用详解(适合初学者)

    基于linux下的tar包管理和yum源配置 友情提示:对于这些实际操作的,还是需要进行手工的尝试,由于这几个对于包管理的是比较常用和实用的, 所以,一定要熟练使用。 1.tar tar是对于系统中文件,目录等进行打包,解包的工具。tar也可以对文件进行打包存放到别的目录下, 所以在很早的时候,一些老的工程师经常使用tar对文件进行备份。很大程度上,所谓的t…

    Linux干货 2016-08-21
  • N26-第一周

    描述计算机的组成及功能。 计算机主要由运算器,控制器,存储器,输入、输出设备五大部件组成 运算器(Arithmetic Logic Unit, ALU):实现各种算数运算和逻辑运算(与控制器组成cpu)。 控制器(Control Unit, CU):计算机控制中心,根据程序规定的控制程序进行解释,根据要求进行调度,控 制协调各部分有条不紊的运行。 存储器(M…

    Linux干货 2017-02-03
  • 马哥教育网络班21期+第3周课程练习

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@centos ~]# who | awk '{print $1 $NF}'| uniq -d root(192.168.40.1) derulo(19…

    Linux干货 2016-07-22

评论列表(1条)

  • 马哥教育
    马哥教育 2017-04-07 18:21

    总结的非常好,可以来一个目录结构~~~~加油!!!