首页 > 数据库 >【Redis】011-Redis主从复制:Redis集群环境搭建、主从复制之复制原理及手动配置主机

【Redis】011-Redis主从复制:Redis集群环境搭建、主从复制之复制原理及手动配置主机

时间:2023-02-24 11:33:15浏览次数:37  
标签:主从复制 主机 Redis 011 从机 服务器 节点


目录

​​一、Redis集群环境搭建​​

​​1、概念​​

​​2、主从复制的作用​​

​​3、为什么一般使用多台Redis服务器​​

​​4、为什么使用集群​​

​​5、环境配置​​

​​查看当前库的信息:​​

​​默认是主机:​​

​​演示视频:​​

​​需要修改的配置文件内容:​​

​​启动单机多服务集群:​​

​​二、主从复制之复制原理及手动配置主机​​

​​1、一主二从配置​​

​​2、使用规则​​


一、Redis集群环境搭建

1、概念

主从复制,是指将一台Redis服务器的数据,复制到其他的Redis服务器。前者称为主节点(Master/Leader),后者称为从节点(Slave/Follower), 数据的复制是单向的!只能由主节点复制到从节点(主节点以写为主、从节点以读为主);

默认情况下,每台Redis服务器都是主节点,一个主节点可以有0个或者多个从节点,但每个从节点只能由一个主节点;

【Redis】011-Redis主从复制:Redis集群环境搭建、主从复制之复制原理及手动配置主机_主从复制

主从复制,读写分离,我们80%的情况都是在读取数据,减缓服务器压力,在架构中经常使用;

最低配是一主二从;

 

2、主从复制的作用

数据冗余:主从复制实现了数据的热备份,是持久化之外的一种数据冗余的方式;

故障恢复:当主节点故障时,从节点可以暂时替代主节点提供服务,是一种服务冗余的方式;

负载均衡:在主从复制的基础上,配合读写分离,由主节点进行写操作,从节点进行读操作,分担服务器的负载;尤其是在多读少写的场景下,通过多个从节点分担负载,提高并发量;

高可用(集群)基石:主从复制还是哨兵和集群能够实施的基础;

 

3、为什么一般使用多台Redis服务器

为防止宕机,一般配置三台Redis服务器,一主二从;

单台Redis服务器内存一般不应该超过20GB,否则赶紧使用集群;

在企业中,主从复制是必须使用的,真实项目中不存在使用单机redis;

默认情况下,每台Redis服务器都是主节点(从节点需要配置),一个主节点可以有个从节点,一个从节点只能属于一个主节点;

【Redis】011-Redis主从复制:Redis集群环境搭建、主从复制之复制原理及手动配置主机_Redis_02

 

4、为什么使用集群

单台服务器难以负载大量的请求;

单台服务器故障率高,系统崩坏概率大;

单台服务器内存容量有限;

 

5、环境配置

只配置从库,不用配置主库(默认自己就是主库);

查看当前库的信息:

info replication

默认是主机:

【Redis】011-Redis主从复制:Redis集群环境搭建、主从复制之复制原理及手动配置主机_Redis_03

演示视频:

我们使用的是Windows环境学习的,就不再演示了,狂神的教程:

下面的笔记就直接摘抄了,不再实际演示;

 

需要修改的配置文件内容:

既然需要启动多个服务,就需要多个配置文件。每个配置文件对应修改以下信息:

  • 端口号;
  • pid文件名;
  • 日志文件名;
  • rdb文件名;

 

启动单机多服务集群:

【Redis】011-Redis主从复制:Redis集群环境搭建、主从复制之复制原理及手动配置主机_redis_04

 

二、主从复制之复制原理及手动配置主机

1、一主二从配置

默认情况下,每台Redis服务器都是主节点;我们一般情况下只用配置从机就好了;

认老大!一主(79)二从(80,81)

使用SLAVEOF host port就可以为从机配置主机了;

【Redis】011-Redis主从复制:Redis集群环境搭建、主从复制之复制原理及手动配置主机_redis_05

【Redis】011-Redis主从复制:Redis集群环境搭建、主从复制之复制原理及手动配置主机_主从复制_06

然后主机上也能看到从机的状态:

【Redis】011-Redis主从复制:Redis集群环境搭建、主从复制之复制原理及手动配置主机_Redis_07

我们这里是使用命令搭建,是暂时的,真实开发中应该在从机的配置文件中进行配置,这样的话是永久的;

