一、redis持久化

redis是内存数据库,一切的数据都是存储到内存中的,我们知道,当服务器意外关机,那么在内存中的数据都将丢失,但是redis为我们提供持久化功能,这样就能把数据保存到硬盘上。redis提供两种持久化方式,分别是RDB和AOF方式,各有特点。下面进行介绍这两种方式。

1、RDB方式

默认情况下,redis是开启RDB方式进行持久化的,主要由配置文件中几个参数指定:

save  1                      # after 900 sec (15 min) if at least 1 key changed
save 10 # after 300 sec (5 min) if at least 10 keys changed
save 10000 # after 60 sec if at least 10000 keys changed
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb # The filename where to dump the DB
dir /var/redis/6379 # the data file's directory.

save参数指定了快照条件,可以存在多个条件,条件之间是或关系,如上所说:save 900 1 的意思是在15分钟内有至少一个key被更改就进行快照。

快照执行的原理:

  • redis使用fork函数复制一份当前进程(父进程)的副本(子进程)
  • 父进程继续处理任务,而子进程开始将内存中的数据写入硬盘中的临时文件
  • 当子进程写入完所有数据后会用该临时文件替换旧的RDB文件,到此一次快照完成

在执行fork函数时,操作系统使用写时复制策略,即fork函数发生的一刻父进程和子进程共享同一内存数据,当父进程需要修改某片数据时,会将该片数据复制一份以保证子进程不受影响,所以新的RDB数据文件是执行fork一刻的内存数据。通过上述过程可以知道,redis在快照过程中不会让数据改变,只有快照结束后才会将旧的文件替成新文件,也就是任何时候RDB文件都是完整的,故我们对redis数据备份可以采用定时备份RDB文件即可。

除了自动快照,还可以手工发送save和bgsave命令让redis执行快照,两个命令的区别在于,前者是由主进程进行快照操作,会阻塞其他请求,而后者是通过子进程执行快照。

redis启动后,会读取RDB快照文件,将数据从硬盘载入到内存。根据数据量、结构和服务器性能的不同,这个加载时间也不相同。

通过RDB方式实现持久化,一旦redis异常退出,就会丢失最后一次快照后修改的数据,如果不能承受任何数据的丢失,那么可以尝试用AOF方式。

2、AOF方式

默认情况下,AOF方式不是没有启用的,可以到配置文件中添加appendonly参数进行开启:

appendonly yes                        #开启AOF
appendfilename "appendonly.aof"
appendfsync everysec
auto-aof-rewrite-percentage 100 #当目前aof文件大小超过上一次重写时aof文件大小百分之多少时进行重写,如果之前没有重写过,则以启动大小为依据
auto-aof-rewrite-min-size 64mb #限制容许重写的最小aof文件大小

其中appendfsync参数有三个值:

  • everysec:默认值,每秒执行一次同步到硬盘。
  • always:每次数据改变就执行一次同步
  • no:不同步,完全由OS缓存决定同步

redis允许aof和rdb共存,此时重启redis会读取aof文件到内存中恢复数据。

二、redis复制

通过AOF和RDB持久化可以做到防止数据丢失,但是对于一台服务器,如果硬盘坏了,数据还是会丢失。为了避免单点故障,可以把一台服务器数据复制到另外几台服务器上,即使有一台故障了,其他还可以提供服务。redis提供复制功能可以自动实现数据的同步。

1、复制原理

了解复制原理对运维很有帮助。

当一个从数据库启动后,会主动主数据库发送sync命令,主接收到sync命令后开始在后台保存快照(RDB持久化过程),并将快照过程中的命令缓存起来。当快照完成后,会把快照和缓存的命令发送给从数据库。从数据库接收到后,载入快照和执行缓存命令。当主从数据库断开连接后,会从新执行上述步骤,不支持断点续传。

2、配置复制

环境说明:
IP 功能
192.168.245.129 master
192.168.245.131 slave

在redis中配置主从复制很简单,只需要在从数据库配置文件中添加slaveof <masterip> <masterport>参数即可实现,主数据库无需任何配置。
在192.168.245.131的配置文件中添加如下:

slaveof 192.168.245.129 

