摘要:

1.0 redis持久化Redis是一种内存型数据库,一旦服务器进程退出,数据库的数据就会丢失,为了解决这个问题,Redis提供了两种持久化...

1.0 redis持久化

Redis是一种内存型数据库,一旦服务器进程退出,数据库的数据就会丢失,为了解决这个问题,Redis提供了两种持久化的方案,将内存中的数据保存到磁盘中,避免数据的丢失。

1|1RDB持久化

redis提供了RDB持久化的功能,在指定的时间间隔内生成数据集的时间点快照(point-in-time snapshot)这个功能可以将redis在内存中的的状态保存到硬盘中,RDB持久化产生的RDB文件是一个经过压缩的二进制文件,这个文件被保存在硬盘中,redis可以通过这个文件还原数据库当时的状态。

它可以手动执行。

也可以在redis.conf中配置,定期执行。

优点:速度快,适合做备份,主从复制就是基于RDB持久化功能实现

rdb通过在redis中使用save命令触发 rdb

rdb配置参数:

port 6379

daemonize yes

pidfile /data/6379/redis.pid

loglevel notice

logfile "/data/6379/redis.log"

dir /data/6379

protected-mode yes

dbfilename dbmp.rdb

save 900 1

save 300 10

save 60 10000

每过900秒 有1个操作就进行持久化

save 900秒 1个修改类的操作

save 300秒 10个操作

save 60秒 10000个操作

2.触发rdb持久化,也可以手动save命令即可,生成 dump.rdb持久化文件

3.重启redis,数据不再丢失

4.rdb数据文件是二进制文件,人为的看不懂

1|2redis持久化之AOF

AOF(append-only log file)

记录服务器执行的所有变更操作命令(例如set del等),并在服务器启动时,通过重新执行这些命令来还原数据集

AOF 文件中的命令全部以redis协议的格式保存,新命令追加到文件末尾。

优点:最大程序保证数据不丢

缺点:日志记录非常大

配置方式

1.在配置文件中,添加aof参数

在redis-6379.conf中添加参数,开启aof功能

appendonly yes

appendfsync everysec

2.重启redis数据库,加载aof功能

3.检查redis数据目录/data/6379/是否产生了aof文件

[root@web02 6379]# ls

appendonly.aof dbmp.rdb redis.log

4.登录redis-cli,写入数据,实时监听aof文件信息

tail -f appendonly.aof

5.设置新key,检查aof信息,然后关闭redis,检查数据是否持久化

redis-cli -a redhat shutdown

redis-Server /etc/redis.conf

redis-cli -a redhat

在不重启redis的情况下,切换rdb数据到aof数据中

1.配置redis支持rdb持久化

2.启动redis客户端,通过命令,临时切换到aof模式

127.0.0.1:6379> CONFIG set appendonly yes

OK

127.0.0.1:6379> CONFIG SET save ""

OK

3.检查此时的数据持久化方式是rdb,还是aof,检查appendonly.aof文件,数据变动

tail -f appendonly.aof

4.此时aof还未永久生效,写入参数到配置文件

编辑redis-6379.conf 添加如下参数

appendonly yes

appendfsync everysec

2|0主从同步

redis主从同步实现

1.准备三个redis数据库,redis支持多实例

三个配置文件,仅仅是端口的不同

在三个配置文件中,添加主从同步的参数

redis-6379.conf

port 6379

daemonize yes

pidfile /data/6379/redis.pid

loglevel notice

logfile "/data/6379/redis.log"

dir /data/6379

protected-mode yes

dbfilename dbmp.rdb

save 900 1

save 300 10

save 60 10000

redis-6380.conf

port 6380

daemonize yes

pidfile /data/6380/redis.pid

loglevel notice

logfile "/data/6380/redis.log"

dir /data/6380

protected-mode yes

dbfilename dbmp.rdb

save 900 1

save 300 10

save 60 10000

slaveof 127.0.0.1 6379

redis-6381.conf

port 6381

daemonize yes

pidfile /data/6381/redis.pid

loglevel notice

logfile "/data/6381/redis.log"

dir /data/6381

protected-mode yes

dbfilename dbmp.rdb

save 900 1

save 300 10

save 60 10000

slaveof 127.0.0.1 6379

2.启动三个数据库实例,查看主从同步身份

redis-cli -p 6379 info replication

