redis的主从配置模拟(一主双从)

目录

先来给大家扩展机道面试官经常会问到关于redis的题

一、redis有哪些好处

二、redis相比memcached有哪些优势

三、redis常见性能问题和解决方案

四、redis集群的工作原理

五、redis主从的原理

redis的主从配置模拟(一主双从)

一、准备环境

二、分别安装redis

[三、 主配置文件修改](#三、 主配置文件修改)

四、重启redis,测试


先来给大家扩展机道面试官经常会问到关于redis的题

一、redis有哪些好处

(1) 速度快,因为数据存在内存中,类似于HashMap,HashMap的优势就是查找和操作的时间复杂度都是O(1)

(2) 支持丰富数据类型,支持string,list,set,sorted set,hash

(3) 支持事务,操作都是原子性,所谓的原子性就是对数据的更改要么全部执行,要么全部不执行

(4) 丰富的特性:可用于缓存,消息,按key设置过期时间,过期后将会自动删除

二、redis相比memcached有哪些优势

(1) memcached所有的值均是简单的字符串,redis作为其替代者,支持更为丰富的数据类型

(2) redis可以持久化其数据

三、redis常见性能问题和解决方案

(1) Master最好不要做任何持久化工作,如RDB内存快照和AOF日志文件

(2) 如果数据比较重要,某个Slave开启AOF备份数据,策略设置为每秒同步一次

(3) 为了主从复制的速度和连接的稳定性,Master和Slave最好在同一个局域网内

(4) 尽量避免在压力很大的主库上增加从库

(5) 主从复制不要用树状结构,用单向链表结构更为稳定,即:Master(写) <- Slave1(读) <- Slave2(读) <- Slave3(读)...

这样的结构方便解决单点故障问题,实现Slave对Master的替换。如果Master挂了,可以立刻启用Slave1做Master,其他不变。

四、redis集群的工作原理

主多从+哨兵模式(keelalived)

五、redis主从的原理

从服务器会向主服务器发出SYNC指令,当主服务器接到此命令后,就会调用BGSAVE指令来创建一个子进程专门进行数据持久化工作,也就是将主服务器的数据写入RDB文件中。在数据持久化期间,主服务器将执行的写指令都缓存在内存中。

在BGSAVE指令执行完成后,主服务器会将持久化好的RDB文件发送给从服务器,从服务器接到此文件后会将其存储到磁盘上,然后再将其读取到内存中。这个动作完成后,主服务器会将这段时间缓存的写指令再以redis协议的格式发送给从服务器。

redis的主从配置模拟(一主双从)

一、准备环境

这里我们准备三台服务器

master

slave1

slave2

关闭防火墙和selinux

做好域名解析

二、分别安装redis

安装详情请参考此文章

Redis服务-CSDN博客

三、 主配置文件修改

编辑master的redis配置文件:

cd /data/application/redis/

vim redis.conf

修改slave1的配置文件:

cd /data/application/redis/

vim redis.conf

找到主从模块

slave2的配置文件修改的地方和slave是一样的:

cd /data/application/redis/

vim redis.conf

找到主从模块

四、重启redis,测试

master

重启redis

登录redis查询主从状态

slave1

重启redis

登录redis查询主从状态

slave2

重启redis

登录redis查询主从状态

这是我们在master上创建一个key

也会同步到slave和slave2上

希望能够帮助到大家!!

相关推荐
海天鹰7 小时前
【免费】PHP主机=域名+解析+主机
服务器
DianSan_ERP8 小时前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
加号38 小时前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏8 小时前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐8 小时前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
哇哈哈20218 小时前
信号量和信号
linux·c++
呉師傅9 小时前
火狐浏览器报错配置文件缺失如何解决#操作技巧#
运维·网络·windows·电脑
不是二师兄的八戒9 小时前
Linux服务器挂载OSS存储的完整实践指南
linux·运维·服务器
芝士雪豹只抽瑞克五9 小时前
Nginx 高性能Web服务器笔记
服务器·nginx
百锦再9 小时前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip