搭建Redis主从集群+哨兵+代理predixy

这篇具有很好参考价值的文章主要介绍了搭建Redis主从集群+哨兵+代理predixy。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


前言

提示:这里可以添加本文要记录的大概内容:

搭建了一个 Redis 服务器集群(主从复制+哨兵模式+代理),实现了主从配置和容灾部署,使得主机出现故障时,可自动进行容灾切换,现详细记录下搭建过程以及遇到的问题


提示:以下是本篇文章正文内容,下面案例可供参考

一、Redis是什么?

Redis(Remote Dictionary Server 远程字典服务)是一个开源的高性能key-value数据库,它通常被称为数据结构服务器,因为值(value)可以是 字符串(String), 哈希(Hash), 列表(list), 集合(sets) 和 有序集合(sorted sets)等类型,官网:https://redis.io/。

1、Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
2、Redis不仅仅支持简单的key-value类型的数据,同时还提供 list,set,zset,hash等数据结构的存储。
3、Redis支持数据的备份,即master-slave模式的数据备份。
不多说网上资料很多

二、搭建Redis集群步骤

1.环境和版本

操作系统:Linux Centos7
Redis版本:redis-5.0.14
Predixy版本:predixy-1.0.5

准备四台Linux服务器centos7系统

服务器IP 服务器名 节点类型 进程
10.20.32.75 gremastersvr1 predixy predixy
10.20.32.76 grestandsvr1 master redis,sentinel
10.20.32.77 gresegsvr1 slave redis,sentinel
10.20.32.78 gresegsvr2 slave redis,sentinel

2.Redis 安装部署

Master,Slave 三台服务器上分别安装Redis
代码如下(示例):

----#安装Redis
root: mkdir -p /data/redis
root: cd /data/redis
##--解压
root: tar -zxvf redis-5.0.14.tar.gz
root: cd redis-5.0.14
root: make
##命令安装redis到/usr/local/redis中
root: make PREFIX=/usr/local/redis install 
root: cd /usr/local/redis/bin
##进入到redis-5.0.14中复制redis.conf 到  /usr/local/redis/bin下面
##将redis.conf修改daemonize yes 以后端模式启动
##将redis.config里面的bind 127.0.0.1修改为0.0.0.0,不然只允许本机连接,客户端连接的话会拒绝连接
##将redis.config里面的requirepass 123456
##并且将protected-mode no改为yes,意思是是否开启保护模式
root: ./redis-server redis.conf
##查看进程
root: ps -aux | grep redis
##杀死进程
root:kill -9 840

3.主从同步配置

代码如下(示例):

10.20.32.76 主服务(读写)
10.20.32.77 从服务()
10.20.32.78 从服务()

##主redis.config配置
bind:0.0.0.0           #Redis 默认只允许本机访问,把 bind 修改为 0.0.0.0 表示允许所有远程访问,如果想指定限制访问,可设置对应的 ip。
port:6379                 # 监听端口默认为6379,想改其他也行。
protected-mode:no         #关闭保护模式,可以外部访问。
daemonize:yes             #设置为后台启动
logfile:./redis.log       #日志文件,这里放置在当前配置文件目录下,生成后在 bin 目录下可找到
requirepass:123456  #设置 redis 连接密码,如果不需要则可以不用配置
masterauth:123456   #slave 服务连接 master 的密码,如果master没有设置密码则可以不用配置

##从redis.config配置
bind:0.0.0.0           #Redis 默认只允许本机访问,把 bind 修改为 0.0.0.0 表示允许所有远程访问,如果想指定限制访问,可设置对应的 ip。
port:6379                 # 监听端口默认为6379,想改其他也行。
protected-mode:no         #关闭保护模式,可以外部访问。
daemonize:yes             #设置为后台启动
logfile:./redis.log       #日志文件,这里放置在当前配置文件目录下,生成后在 bin 目录下可找到
requirepass:123456  #设置 redis 连接密码,如果不需要则可以不用配置
masterauth:123456   #slave 服务连接 master 的密码,如果master没有设置密码则可以不用配置
replicaof 10.20.32.76 6379  ## 指定当本机为slave服务时,设置master服务的IP地址及端口,在redis启动的时候他会自动跟master进行数据同步,master主机可以不用配置

master服务器发送
set k1 zhanglong
搭建Redis主从集群+哨兵+代理predixy
slave2从自动获取值
搭建Redis主从集群+哨兵+代理predixy
slave1从自动获取值
搭建Redis主从集群+哨兵+代理predixy
主从复制配置成功

