redis主从+哨兵+集群模式搭建详解

news/2024/5/6 0:18:12/文章来源:https://blog.csdn.net/axibazZ/article/details/127057006

一、redis主从安装

1. 下载redis

Download | Redis

我这里选择的是redis-6.2.7版本

这里三台机器,都需要安装redis

node1 192.168.157.128

node2 192.168.157.129

node3 192.168.157.130

2. 安装redis

# 解压redis
tar -zxvf redis-6.2.7.tar.gz
# 编译安装
cd redis-6.2.7
make

3. 修改配置

node1 主 node2 node3从

node1 redis.conf

bind  192.168.157.128
port 6379 
daemonize yes 
logfile ./logs/redis_6379.log
pidfile  ./pid/redis_6379.pid
requirepass 123456
masterauth  123456

node2

bind  192.168.157.129
port 6379 
daemonize yes 
logfile ./logs/redis_6379.log
pidfile  ./pid/redis_6379.pid 
replicaof  192.168.157.128 6379
requirepass 123456
masterauth  123456

node3

bind  192.168.157.130
port 6379 
daemonize yes 
logfile ./logs/redis_6379.log
pidfile  ./pid/redis_6379.pid 
replicaof  192.168.157.128 6379
requirepass 123456
masterauth  123456

4. 相关解释

bind 为当前主机的地址

port 为redis启动的端口

daemonize 是否为后台启动,默认为no

logfile 日志路径

pidfile pid路径

replicaof 主节点ip  port

requirepass redis的密码

masterauth 主节点密码

5. 启动redis

# 在redis.conf文件目录下
./src/redis-server redis.conf

查看日志文件输出,可以看到129和130已经同步完成。

6. 测试

在node1的redis中存数据,查看node2,node3中是否存在。

使用redis-cli 连接redis 

# h 主机地址 p 端口号 a 密码
redis-cli -h 192.168.157.128 -p 6379 -a 123456
# 也可以进入之后使用auth 123456 来认证
redis-cli -h 192.168.157.128 -p 6379
auth 123456

从节点输入命令 info replication 查看

 主节点node1中设置set name jack

从节点可以get name

 从节点只能读不能写

 7. 注意

  • 主节点可以写,从节点不能写,只能读。主节点中的所有数据都会保存到从节点中去。
  • 主节点断开连接,从节点依旧连接到主节点的,但是没有写操作,这个时候,主节点如果回来了,从节点依旧可以直接获取到主节点写的信息!
  • 如果是使用命令行,来配置的主从,这个时候如果重启了,就会变回主节点!只要变为从节点,立马就会从主节点中获取值!

8. 主从复制原理

  • Slave 启动成功连接到 master 后会发送一个sync同步命令。
  • Master 接到命令,启动后台的存盘进程,同时收集所有接收到的用于修改数据集命令,在后台进程执行完毕之后,master将传送整个数据文件到slave,并完成一次完全同步。
  • 全量复制: slave服务在接收到数据库文件数据后,将其存盘并加载到内存中。
  • 增量复制: Master 继续将新的所有收集到的修改命令依次传给slave,完成同步,但是只要是重新连接master,一次完全同步(全量复制)将被自动执行! 主节点的数据一定可以在从节点中看到。
     

二、 Redis 哨兵模式

1. 配置sentinel.conf文件

port 26379
protected-mode no
daemonize yes
logfile ./logs/sentinel.log
sentinel monitor redis-master 192.168.157.128 6379 2
sentinel auth-pass redis-master 123456
sentinel down-after-milliseconds redis-master 3000
sentinel failover-timeout redis-master 180000

port 哨兵模式的端口号

protected-mode 保护模式,外部是否可以访问,这是设置为no,外部可以访问

daemonize 设置后台启动

logfile 日志文件

sentinel monitor 执行服务器ip和端口,并且指定当有2台哨兵认为主节点挂了,则对主节点进行容灾切换

sentinel auth-pass 主节点对应的密码

sentinel down-after-milliseconds 主节点多久每反应则认为挂了

sentinel failover-timeout 故障转移超时时间(毫秒)

2. 分别启动三台服务器上的哨兵

# 在sentinel.conf目录下,启动哨兵
./src/redis-sentinel sentinel.conf

3. 查看sentinel.log日志

可以看到启动成功,并且成功监听 master

4. 查看sentinel信息

 5. Redis 容灾切换模拟

将node1 redis服务停掉

可以看到redis-master的状态先变成down,然后重新选择一个master,192.168.157.130成为新的主节点

 重新启动192.168.157.128节点的redis,查看sentinel.log信息,可以看到此时128节点的redis变成了slave 从节点了。

 三、redis集群模式

