redis主从复制薪火相传

一.主从复制


        1、是什么                

                主机数据更新后根据配置和策略, 自动同步到备机的master/slaver机制,Master以写为主,Slave以读为主

        2、能干嘛                

                读写分离,性能扩展(主 写 从 读)

                容灾快速恢复

        3、 主从复制                

                一主二仆

                更改端口号

                6379

                6380 zh 6381 6382

                拷贝多个redis.conf文件include(写绝对路径)

                开启daemonize yes

                Pid文件名字pidfile

                指定端口port

                Log文件名字

                dump.rdb名字dbfilename

                Appendonly 改为no

                注意:不能设置密码

        创建文件

                移动到这个目录下

                

                修改这个文件

                

                redis6380.conf需要配置的东西

include /usr/gkf/redis-5.0.14/redis.conf
port 6380
daemonize yes
dir /usr/myredis
dbfilename dump6380.rdb
pidfile /var/run/redis_6380.pid
bind 0.0.0.0
protected-mode no

        
                启动命令 /usr/redis/bin/redis-server /usr/myredis/redis6380.conf

                链接成功  

                因为没有设置密码,可以直接链接

                

                其余里面的内容的信息是一样的,不过把6380替代对应的

                                

                启动三台redis服器

                /usr/java/redis/bin/redis-server /usr/java/myredis/redis6379.conf

                /usr/java/redis/bin/redis-server /usr/java/myredis/redis6380.conf

                /usr/java/redis/bin/redis-server /usr/java/myredis/redis6381.conf

                新开一个虚拟机连接6381和6382    

          

                redis_6381.conf

                include /usr/java/myredis/redis.conf

                pidfile /var/run/redis_6381.pid

                port 6381

                dbfilename dump6381.rdb

                查看三台服务器的运行情况

                连接客户端 :./redis-cli -p 6379

                查看运行 状态:info replication

                

                三台都是主机

                配置从机

                6379 主 80 81从

                slaveof

                成为某个实例的从服务器

                1.在6380和6381上执行: slaveof 127.0.0.1 6379

                 在80里面查看

                2.在主机上写,在从机上可以读取数据

                                                ​​​​​​​        ​​​​​​​        ​​​​​​​        ​​​​​​​        ​​​​​​​        ​​​​​​​        ​​​​​​​        ​​​​​​​        

                3.主机挂掉,重启就行,一切如初

                从机宕机需要重新启动

                4.从机重启需重设:slaveof 127.0.0.1 6380

        ​​​​​​​        

        4、复制原理

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


       5、 薪火相传        
                

                上一个Slave可以是下一个slave的Master,Slave同样可以接收其他 slaves的连接和同步请求,那么该slave作为了链条中下一个的master, 可以有效减轻master的写压力,去中心化降低风险。

                用 slaveof

                中途变更转向:会清除之前的数据,重新建立拷贝最新的

                风险是一旦某个slave宕机,后面的slave都没法备份

                主机挂了,从机还是从机,无法写数据了

                80 1

                81 2

                82 3

                反客为主
                

        当一个master宕机后,后面的slave可以立刻升为master,其后面的slave不用做任何修改。

                用 slaveof no one 将从机变为主机。

       6、 哨兵模式(sentinel)

                反客为主的自动版,能够后台监控主机是否故障,如果故障了根据投票数自动将从库转换为主库

                

                调整为一主二仆模式,6380带着6381、6382

                自定义的/myredis目录下新建sentinel.conf文件,名字绝不能错

                80

                配置哨兵,填写内容

                sentinel monitor mymaster 192.168.81.33 6380 1

                其中mymaster为监控对象起的服务器名称, 1 为至少有多少个哨兵同意迁移的数量。

        ​​​​​​​        

                ​​​​​​​

                启动哨兵

                        /usr/local/bin/redis-sentinel /usr/myredis/sentinel.conf

                ​​​​​​​

                        宕机6380

                

                        当主机挂掉,从机选举中产生新的主机

                        (大概10秒左右可以看到哨兵窗口日志,切换了新的主机)

                        哪个从机会被选举为主机呢?根据优先级别:replica-priority

                        原主机重启后会变为从机。

                        宕机之后刚才写的sentinel.conf会自动生成一些东西

                        

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

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

相关文章

瑞_力扣LeetCode_二叉搜索树相关题

文章目录 说明题目 450. 删除二叉搜索树中的节点题解递归实现 题目 701. 二叉搜索树中的插入操作题解递归实现 题目 700. 二叉搜索树中的搜索题解递归实现 题目 98. 验证二叉搜索树题解中序遍历非递归实现中序遍历递归实现上下限递归 🙊 前言:本文章为瑞…

【验证码逆向专栏】最新某验三代滑块逆向分析,干掉所有的 w 参数!

声明 本文章中所有内容仅供学习交流使用,不用于其他任何目的,不提供完整代码,抓包内容、敏感网址、数据接口等均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关! 本文章未…

EOCR-FEZ漏电保护器下低压工业领域的应用

电柜中常见的故障主要包括以下几种: 断路器故障:断路器是配电柜中的主要元件之一,常见的故障包括断路器拒动、误动、爆炸、烧毁等。这些故障可能是由于断路器的机械故障、电气故障或者是控制回路的问题所导致的。接触器故障:接触…

华为防火墙USG6000V1的NAT实验

实验拓扑: 之前实验做过,可以翻找之前的博客,各设备ip和接口已配好,均可可ping通防火墙。 实验要求: 一.生产区在工作时间内可以访问dmz区域,仅可以访问http服务器。 二.办公区全天可以访问dmz区域&…

Ceph篇之搭建Ceph可视化界面Dashboard