redis-cli -p 6380 info replication

redis-cli -p 6381 info replication

3:确保查看信息如下 并且检查是否同步

4.如果我主库挂了怎么办??

1.手动切换主从身份,选举一个新的主库

1.干掉6379主库

2.在6380上关闭自己的slave身份

slaveof no one

3.在6381上给与新的主人身份

salveof 127.0.0.1 6380

4.修改完毕,还得修改配置文件,永久生效

2,用哨兵自动选举新主人

2|1redis哨兵:

哨兵功能:

哨兵进行检测,主从架构是否正常,如果主库挂掉,哨兵会自动的修改redis.conf,进行添加/删除 slaveof 指令

redis哨兵安装配置:

1.准备三个redis实例,一主两从

详见上面redis主从配置

2,准备好了三个数据库实例,启动三个数据库实例

redis-server redis-6379.conf

redis-server redis-6380.conf

redis-server redis-6381.conf

3,准备三个哨兵,开始监控主从架构

准备三个配置文件,哨兵文件

redis-26379.conf

port 26379

dir /var/redis/data/

logfile "26379.log"

sentinel monitor sbmaster 127.0.0.1 6379 2

sentinel down-after-milliseconds qsmaster 30000

sentinel parallel-syncs sbmaster 1

sentinel failover-timeout sbmaster 180000

daemonize yes

redis-26380.conf

port 26380

dir /var/redis/data/

logfile "26380.log"

sentinel monitor sbmaster 127.0.0.1 6379 2

sentinel down-after-milliseconds qsmaster 30000

sentinel parallel-syncs sbmaster 1

sentinel failover-timeout sbmaster 180000

daemonize yes

redis-26381.conf

port 26381

dir /var/redis/data/

logfile "26381.log"

sentinel monitor sbmaster 127.0.0.1 6379 2

sentinel down-after-milliseconds sbmaster 30000

sentinel parallel-syncs sbmaster 1

sentinel failover-timeout sbmaster 180000

daemonize yes

4,启动三个哨兵实例

redis-sentinel redis-26380.conf

redis-sentinel redis-26379.conf

redis-sentinel redis-26381.conf

检查哨兵状态是否正常

只有发现如下信息,与下面一致,即为正常

redis-cli -p 26379 info sentinel

# Sentinel

sentinel_masters:1

sentinel_tilt:0

sentinel_running_scripts:0

sentinel_scripts_queue_length:0

sentinel_simulate_failure_flags:0

master0:name=sbmaster,status=ok,address=127.0.0.1:6380,slaves=2,sentinels=3

5,进行哨兵自动主从切换

1.干掉6379的redis数据库

2.查看6380和6381的身份信息,是否自动的进行主从切换(需等待30秒才会切换)

3.手动启动6379挂掉的数据库,查看是否会被哨兵,添加进信息的主从集群

注意!!如果发现不成功,需删掉所有的哨兵配置文件,从新来过

注意!!如果发现不成功,需删掉所有的哨兵配置文件,从新来过

注意!!如果发现不成功,需删掉所有的哨兵配置文件,从新来过

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。