4.哨兵模式配置

哨兵可以进行故障转移,如果主宕机了,会投票选出一个新的主,然后原来的主上线后自动变成从机,保证服务的高可用
代码如下(示例):

##修改sentinel.conf配置文
//端口默认为26379。 
port 26379 
//关闭保护模式,可以外部访问。 
protected-mode no 
//设置为后台启动。 
daemonize yes 
//日志文件。 
logfile ./sentinel.log 
//指定主机IP地址和端口,并且指定当有2台哨兵认为主机挂了,则对主机进行容灾切换。 
sentinel monitor mymaster 10.20.32.76 6379 2 
//当在Redis实例中开启了requirepass,这里就需要提供密码。如果没有设置密码则不需要 
sentinel auth-pass mymaster 123456 
//这里设置了主机多少秒无响应,则认为挂了。 
sentinel down-after-milliseconds mymaster 3000 
//主备切换时,最多有多少个slave同时对新的master进行同步,这里设置为默认的1。 
snetinel parallel-syncs mymaster 1 
//故障转移的超时时间,这里设置为三分钟。 
sentinel failover-timeout mymaster 180000 

##sentinel.conf复制到/usr/local/redis/bin下面

##启动哨兵
root: cd /usr/local/redis/bin
root:  ./redis-sentinel  sentinel.conf

#查看哨兵信息
root: ./redis-cli -p 26379 
info sentinel

将Master 的Redis进程Kill
搭建Redis主从集群+哨兵+代理predixy
通过代理发送值
搭建Redis主从集群+哨兵+代理predixy
其他Redis服务器能获取值
搭建Redis主从集群+哨兵+代理predixy
搭建Redis主从集群+哨兵+代理predixy
Master 自动切换到gresegsvr2
搭建Redis主从集群+哨兵+代理predixy
搭建Redis主从集群+哨兵+代理predixy
搭建Redis主从集群+哨兵+代理predixy

哨兵模式配置成功

5.代理predixy配置

代码如下(示例):

root: mkdir -p /data/predixy
root: cd /data/predixy
root: tar -xzf predixy-1.0.5-bin-amd64-linux.tar.gz
##部署到工作目录
root: mv predixy-1.0.5 /usr/local/
##修改配置文件
root: cd /usr/local/predixy-1.0.5/conf/

##predixy的配置类似redis, 具体配置项的含义在配置文件里有详细解释,请参考下列配置文件:

##predixy.conf:整体配置文件,会引用下面的配置文件
##cluster.conf:用于Redis Cluster时,配置后端redis信息
##sentinel.conf:用于Redis Sentinel时,配置后端redis信息
##auth.conf:访问权限控制配置,可以定义多个验证密码,可每个密码指定读、写、管理权限,以及定义可访问的健空间
##dc.conf:多数据中心支持,可以定义读写分离规则,读流量权重分配
##latency.conf: 延迟监控规则定义,可以指定需要监控的命令以及延时时间间隔

##修改配置文件predixy.conf
Bind 0.0.0.0:7617
Include sentinel.conf
# Include try.conf

##因为我们的集群就是主从集群+sentinel监控,所以主要配置sentinel.conf
SentinelServerPool {
    Password 123456
    Databases 16
    Hash crc16
    HashTag "{}"
    Distribution modula
    MasterReadPriority 60
    StaticSlaveReadPriority 50
    DynamicSlaveReadPriority 50
    RefreshInterval 1
    ServerTimeout 1
    ServerFailureLimit 10
    ServerRetryTimeout 1
    KeepAlive 120
    Sentinels {
        + 10.20.32.76:26379
        + 10.20.32.77:26379
        + 10.20.32.78:726379
    }
    Group mymaster {
        + 10.20.32.76:6379
        + 10.20.32.77:6379
        + 10.20.32.78:6379		
    }
}

##启动predixy
root: cd /usr/local/predixy-1.0.5/
root: /usr/local/predixy-1.0.5/bin/predixy /usr/local/predixy-1.0.5/conf/predixy.conf

工具连接代理服务器
搭建Redis主从集群+哨兵+代理predixy
通过代理发送设置的值
搭建Redis主从集群+哨兵+代理predixy
Redis三台服务器获取代理发送的值
搭建Redis主从集群+哨兵+代理predixy
搭建Redis主从集群+哨兵+代理predixy
搭建Redis主从集群+哨兵+代理predixy
代理配置成功


总结

记录点点滴滴文章来源地址https://www.toymoban.com/news/detail-432898.html

