linux redis哨兵 sh,Linux下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 redis哨兵 sh,Linux下redis的持久化、主从同步与哨兵详解相关推荐
- Linux下的redis的持久化,主从同步及哨兵
redis持久化 Redis是一种内存型数据库,一旦服务器进程退出,数据库的数据就会丢失, 为了解决这个问题,Redis提供了两种持久化的方案,将内存中的数据保存到磁盘中,避免数据的丢失. RDB持久 ...
- Redis 多机服务 : 主从同步、哨兵、集群
文章目录 主从同步(复制) 同步 命令传播 优缺点 哨兵 下线判断与选举 故障转移 集群 握手 分片 主从同步(复制) 主从同步是Redis高可用服务的基石,其将主要存储数据的服务器成为主服务器(ma ...
- Redis主从架构:主从同步和哨兵机制
Redis主从架构:主从同步和哨兵机制 一. Redis主从架构 二. 主从同步 2.1 引入 2.2 原理 (1) 全量同步 (2) 增量同步 (3) 优化Redis主从集群 2.3 总结 三. 哨 ...
- linux c多进程多线程,linux下的C\C++多进程多线程编程实例详解
linux下的C\C++多进程多线程编程实例详解 1.多进程编程 #include #include #include int main() { pid_t child_pid; /* 创建一个子进程 ...
- 创建三个并发进程linux,Linux下几种并发服务器的实现模式(详解)
1>单线程或者单进程 相当于短链接,当accept之后,就开始数据的接收和数据的发送,不接受新的连接,即一个server,一个client 不存在并发. 2>循环服务器和并发服务器 1.循 ...
- dns日志级别 linux,linux下DNS服务器视图view及日志系统详解
linux下DNS服务器视图view及日志系统详解DNS服务器ACL:在named.conf文件中定义ACL功能如同bash当中定义变量,便于后续引用 ACL格式: acl ACL名称 { IP地址1 ...
- 1 linux下tcp并发服务器的几种设计的模式套路,Linux下几种并发服务器的实现模式(详解)...
1>单线程或者单进程 相当于短链接,当accept之后,就开始数据的接收和数据的发送,不接受新的连接,即一个server,一个client 不存在并发. 2>循环服务器和并发服务器 1.循 ...
- linux在vi创建文件,Linux下创建文本文件(vi/vim命令使用详解)
vi test.txt 或者 vim test.txt 再或者 touch test.txt vim是vi的升级版,指令更多,功能更强. 下面是收集的vim用法,当在vim里面要实现退出,首先要做的是 ...
- Linux如何重启oracle监听,Linux下重启oracle服务及监听器和实例详解
一.在Linux下重启Oracle数据库及监听器: 方法1: 用root以ssh登录到linux,打开终端输入以下命令: cd $ORACLE_HOME #进入到oracle的安装目录 dbstart ...
- linux网络驱动rtl8211f,RTL8211F在uboot下使用mii工具配置RJ45网口灯详解
RTL8211F在uboot下使用mii工具配置RJ45网口灯详解. 首先要明确使用这个工具的目的,类似于i2c-test工具测试i2c,使用这个工具验证测试网口灯的配置.然后再通过软件或者驱动来实现 ...
最新文章
- Ubuntu 16.04源码编译安装Apache 2.4.25教程
- 洛谷 P4284 [SHOI2014]概率充电器 解题报告
- mini mp3模块 输出_小米有品众筹魔方mini电脑主机
- 封装的可运行于winform与web的Log4Net的类库
- [HDU3691 Nubulsa Expo]
- 庖丁解牛TLD(一)——开篇
- 在 MySQL 中使用码农很忙 IP 地址数据库
- php zip怎么安装,php如何安装zip模块?(方法介绍)
- ubuntu 开启 rewrite 模块
- mysql是表级锁还是行级锁_带你了解MySQL数据库中的全局锁、表级锁、行级锁
- 如何成为一名卓越的数据科学家-桃树七剑之二:数据准备
- Java 垃圾回收机制(GC)简述
- 射雕zero找不到服务器,神秘领域《射雕ZERO》未揭秘场景盘点
- c语言生日蛋糕图片,poj1190生日蛋糕
- 阿里天池:小样本商标检测(baseline0.50)
- 用MPI进行分布式内存编程(二)MPI_allreduce MPI_scatt MPI_bcast.....
- Unity 之 代码获取IOS设备型号 -- 做分辨率适配
- Android 一体机研发之修改系统设置————声音
- 用U盘打造专属个人的微型护航系统--winpe
- LaTex中文编辑入门
热门文章
- pixel2style2pixe环境配置([‘ninja‘, ‘-v‘] + no module named ‘fused’)
- 2018年手机应用UI设计趋势预测
- 内存管理---匿名页面管理
- fatal error C1071: 在注释中遇到意外的文件结束
- 铁氧体磁珠相关知识总结
- 粤传媒构建大数据全媒体平台
- python取随机小数_python随机小数
- 微信公众号h5游戏核销流程
- Chapter Three:实战 js 混淆 - 源码乱码(简单)
- 更流网络seo专家分析百度快照不更新情况