【Redis】011-Redis主从复制:Redis集群环境搭建、主从复制之复制原理及手动配置主机_主从复制_08

 

2、使用规则

①从机只能读,不能写,主机可读可写但是多用于写;

127.0.0.1:6381> set name sakura # 从机6381写入失败
(error) READONLY You can't write against a read only replica.

127.0.0.1:6380> set name sakura # 从机6380写入失败
(error) READONLY You can't write against a read only replica.

127.0.0.1:6379> set name sakura
OK
127.0.0.1:6379> get name
"sakura"

②当主机断电宕机后,默认情况下从机的角色不会发生变化 ,集群中只是失去了写操作,当主机恢复以后,又会连接上从机恢复原状;

③当从机断电宕机后,若不是使用配置文件配置的从机,再次启动后作为主机是无法获取之前主机的数据的,若此时重新配置称为从机,又可以获取到主机的所有数据。这里就要提到一个同步原理;

④第二条中提到,默认情况下,主机故障后,不会出现新的主机,有两种方式可以产生新的主机:

- 从机手动执行命令slaveof no one,这样执行以后从机会独立出来成为一个主机
- 使用哨兵模式(自动选举)

如果没有老大了,这个时候能不能选择出来一个老大呢?手动!

如果主机断开了连接,我们可以使用SLAVEOF no one让自己变成主机!其他的节点就可以手动连接到最新的主节点(手动)!如果这个时候老大修复了,那么久重新连接!

 

 

 

 

 

 

 

 

标签:主从复制,主机,Redis,011,从机,服务器,节点
From: https://blog.51cto.com/u_13272819/6083319

相关文章

  • 873~874 redis概述,下载安装
    Redis:1、概述:redis是一款高性能的NOSQL系列的非关系型数据库;1-1:什么是NOSQLNoSQL(NoSQL=NotOnlySQL),意即“不仅仅是SQL”,是一项全新的数据......
  • redis知识点
    通信协议协议概念:所谓协议其实就是发送和接收双方约定的数据格式而已;类似于加密解密;没有什么神秘;比如http协议,双方约定好格式,如何读取url,取参赛,取请求头......
  • 深入理解跳表及其在Redis中的应用
    前言跳表可以达到和红黑树一样的时间复杂度O(logN),且实现简单,Redis中的有序集合对象的底层数据结构就使用了跳表。其作者威廉·普评价:跳跃链表是在很多应用中有可能替代......
  • Redis入门学习
    认识RedisRedis诞生于2009年全称是RemoteDictionaryServer,远程词典服务器,是一个基于内存的键值型NoSQL数据库。特征:键值(key-value)型,value支持多种不同数据结构,功能丰......
  • arrch架构部署redis,报错: ignore-warnings ARM64-COW-BUG
    做个记录。 arrch架构的redis安装包下载链接:https://pan.baidu.com/s/1TMXNpMvMDWRFD1f5km7MwQ  提取码:36qk 启动redis报错如下:Rediswillnowexittoprev......
  • 以docker方式部署的redis键值查询及清理
     1、首先使用 dockerps 命令来查看正在运行的容器。该命令会列出容器的ID、名称、端口号、状态等信息。也可以使用 dockerps-a 命令来查看所有容器,包括已经停止的......
  • redis分布式锁的实现
    一.正常加锁当两个用户同时注册一个用户名时,为保证用户名不能重复,因此对其注册的用户名加锁。具体步骤:获得用户注册的用户名,进行判断,如果为空则对其进行加锁,保存到数据......
  • redis列表类型 list set&sortedset
    列表类型list可以添加一个元素到列表的头部(左边)或者尾部(右边)1添加1lpushkeyvalue将元素加入列表左表2rpushkeyvalue将元素加入列表右边2获取......
  • redis(1)NoSQL数据库简介
    1.1技术发展redis是用来解决性能问题的数据库技术的分类:解决功能性问题:Java、Jsp、RDBMS、Tomcat、HTML、Linux、JDBC、SVN解决扩展性问题:Struts、Spring、SpringMVC......
  • Redis
    Redis的缓存雪崩、穿透和击穿缓存雪崩缓存本来可以抗住高峰期的大量请求、但缓存机器发生意外全盘宕机,导致大量请求全部落在数据库,数据库崩溃。解决方案:1、限流组件、......