然后重启从服务器(必须要重启,否则参数没有效果

/etc/init.d/redis_6379 stop
/etc/init.d/redis_6379 start

在主数据库执行个命令:

127.0.0.1:> set foo testmaster
OK

从数据库查看结果:

127.0.0.1:> get foo
"testmaster"

3、其他说明

redis的从数据库还可以作为主数据库。  

redis比较耗时的操作是数据的持久化,为了提高性能,我们可以统一在从库进行数据的持久化,也能保证数据安全。具体操作如下:

  • 通过复制建立一个或几个从数据库,并开启持久化功能
  • 关闭主数据库的持久化
  • 如果主数据库故障,则在从库执行slaveof no one命令将从数据库提升为主数据库
  • 如果原主数据库恢复了,可以再次设置成新主数据库的从数据库

Redis的管理的更多相关文章

  1. 几款开源的图形化Redis客户端管理软件

    转载于:http://www.itxuexiwang.com/a/shujukujishu/redis/2016/0216/98.html?1455870209 Redis是一个超精简的基于内存的键值 ...

  2. Redis桌面管理工具 RedisDesktopManager

    下载链接地址:[官网地址:https://redisdesktop.com] redis-desktop-manager-0.8.8.384.exe Source code (zip) Source ...

  3. 几款开源的图形化Redis客户端管理软件推荐

    Redis是一个超精简的基于内存的键值对数据库(key-value),一般对并发有一定要求的应用都用其储存session,乃至整个数据库.不过它公自带一个最小化的命令行式的数据库管理工具,有时侯使用起 ...

  4. PyRedisAdmin v1.0 Beta 发布,Redis 在线管理工具 - 开源中国社区

    PyRedisAdmin v1.0 Beta 发布,Redis 在线管理工具 - 开源中国社区 PyRedisAdmin v1.0 Beta 发布,Redis 在线管理工具

  5. Redis 内存管理与事件处理

    1 Redis内存管理 Redis内存管理相关文件为zmalloc.c/zmalloc.h,其只是对C中内存管理函数做了简单的封装,屏蔽了底层平台的差异,并增加了内存使用情况统计的功能. void * ...

  6. Redis 桌面管理器

    使用Redis桌面管理器,可以方便开发人员进行开发测试,对Redis存储内容进行可视化管理. 下载安装:https://redisdesktop.com/download 1. 为了方便测试,打开re ...

  7. 安装window下的redis,redis可视化管理工具(Redis Desktop Manager)安装,基础使用,实例化项目

    以下包括内容: 一.redis下载安装,启动 二.Redis可视化管理工具(Redis Desktop Manager)安装 三.实例化项目 一.redis下载安装,启动 1,redis官方下载地址: ...

  8. redis : 桌面管理工具 redis-desktop-manager使用指南

    概要:一款好用的Redis桌面管理工具,支持命令控制台操作,以及常用,查询key,rename,delete等操作. 下载软件,请点击下面链接,进入下载页,选择对应版本: https://redisd ...

  9. redis桌面管理工具 redis-desktop-manager使用指南(转)

    版权声明:转自 http://blog.csdn.net/li396864285/article/details/54629898     概要:一款好用的Redis桌面管理工具,支持命令控制台操作, ...

  10. Redis键管理

    Redis键管理 Redis 键命令用于管理 redis 的键. 语法 Redis 键命令的基本语法如下: redis > COMMAND KEY_NAME redis > SET w3c ...

随机推荐

  1. java之静态代理

    © 版权声明:本文为博主原创文章,转载请注明出处 定义: - 为其他对象提供一种代理以控制对这个对象的访问 组成: 抽象角色:通过接口或抽象类声明真正角色实现的业务方法 真实角色:实现抽象角色,定义真 ...

  2. [Material Design] 教你做一个Material风格、动画的button(MaterialButton)

    原创作品,转载请注明出处:http://blog.csdn.net/qiujuer/article/details/39831451 前段时间Android L 公布了,相信看过公布会了解过的朋友都为 ...

  3. jar包解压与打包

    首先感谢大神的指导:https://blog.csdn.net/mr_pang/article/details/47028921 1.首先准备一个能运行的jar文件,我们使用第三方解压工具进行解压wi ...

  4. jfreechart折线图 demo

    public class ChartUtil { public static ChartUtil chartUtil; private RoomViewsDataService roomViewsDa ...

  5. u-boot中断功能初步分析之---------按键中断

    作者:彭东林 邮箱:pengdonglin137@163.com QQ: 405728433 以前一直有个疑问,在U-boot下到底能不能使用中断,为了验证这个问题,于是乎,昨天晚上我在自己的 TQ2 ...

  6. FastDFS分布文件系统

    FastDFS是为互联网应用量身定做的一套分布式文件存储系统,非常适合用来存储用户图片.视频.文档等文件.对于互联网应用,和其他分布式文件系统相比,优势非常明显.具体情况大家可以看相关的介绍文档,包括 ...

  7. nginx与apache的区别

    Web服务器 Web服务器也称为WWW(WORLD WIDE WEB)服务器,主要功能是提供网上信息浏览服务. 应用层使用HTTP协议. HTML文档格式. 浏览器统一资源定位器(URL). Web服 ...

  8. python pytest

    之前一直用unittest ,现在学习pytest 看看那个好 1. 安装 pip install -U pytest py.test --version 2. 只需要按照下面的规则: 测试文件以te ...

  9. Office365client通过本地方式批量部署(即点即用部署)

    当企业用户拥有Office 365 ProPlus的许可后,可登陆Office 365.自行下载Officeclient安装部署 以上仅仅是理想情况,实际情况是企业用户较多,IT水平參差不齐,企业的带 ...

  10. ASP.NET动态网站制作(16)-- SQL数据库(2)

    前言:SQL数据库的第二节课,继续讲解基本的语句及用法. 内容: 1.insert插入语句  insert into Book(bookName,bookPrice,bookAuthor) value ...