Redis主从复制(反客为主模式 演示示例)——图解版

2024-01-14 00:30

本文主要是介绍Redis主从复制(反客为主模式 演示示例)——图解版,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

    • 一、Redis主从复制(反客为主的理解)
    • 二、Redis主从复制配置步骤概述
    • 三、lz虚拟机配置说明
    • 四、Redis主从复制(每台服务器的redis配置文件配置步骤)
      • 1、配置master服务器(即IP为192.168.3.15的6379端口)的配置文件
      • 2、配置slave1服务器(即IP为192.168.3.16的6380端口)的配置文件
      • 3、配置slave2服务器(即IP为192.168.3.17的6381端口)的配置文件
    • 五、Redis主从复制(反客为主演示示例,包含各种宕机情况))
      • 1、分别启动3台服务器的redis服务端,并查看3台服务器的角色信息
      • 2、slave1和slave2分别执行slaveof +master服务器ip+端口命令,查看slave1和slave2角色信息,并查看master角色信息。
      • 4、当master服务器宕机后,在slave1服务器中执行slaveof no one命令,slave2服务器重新挂载到slave1服务器中,查看slave1和slave2的角色。
      • 5、当master服务器宕机重新启动后,在次查看slave1服务器和slave2服务器角色。

一、Redis主从复制(反客为主的理解)

在这里插入图片描述

  • 由上图结构可知,反客为主指一个master服务器同时挂2个salve服务器。当master宕机后,在2个slave服务器的哪一台服务器中执行slaveof no one 命令,哪一台服务器就会升级为master服务器。

二、Redis主从复制配置步骤概述

序号配置作用
1配从(库)不配主(库)配置从服务器不配置主服务器
2从库配置,使用 slaveof 主库IP 主库端口 命令slaveof命令再每次与master断开之后,都需要重新连接,除非你配置进redis.conf文件。
3info replication命令查看主/从复制信息
4slaveof no one命令使当前数据库停止与其他数据库同步,转成主数据库
5拷贝redis.conf文件表示指定配置文件启动redis服务
6开启daemonize yes表示是否把redis-server启动在后台,默认是“否”。若改成yes,会生成一个pid文件。
7指定pid文件名字表示pid文件的路径
8指定IP和端口表示指定服务器IP和端口如果是主机的话bind要改成0.0.0.0,从机不需要(主机一定要修改,否则主从连接失败)
9指定log文件名字表示日志文件路径
10指定dump.rdb名字表示数据库文件路径

三、lz虚拟机配置说明

1、三台虚拟机配置说明:

ip端口说明
192.168.3.15(master)6379redis主服务器
192.168.3.16(slave1)6380redis从服务器
192.168.3.17(slave2)6381redis从服务器

2、关闭三台虚拟机的防火墙,保证三台虚拟机的ip和端口都能互相访问通
在这里插入图片描述

四、Redis主从复制(每台服务器的redis配置文件配置步骤)

1、配置master服务器(即IP为192.168.3.15的6379端口)的配置文件

  • 拷贝redis.conf文件为redis6379.conf,并编辑redis6379.conf文件。如下图:
    在这里插入图片描述

  • 开启daemonize yes,如下图:
    在这里插入图片描述

  • 修改pid文件名字为redis_6379.pid,如下图:
    在这里插入图片描述

  • 指定IP和端口(6379),主机一定要把bind 127.0.0.1要改成0.0.0.0,从机不需要(一定要修改,否则主从连接失败),如下图:

    在这里插入图片描述
    在这里插入图片描述

  • 修改log文件名字为6379.log,如下图:
    在这里插入图片描述

  • 修改dump.rdb名字为dump6379.rdb,如下图:
    在这里插入图片描述