到了这里,关于搭建Redis主从集群+哨兵+代理predixy的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Redis学习笔记02(主从同步,哨兵,哨兵集群)

    redis具有高可靠性:1.数据尽量减少丢失(AOF和RDB来保障) 2.服务尽量减少中断.第二点通过增加冗余副本来保障。 读写分离:  减少保障数据一致性的开销。修改操作只会在主库上进行。 同步过程  1.psync包括了主库runID和复制进度offset。第一次采用全量复制协议(主库bgsav

    2024年02月02日
    浏览(89)
  • Redis 主从复制 哨兵 集群

    主从复制,是指将一台Redis服务器的数据,复制到其他的Redis服务器。前者称为主节点(Master),后者称为从节点(Slave);数据的复制是单向的,只能由主节点到从节点。 默认情况下,每台Redis服务器都是主节点;且一个主节点可以有多个从节点(或没有从节点),但一个从节点只能

    2024年02月11日
    浏览(52)
  • 【Redis】3、Redis主从复制、哨兵、集群

    主从复制,是指将一台Redis服务器的数据,复制到其他的Redis服务器。前者称为主节点(Master),后者称为从节点(Slave);数据的复制是单向的,只能由主节点到从节点。 默认情况下,每台Redis服务器都是主节点;且一个主节点可以有多个从节点(或没有从节点),但一个从节点只能

    2024年02月09日
    浏览(43)
  • redis主从复制、哨兵与集群

    目录 一、概述 二、redis主从复制 1、概念 2、主从复制的作用 3、主从复制流程 4、搭建Redis 主从复制实验 ①在三台服务器上安装redis (1)关闭防火墙和安全机制 (2)修改内核参数 (3)安装redis (4)创建redis工作目录 (5)准备环境变量 (6)定义systemd服务管理脚本 ②修改

    2024年02月03日
    浏览(49)
  • redis的主从复制、哨兵、集群

    主从复制,是指将一台Redis服务器的数据,复制到其他的Redis服务器。前者称为主节点(Master),后者称为从节点(Slave);数据的复制是单向的,只能由主节点到从节点。 原理: 主从关系确定好后,开启从节点时,会发送一个sync的同步命令给主节点,主节点接收到后会把redis内存

    2024年02月06日
    浏览(47)
  • redis之主从复制、哨兵、集群

    在web服务器中,高可用是指服务器可以正常访问的时间,衡量的标准是在多长时间内可以提供正常服务(99.9%、99.99%、99.999%等等)。 高可用的计算公式是1-(宕机时间)/(宕机时间+运行时间)有点类似与网络传输的参数误码率,我们用9的个数表示可用性: 2个9:99%,一年内宕

    2024年02月11日
    浏览(48)
  • Redis 主从配置、哨兵、集群模式

    目录 Redis 主从复制  主从复制的作用: 主从复制流程: 搭建Redis 主从复制 安装 Redis 环境准备 修改内核参数 安装redis 创建redis工作目录 环境变量 定义systemd服务管理脚本 修改 Redis 配置文件(Master节点操作) 修改 Redis 配置文件(Slave节点操作) 验证主从效果 Redis 哨兵模式

    2024年02月12日
    浏览(59)
  • 3.Redis主从复制、哨兵、集群

    Redis主从复制,是指将一台Redis服务器的数据,复制到其他的Redis服务器。前者称为主节点(Master),后者称为从节点(Slave):数据的复制是单向的,只能由主节点到从节点。 默认情况下,每台Redis服务器都是主节点:且 一个主节点可以有多个从节点(或没有从节点),但一个从节点只

    2024年02月12日
    浏览(61)
  • Redis高可用(主从复制,哨兵,集群)

    主从复制,是指将一台Redis服务器的数据,复制到其他的Redis服务器。前者称为主节点(Master),后者称为从节点(slave);数据的复制是单向的,只能由主节点到从节点。 默认情况下,每台Redis服务器都是主节点;且一个主节点可以有多个从节点(或没有从节点),但一个从

    2024年02月07日
    浏览(35)
  • Redis高可用主从复制、哨兵、集群

    在Redis中,实现高可用的技术主要包括持久化、主从复制、哨兵和集群。 1、主从复制 主从复制时高可用Redis的基础,哨兵和cluster都是在主从复制基础上实现高可用的,主从复制主要实现了数据的多级备份,以及对与读操作的负载均衡和简单的故障恢复。 缺陷:①故障恢复无

    2024年02月12日
    浏览(51)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包