一、Ceph Dashboard Ceph 提供了原生的Dashboard功能,通过Dashboard可以获取Ceph集群的各种基本状态信息等。 二、搭建Ceph Dashboard step1:在每个mgr节点安装 yum install ceph-mgr-dashboard -ystep2:开启mgr功能 ceph mgr module enab…

全新PHP短网址生成系统,短链接生成系统,URL缩短器系统源码

PHP短网址系统URL缩短器平台,它使您可以轻松地缩短链接,根据受众群体的位置或平台来定位受众,并为缩短的链接提供分析见解。 系统使用了Laravel框架编写,前后台双语言使用,可以设置多域名,还可以开设套餐等…

python24.1.26读文件

打开文件 encoding:编码方式 程序会记录读文件的位置 读一部分文字: 读一行文字: 结合while循环 readlines结合for循环 关闭文件: 或者 实践:

【iOS ARKit】人脸检测追踪基础

在计算机人工智能(Artificial Inteligence,AI)物体检测识别领域,最先研究的是人脸检测识别,目前技术发展最成熟的也是人脸检测识别。人脸检测识别已经广泛应用于安防、机场、车站、闸机、人流控制、安全支付等众多社会领域&#x…

如何配置MacLinuxWindows环境变量

这里写目录标题 什么是环境变量什么是PATH为什么要配置环境变量 如何配置环境变量环境变量有哪些环境变量加载顺序环境变量加载详解 配置参考方法一: export PATHLinux环境变量配置方法二:vim ~/.bashrcLinux环境变量配置方法三:vim ~/.bash_…

从零开始:使用 Systemd 管理 Linux 服务的完全指南

从零开始:使用 Systemd 管理 Linux 服务的完全指南 引言Systemd 简介Systemd 与 SysVinit 的主要区别 Systemd 的核心组件1. systemctl2. systemd-journald3. systemd-analyze4. systemd-tmpfiles 管理服务启动和停止服务重启和重新加载服务查看服务状态管理服务自启…

超越传统,想修哪里就修哪里,SUPIR如何通过文本提示实现智能图像修复

项目简介 通过参数增加使得模型不仅能够修复图像中的错误或损坏,还能根据文本提示进行智能修复。例如根据描述来改变图像中的特定细节。这样的处理方式提升了图像修复的质量和智能度,使得模型能够更准确、更灵活地恢复和改进图像。 SUPIR的主要功能图像…

Azure AI - 沉浸式阅读器,阅读障碍用户福音

目录 一、什么是沉浸式阅读器将内容划分开来提高可读性显示常用字词的图片突出显示语音的各个部分朗读内容实时翻译内容将单词拆分为音节 二、沉浸式阅读器如何工作?环境准备创建 Web 应用项目设置身份验证配置身份验证值安装标识客户端 NuGet 包更新控制器以获取令…

InitVerse:为云计算服务带来更高的透明度和可验证性

InitVerse:为云计算服务带来更高的透明度和可验证性 在云计算服务领域,透明度和可验证性是构建信任的关键要素。传统的云计算市场往往缺乏透明度,用户难以了解其数据和计算资源的实际使用情况。然而,通过利用区块链技术&#xff0…

php下curl发送cookie

目录 一:使用 CURLOPT_COOKIE 选项 二:CURLOPT_COOKIEFILE 三:CURLOPT_HTTPHEADER php curl发送cookie的几种方式,下面来介绍下 一:使用 CURLOPT_COOKIE 选项 通过设置 CURLOPT_COOKIE 选项,你可以将 cookie 字符…

Python数值类型与数学函数:深入理解与高效应用

文章目录 一、Python的数字1.数值类型1.1 整型(int)1.2 浮点型(float)1.3 复数(complex) 2.数字类型转换2.1 int(x)2.2 float(x)2.3 complex(x)2.4 complex(x, y) 3.数字运算3.1 round 二、函数1.数学函数1…

【模拟算法系列】详解5道题

本文讲解模拟算法系列的5道经典题,在讲解题目的同时提供AC代码,点击题目即可打开对应OJ链接 目录 模拟算法的介绍 1、替换所有的问号 2、提莫攻击 3、 Z 字形变换 4、外观数列 5、数青蛙 模拟算法的介绍 题目中明确告诉你要干什么,思路…

在云服务器上通过FileZilla配置FTP(通过FileZilla配置FTP升级版)

有兴趣的读者可以看看博主的博客,有很全面的教程 阿里云之申请云服务器–配置jdk,tomcat,安全策略–能够在他人电脑上显示本电脑的Tomcat 通过FileZilla配置FTP 修改我们的安全组,将21,和50000-50010端口添加进去 加入实例即可,剩…

vue处理后端返回的文件数据流,并提供下载接口

返回的数据流 前端对其进行处理并下载 downloadFile(res, fileName) {// 使用后台返回的数据创建一个新的Blob对象 let blob new Blob([res]); // 如果fileName参数未定义或为空,则从res的headers中获取content-disposition字段,并从中提取文件名 if…

基于阿里云服务器部署幻兽帕鲁联机服务器详细教程

如何自建幻兽帕鲁服务器?基于阿里云服务器搭建幻兽帕鲁palworld服务器教程来了,一看就懂系列。本文是利用OOS中幻兽帕鲁扩展程序来一键部署幻兽帕鲁服务器,阿里云百科aliyunbaike.com分享官方基于阿里云服务器快速创建幻兽帕鲁服务器教程&…

Java实现加权平均分计算程序WeightedAverageCalculator

成绩加权平均分计算程序,带UI界面和输入保存功能。 因为本人对成绩的加权均分有所关注,但学校的教务系统查分时往往又不显示个人的加权均分,加之每次手动敲计算器计算很麻烦就花了点时间写了一个加权均分计算程序自用,顺便开源。…