linux主从服务器不能同步,Linux下redis的持久化、主从同步与哨兵详解相关推荐

  1. Redis中持久化的两种方法详解

    Redis提供了两种不同的持久化方法来将数据存储到硬盘里面.一种方法叫快照(snapshotting),它可以将存在于某一时刻的所有数据都写入硬盘里;另一种方法教只追加文件(append-only f ...

  2. linux在vi创建文件,Linux下创建文本文件(vi/vim命令使用详解)

    vi test.txt 或者 vim test.txt 再或者 touch test.txt vim是vi的升级版,指令更多,功能更强. 下面是收集的vim用法,当在vim里面要实现退出,首先要做的是 ...

  3. linux c多进程多线程,linux下的C\C++多进程多线程编程实例详解

    linux下的C\C++多进程多线程编程实例详解 1.多进程编程 #include #include #include int main() { pid_t child_pid; /* 创建一个子进程 ...

  4. Linux如何重启oracle监听,Linux下重启oracle服务及监听器和实例详解

    一.在Linux下重启Oracle数据库及监听器: 方法1: 用root以ssh登录到linux,打开终端输入以下命令: cd $ORACLE_HOME #进入到oracle的安装目录 dbstart ...

  5. linux网络驱动rtl8211f,RTL8211F在uboot下使用mii工具配置RJ45网口灯详解

    RTL8211F在uboot下使用mii工具配置RJ45网口灯详解. 首先要明确使用这个工具的目的,类似于i2c-test工具测试i2c,使用这个工具验证测试网口灯的配置.然后再通过软件或者驱动来实现 ...

  6. Linux用户、权限及改变文件所有者及文件所属组多例详解 附python代码

    https://blog.csdn.net/hanhanwanghaha宝藏女孩 欢迎您的关注! 欢迎关注微信公众号:宝藏女孩的成长日记 如有转载,请注明出处(如不注明,盗者必究) Linux用户.权 ...

  7. 深入剖析Redis系列(三) - Redis集群模式搭建与原理详解

    前言 在 Redis 3.0 之前,使用 哨兵(sentinel)机制来监控各个节点之间的状态.Redis Cluster 是 Redis 的 分布式解决方案,在 3.0 版本正式推出,有效地解决了 ...

  8. redis学习笔记(7)之redis哨兵详解

    redis哨兵详解 sentinel命令 客户端连接 素材代码 思路 实现过程 哨兵的切换实现原理 发布订阅基础 哨兵的实现原理 部署建议 需要关注的问题 代码流程 内容来源为六星教育,这里仅作为学习 ...

  9. Win7下的内置FTP组件的设置详解

    Win7下的内置FTP组件的设置详解 在局域网中共享文件,FTP是比较方便的方案之一.Win7内部集成了FTP,只是设置起来颇费一番功夫.着文以记之. 一.安装FTP组件 由于Win7默认没有安装FT ...

  10. mysql8.0.20 64位安装教程_windows 64位下MySQL 8.0.15安装教程图文详解

    先去官网下载点击的MySQL的下载 下载完成后解压 解压完是这个样子 配置系统环境变量 复制解压后的mysql到C盘或者其他磁盘下 我们去系统的环境变量的path里添加一个mysql的配置  指向my ...

最新文章

  1. java一天一次_做JAVA两年,月薪18k,这些自学心得你绝对值得借鉴
  2. Lattice diamond IPexpress 例子 - PLL
  3. 五大存储模型关系模型、键值存储、文档存储、列式存储、图形数据
  4. Buuctf(pwn)[OGeek2019]babyrop
  5. python入门神器_爬虫 (一) 神器准备篇
  6. mybatisplus新增返回主键_第17期:索引设计(主键设计)
  7. 原生js 基于canvas写一个简单的前端 截图工具
  8. linux xwindow 权限,普通用户如何启动XWindow的问题
  9. CRM是什么?CRM客户管理系统主要的功能,作用,特点分别有哪些?
  10. 微型计算机2019年年度盘点,「2019 IT产业市场回顾」性能堆砌、轴之战再起、多声道普及!2019年游戏外设市场年终盘点...
  11. win10需要修复计算机,Win10开机蓝屏,显示“你的电脑/设备需要修复”怎么办?答案来了...
  12. ORA-32002 ORA-32017 ORA-32019
  13. 实践是检验真理的唯一标准 (转)
  14. C语言中的switch语句基本用法
  15. 西泽金融: 银行业的下半场
  16. android文字与图片底部对齐,ImageView 图片和 TextView 文字的底部对齐
  17. 2.4G 无线收发芯片 XL2400 SOP8封装 射频芯片 带规格书
  18. 顺瓜摸藤--策划人的系统观和方法论
  19. 【最新】2022年注册测绘师考试测绘案例分析真题及参考答案
  20. 计算机科学采用通知,关于采用合同模板的通知 科研〔2019〕134号

热门文章

  1. iOS H264,H265视频编码(Video encode)
  2. Dev GridView 绑定Listlt;Tgt;、BindingList lt;Tgt;、BindingSource
  3. SqlServer用户数据库的系统视图sysobjects、syscolumns、systypes
  4. 最强悍的VS插件—reSharper
  5. iBatis.Net实现返回DataTable和DataSet对象
  6. 浅析C#发送短信的原理
  7. elastic-job 和 xxl-job 的对比
  8. SpringBoot上传图片的示例
  9. Using the URLconf defined in catsui.urls, Django tried these URL patterns, in this order:
  10. 15个最受欢迎的Python开源框架(转载)