这里选择每台机器启动两个redis服务,端口分别为7001和7002

1. 准备redis工作目录

#创建redis01 redis02目录
mkdir redis01 redis02
#将redis复制到redis01和redis02下
cp -R redis-6.2.7/ redis01/
cp -R redis-6.2.7/ redis02/
#删除rdb文件
rm -rf redis01/dump.rdb
rm -rf redis02/dump.rdb

2. 修改配置

redis.conf

bind 192.168.157.129
port 7001
daemonize yes
logfile "./logs/redis_7001.log"
pidfile "./pid/redis_7001.pid"
requirepass "123456"
masterauth "123456"
dir "/opt/apps/redis01/data"
cluster-enabled yes
cluster-node-timeout 10100
appendonly yes

主要增加了cluster-enabled yes 这个配置,表示开启集群

3. 启动每个redis

./src/redis-server redis.conf

4. 创建redis集群

在任意一台机器上执行创建集群命令

./src/redis-cli --cluster create \
192.168.157.128:7001 192.168.157.128:7002 \
192.168.157.129:7001 192.168.157.129:7002 \
192.168.157.130:7001 192.168.157.130:7002 \
--cluster-replicas 1 -a 123456

--cluster-replicas 1 表示一主一从

-a 是密码

创建完成的打印信息 

5. 查看集群信息

#连接 -c 以集群模式连接
./src/redis-cli -h 192.168.157.128 -c -p 7001 -a 123456
#查看节点信息
cluster nodes

 存数据和取数据都会告诉你在哪个槽哪个服务上

当我们手动停掉一个master时,会重新选一个master,而那个停掉的master重新启动后成为slave节点。

 至此集群搭建完成。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_203660.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据分析 面经(已拿到offer)

北航计算机专业(计院太卷,现考虑转向信息安全方向)本科二年级,闲来无事找份日常实习试试水 考虑数分岗也是因为楼主目前大二,专业课学习不够深入,开发技术尚不成熟,而sql、excel和数据可视化比…

四元数是什么

1、四元数的构成 四元数是简单的超复数,由实数加上三个虚数单位组成,主要用于在三维空间中表示旋转 四元数原理包含大量数学相关知识,较为复杂,比如:复数、四维空间等等 因此此文章只对其基本构成和基本公式进行学习…

多视图属性网络异常检测系列一

论文《Deep Anomaly Detection on Attributed Networks》近期会对多视图属性网络异常检测系列进行学习记录 这篇虽然不是多视图的,但可以说是属性网络上异常检测的典型,已是近年属性网络异常检测必参考的一篇文献。背景 由于属性网络中附加的节点属性补充了知识发现中的原始网…

.Net Redis的秒杀Dome和异步执行

1.先到官网下载Redis部署好 Redis 教程 | 菜鸟教程 2.创建一个上游业务项目(这里用控制台项目了,Framwork4.7.2) NuGet包下载SerivceStack.Redis 创建一个RedisMessgaeQueue(Redis连接帮助类) using ServiceStack.Redis; using System;name…

PCIe系列专题之三:3.0 数据链路层概述

