zoukankan      html  css  js  c++  java
  • 【redis】持久化RDB和AOF

    redis之持久化RDB与AOF

     

    redis数据持久化

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

    RDB持久化

    redis提供了RDB持久化的功能,这个功能可以将redis在内存中的的状态保存到硬盘中,它可以手动执行。【手动执行时通过save指令触发的】

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

    RDB持久化产生的RDB文件是一个经过压缩二进制文件,这个文件被保存在硬盘中,redis可以通过这个文件还原数据库当时的状态。

    rdb配置参数:

    复制代码
    RDB(持久化)
    内存数据保存到磁盘
    在指定的时间间隔内生成数据集的时间点快照(point-in-time snapshot)
    优点:速度快,适合做备份,主从复制就是基于RDB持久化功能实现
    rdb通过再redis中使用save命令触发 rdb
    
    
    rdb配置参数:
    
    dir /data/6379/
    dbfilename  dbmp.rdb
    
    每过900秒 有1个操作就进行持久化
    
    save 900秒  1个修改类的操作
    save 300秒  10个操作
    save 60秒  10000个操作
    
    save  900 1
    save 300 10
    save 60  10000
    复制代码

    redis持久化之RDB实践

    1.配置启动redis服务端的配置文件

    # 创建log日志文件
    mkdir -p /data/6380/
    cd /data/6380/
    touch redis.log
    复制代码
    daemonize yes                  # 是否开启后台运行
    port 6379                         #端口
    logfile /data/6379/redis.log  # 自定义日志文件
    dir /data/6379               #自定义持久化文件存储位置
    dbfilename  dbmp.rdb        #rdb持久化文件
    bind 192.168.61.129   #redis绑定地址
    requirepass redhat            #redis登录密码
    save 900 1                    #rdb机制 每900秒 有1个修改记录
    save 300 10                    #每300秒        10个修改记录
    save 60  10000                #每60秒内        10000修改记录
    复制代码

    2.通过上面的配置文件启动redis服务端

    redis-server redis.conf

    登录redis客户端

    # --raw参数表示支持中文
    redis-cli -p 6380 -h 192.168.61.129 --raw   

    3、登录redis后设置一个key

    因为我们要验证他的数据持久化,所以我们登录后需要创建一个key,用save指令触发持久化,然后杀死redis服务端的进程,

    复制代码
    192.168.61.129:6380> KEYS *
    
    192.168.61.129:6380> set name "alex"
    OK
    192.168.61.129:6380> set age 19
    OK
    192.168.61.129:6380> get name
    alex
    192.168.61.129:6380> get age
    19
    复制代码

    4.此时检查目录,/data/6380底下没有dbmp.rdb文件

    5.通过save触发持久化,将数据写入RDB文件

    复制代码
    192.168.61.129:6380> KEYS *
    
    192.168.61.129:6380> set name "alex"
    OK
    192.168.61.129:6380> set age 19
    OK
    192.168.61.129:6380> get name
    alex
    192.168.61.129:6380> get age
    19
    192.168.61.129:6380> SAVE
    OK
    复制代码

    6、查看持久化文件dbmp.rdb

    redis持久化之AOF实践

    AOF(append-only log file)
    记录服务器执行的所有变更操作命令(例如set del等),并在服务器启动时,通过重新执行这些命令来还原数据集
    AOF 文件中的命令全部以redis协议的格式保存,新命令追加到文件末尾。
    优点:最大程序保证数据不丢
    缺点:日志记录非常大

    redis-client   写入数据  >  redis-server   同步命令   >  AOF文件

    配置参数

    AOF持久化配置,两条参数
    
    appendonly yes
    appendfsync  always    总是修改类的操作
                 everysec   每秒做一次持久化   # 常用
                 no     依赖于系统自带的缓存大小机制

    1、准备aof配置文件redis.conf

    复制代码
    daemonize yes   # 进程是否在后台运行
    port 6380          # 端口
    logfile /data/6380/redis.log   # log日志
    dir /data/6380            
    dbfilename  dbmp.rdb       # 数据持久化文件
    bind 192.168.61.129        # 绑定ip
    requirepass root         # 设置密码为root
    appendonly yes
    appendfsync everysec     #每秒做一次持久化
    复制代码

    2.基于配置文件启动redis服务端

    redis-server /etc/redis.conf

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

    [root@szx 6380]# ls
    appendonly.aof  dbmp.rdb  redis.log

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

    [root@szx ~ 20:09:35]#tail -f /data/6380/appendonly.aof 

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

    复制代码
    [root@szx / 19:50:25]#redis-cli -p 6380 -h 192.168.61.129 --raw  
    192.168.61.129:6380> auth root
    OK
    192.168.61.129:6380> KEYS *
    
    192.168.61.129:6380> SET name "alex"
    OK
    192.168.61.129:6380> SET age 87
    OK
    复制代码

    步骤:

    修改配置文件-->启动redis服务端-->登录redis客户端-->创建key

    退出客户端杀死redis服务端进程-->重启redis并登录-->查看之前创建的key是否存在

    查看数据持久化的文件,所有操作记录都保存在文件中

    实时监测数据持久化文件:

    redis 持久化方式有哪些?有什么区别?

    rdb:基于快照的持久化,速度更快,一般用作备份,主从复制也是依赖于rdb持久化功能

    aof:以追加的方式记录redis操作日志的文件。可以最大程度的保证redis数据安全,类似于mysql的binlog

  • 相关阅读:
    深入理解memcached
    如何查看你的 memcached 的状态
    转: Linux 技巧:让进程在后台可靠运行的几种方法
    centos 如何用 rsyslog 搭建本地日志服务(续1: omprog模块与php deamon的配合使用)
    转: 解决MSYS2下的中文乱码问题
    解决windows下vim方向键变成 ABCD 的问题
    centos 如何用 rsyslog 搭建本地日志服务
    转:理解 Linux 的硬链接与软链接
    php include include_once require require_once 的区别与联系
    让块级元素水平垂直居中
  • 原文地址:https://www.cnblogs.com/youxiu123/p/11493147.html
Copyright © 2011-2022 走看看