2、配置slave1服务器(即IP为192.168.3.16的6380端口)的配置文件

  • 拷贝redis.conf文件为redis6380.conf,并编辑redis6380.conf文件。如下图:
    在这里插入图片描述

  • 开启daemonize yes,如下图:
    在这里插入图片描述

  • 修改pid文件名字为redis_6380.pid,如下图:
    在这里插入图片描述

  • 指定IP和端口(6380),slave1从服务器一定也要把bind 127.0.0.1要改成0.0.0.0,因为当master宕机后,需要在slave1服务器中执行slaveof no one命令,从而升级为master服务器(一定要修改,否则主从连接失败)。如下图:

    在这里插入图片描述

    在这里插入图片描述

  • 修改log文件名字为6380.log,如下图:
    在这里插入图片描述

  • 修改dump.rdb名字为dump6380.rdb,如下图:
    在这里插入图片描述

3、配置slave2服务器(即IP为192.168.3.17的6381端口)的配置文件

  • 拷贝redis.conf文件为redis6381.conf,并编辑redis6381.conf文件。如下图:
    在这里插入图片描述

  • 开启daemonize yes,如下图:
    在这里插入图片描述

  • 修改pid文件名字为redis_6381.pid,如下图:
    在这里插入图片描述

  • 指定IP和端口(6381),从主机不需要把bind 127.0.0.1要改成0.0.0.0,从机不需要,如下图:

    在这里插入图片描述
    在这里插入图片描述

  • 修改log文件名字为6381.log,如下图:
    在这里插入图片描述

  • 修改dump.rdb名字为dump6381.rdb,如下图:
    在这里插入图片描述

五、Redis主从复制(反客为主演示示例,包含各种宕机情况))

1、分别启动3台服务器的redis服务端,并查看3台服务器的角色信息

  • 启动6379端口的master服务器并测试是否连接成功,如下图:

    在这里插入图片描述

  • 启动6380端口的slave1服务器并测试是否连接成功,如下图:
    在这里插入图片描述

  • 启动6381端口的slave2服务器并测试是否连接成功,如下图:
    在这里插入图片描述

  • 输入info replication命令,查看3台服务器的角色信息,由下图可知,3台服务器均为master服务器,如下图:
    在这里插入图片描述

2、slave1和slave2分别执行slaveof +master服务器ip+端口命令,查看slave1和slave2角色信息,并查看master角色信息。

  • 由下图可知,slave1和slave2服务器的角色都为slave,
    在这里插入图片描述
  • 由下图可知,master服务器的角色都为master,并且挂2个从服务器。
    在这里插入图片描述

4、当master服务器宕机后,在slave1服务器中执行slaveof no one命令,slave2服务器重新挂载到slave1服务器中,查看slave1和slave2的角色。

  • 由下图可知,当master宕机后,在slave1服务器中执行slaveof no one命令并且在slave2服务器重新挂载到slave1服务器中,salve1会升级为master服务器。并且可以看到挂载了slave2服务器。
    在这里插入图片描述

5、当master服务器宕机重新启动后,在次查看slave1服务器和slave2服务器角色。

  • 由下图可知,当master重新启动后,master自己单独一套体系,而slave1和slave2服务器单独一套体系,互不影响。
    在这里插入图片描述

这篇关于Redis主从复制(反客为主模式 演示示例)——图解版的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/603321

相关文章

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

在 Spring Boot 中使用 @Autowired和 @Bean注解的示例详解

《在SpringBoot中使用@Autowired和@Bean注解的示例详解》本文通过一个示例演示了如何在SpringBoot中使用@Autowired和@Bean注解进行依赖注入和Bean... 目录在 Spring Boot 中使用 @Autowired 和 @Bean 注解示例背景1. 定义 Stud

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

Python中Markdown库的使用示例详解

《Python中Markdown库的使用示例详解》Markdown库是一个用于处理Markdown文本的Python工具,这篇文章主要为大家详细介绍了Markdown库的具体使用,感兴趣的... 目录一、背景二、什么是 Markdown 库三、如何安装这个库四、库函数使用方法1. markdown.mark

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意