一、故事前传 之前我们讲了对PCIe的一些基础概念作了一个宏观的介绍,了解了PCIe是一种封装分层协议(packet-based layered protocol),主要包括事务层(Transaction layer), 数据链路层(Data link layer)和物理层(Physi…

MySQL 常用数据类型说明

目录 MySQL中常用的数据类型 整型 整型声明 整型属性 整型的选择 浮点型 定点数类型 浮点数和定点数的区别 时间日期类型 DATE类型 TIME类型 DATETIME类型 YEAR类型 文本字符串 CHAR与VARCHAR类型 TEXT类型 ​编辑 枚举类型(ENUM) MySQL中常用的数据类型 数据类…

直播平台怎么搭建,实现js开光灯效果

直播平台怎么搭建,实现js开光灯效果<!DOCTYPE html><html><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>点击切换灯亮</t…

Spring容器与依赖注入(DI)

1 Spring框架简介 1.1 什么是Spring Spring框架是一个开源的轻量级的DI和AOP容器框架&#xff0c;致力于简化企业级应用开发&#xff0c;让开发者使用简单的Java Bean来实现从前只有EJB才能实现的功能。 1.2 为什么要使用Spring Spring堪称Java世界中最强大的框架&#xff0c;…

单调栈题目:柱状图中最大的矩形

文章目录题目标题和出处难度题目描述要求示例数据范围解法思路和算法代码复杂度分析题目 标题和出处 标题&#xff1a;柱状图中最大的矩形 出处&#xff1a;84. 柱状图中最大的矩形 难度 7 级 题目描述 要求 给定整数数组 heights\texttt{heights}heights 表示柱状图中…

正弦信号发生器的设计

目 录 1 引言 1 2 总体结构设计 2 2.1 单片机概述 2 2.1.1 单片机的发展 2 2.1.2 单片机的用途 3 2.2 系统设计的功能 3 2.3 波形发生和输出频率的方法 4 2.3.1 波形发生的方法 4 2.3.2 输出频率的方法 4 3 系统硬件设计 5 3.1 硬件电路芯片的选择 5 3.1.1 CPU芯片 AT89C51 5 3…

MyBatis中的复杂映射

上一章中实现的MyBatis对象映射较为简单&#xff0c;对象中的属性和数据库中的表字段是一一对应的&#xff08;无论数量和名称都完全一样&#xff09;&#xff0c;如果对象中的属性名和表中的字段名不一致怎么办&#xff1f;又或者Java对象中存在复杂类型属性&#xff08;即类似…

百分点数据科学产教融合计划继续扩大招募

从全球发展来看&#xff0c;数字经济已经成为重组全球要素资源、重塑全球经济结构、改变全球竞争格局的关键力量&#xff0c;是全球共同的发展战略。作为新经济中的数据科学&#xff0c;伴随社会各领域对数字人才需求的与日俱增&#xff0c;也成为了这一波科技革命中的人才竞争…

中国新出海故事:人、疫情与纽带

【潮汐商业评论/原创】 《枪炮、病菌与钢铁》中对人类社会发展的洞察与新千禧年发生了奇妙的呼应&#xff0c;战争、疫情成为了这十年的历史注脚&#xff0c;但时代的车轮总是滚滚向前的&#xff0c;新的世界版图里&#xff0c;全球化、数字化的浪潮构成了新世界跳动的脉搏&am…

第2章 ROS 通信机制 4 —— 常用命令

文章目录1 应用场景2 rosnode 功能包 plumbing_pub_sub编译执行3 rostopic 功能包 plumbing_pub_sub编译执行4 rosservice (服务通信) 功能包 plumbing_server_client编译执行5 rosmsg (话题通信) 功能包 plumbing_pub_sub编译执行6 rossrv (服务通信) 功能包 plumbing_server_…

常见网络知识面试题总结

&#x1f353;个人主页&#xff1a;个人主页 &#x1f352;系列专栏&#xff1a;C/C基础与进阶 &#x1f4ac;推荐一款模拟面试、刷题神器&#xff0c;从基础到大厂面试题&#x1f449;点击跳转刷题网站进行注册学习 目录 1、OSI七层模型与TCPIP四层模型是什么&#xff1f; 2…

核爆!字节跳动算法大佬手写1000页数据算法笔记:Github已标星79k

数据结构是什么 数据结构是计算机存储、组织数据的方式。数据结构是指相互之间存在一种或多种特定关系的数据元素的集合。通常情况下&#xff0c;精心选择的数据结构可以带来更高的运行或者存储效率。数据结构往往同高效的检索算法和索引技术有关。 算法是什么 算法是对解题方案…

PC 端网页特效

一、元素偏移量 offset 系列 (一)offset 概述 1、offset 翻译过来就是偏移量,我们使用 offset 系列相关属性可以动态的得到该元素的位置(偏移)、大小等。 (1)获得元素距离带有定位父元素的位置; (2)获得元素自身的大小(宽度高度); (3)注意:返回的数值都不带单位…

使用polkadot.js在substrate frontier上安装ERC20token合约

使用polkadot.js在substrate frontier上安装ERC20token合约参考资料Substrate Frontier Node Template github.com/substrate-developer-hub/frontier-node-template frontier-node-template/examples/contract-erc20/truffle/contracts/MyToken.json安装ERC20 token合约 sourc…

SwiftUI AR教程之应用程序中使用 RealityKit 生成 3D 文本(教程含完整源码)

项目文件 基本设置 我们将从 Xcode 上的“增强现实应用程序”模板开始: 我使用 SwiftUI 作为界面,使用 Swift 作为语言,使用 RealityKit 作为内容技术: 您现在应该拥有基本的增强现实应用程序模板代码。 使用 RealityKit 生成 3D 文本网格 我们将向我们的项目添加一个函…

快速入门SSMS的使用

快速入门SSMS的使用1.Install SSMS2.Demo2.1 Export DDL2.2 XXXXX3.XXXX4.Waken1.Install SSMS 官方地址 SSMS Website: https://learn.microsoft.com/zh-tw/docs/. 也可以直接下载 Download Website: https://aka.ms/ssmsfullsetup.双击安装 要有电脑的管理员权限 快速启动…