文档章节

Redis客户端连接以及持久化数据

编辑之路
 编辑之路
发布于 01/17 14:33
字数 1286
阅读 75
收藏 1

一、介绍


之前我们讲解了Redis的结构与指令,其实很简单,我也没有过多的讲解,这次我们讲解一下Redis连接客户端以及持久化方案。

1、上文中我们针对redis的数据操作都是在服务器中使用命令执行的,当然这个也是非常安全的处理方式,那么在开发的阶段为了方便我们可是使用可视化界面连接redis,

比如RedisDesktopManager 这个软件等,方便我们快速的操作数据,下面的介绍也是依据这个软件进行的。

2、 针对与Redis 大家肯定也知道,redis的数据是保存在内存的,但是一旦把redis关闭则数据就会丢失,为了防止数据丢失,那么我就需要数据持久化到硬盘上,在此提供了两种持久化方案:

第一种是 RDB 快照的形式,第二种是 AOF 类似日志追加的方式。

那么我就快速的带大家了解一下

二、Redis客户端连接


1、前提说明一下:此方案只允许测试的时候配置,其他情况禁止使用

2、我们进入Redis的文件夹中,新建一个redis配置文件,文件名为: redis.custom.conf,然后在里面如下内容:

配置中的bind 代表绑定 本服务器的IP,在生产环境中禁止使用 0.0.0.0 ,此IP代表服务器内所有的IP都可以被外网进行连接;在生产环境中我们推荐使用绑定具体的内网IP,如我的IP为:192.168.250.132

daemonize yes
port 6666
requirepass 123
logfile ./redislog_louie.log
dir ./
bind 192.168.250.132 127.0.0.1  #  0.0.0.0

 3、此处我的redis端口为6666,如果大家没有关闭防火墙,则需要在防火墙中开启端口通过,允许端口6666的通过。

配置完成后我们保存然后启动。

./src/redis-server redis.custom.conf

然后我们使用 可视化工具连接一下我们的redis,发现连接成功,那么我就可以直接进行增删改查的数据操作啦。

 操作数据

 

 redis客户端已说明完,下面就是最重要的redis持久化。

三、Redis持久化方案


1、redis持久化有两种方案,一种是RDB,一种是AOF

2、RDB数据持久化

 1)说明:RDB是整体快照备份一样,就像我们系统进行镜像的备份这种快照处理,当然看到这个大家应该会有一个问题,这样备份效率相对比较慢,而且一次备份数据比较大,所以官方也不推荐使用此方案进行数据持久化,但我们还得结合实际情况使用,像

redis主从复制的原理底层数据就是通过RDB。

  2)触发RDB的方式有两种:

  save 同步保存

  bgsave 异步保存

话不多说我们配置一下RDB

daemonize yes
port 6666
requirepass 123
logfile ./redislog_louie.log
dir ./
bind 192.168.250.132 127.0.0.1 #  0.0.0.0

save 20 1  # 自动保存策略,20秒内有一个key发生变化就自动保存
dbfilename rdb_louie.rdb  #  rdb文件名
stop-writes-on-bgsave-error yes #  发生错误中断写入,建议开启
rdbcompression yes  # 数据文件压缩,建议开启
rdbchecksum yes # 开启crc64错误校验,建议开启

保存,运行一下我们的redis,就可以看到我们产生的rdb 文件了。

3、AOF数据持久化(推荐方案)

说明:日志追加数据持久化,即在原先的数据基础上进行追加,而不是完全覆写,这样效率高。

注:如果RDB与AOF同时存在的情况下,redis默认优先使用AOF进行数据恢复。

AOF的配置如下:

daemonize yes
port 6666
requirepass 123
logfile ./redislog_louie.log
dir ./
bind 192.168.250.132 127.0.0.1 # 0.0.0.0

appendonly yes  # 开启aof
appendfilename aof_louie.aof  # aof 日志文件名
appendfsync everysec  #  每秒记录一次日志,建议everysec
no-appendfsync-on-rewrite yes  # 重写过程中是否向日志文件写入,yes 代表rewrite过程中,不向aof文件中追加信息,rewrite结束后再写入,no 代表rewrite执行的同时,也向aof追加信息
auto-aof-rewrite-percentage 100 # 触发重写文件增长百分比 默认100%
auto-aof-rewrite-min-size 64mb  # 触发重写最小aof文件尺寸

看到上面的配置,大家会有疑问,为什么会有 重写,主要是因为要压缩数据,产生的文件更小,防止同样的相同命令占用空间,比如如下:用最简短的命令来操作数据

重写说明

至此,数据持久化已经都介绍完后 

四、总结


redis的持久化方案建议采用AOF,高效便捷。下一篇文章我们就要进行redis高可用的介绍。

如果针对上面有任何问题,欢迎留言咨询。

© 著作权归作者所有

编辑之路
粉丝 53
博文 50
码字总数 109912
作品 0
长沙
私信 提问
redis介绍、主从配置

NoSQL之redis介绍: remote rerictionry server 是一个基于key-value键值对的持久化数据库存储系统,redis和memcached缓存服务很像。 但是redis支持的数据存储类型更丰富,包括string、list、...

yacai1990
2016/07/11
0
0
面试宝典系列-读《深入学习Redis(2):持久化》概要

原文链接:深入学习Redis(2):持久化 Redis的5种对象类型(字符串、哈希、列表、集合、有序集合) 查看内存方法:info memory 内存碎片是Redis在分配、回收物理内存过程中产生的。例如,如...

suyain
2018/09/10
43
0
SegmentFault 技术周刊 Vol.37 - 分布式缓存利器:Redis

Redis 是由意大利程序员 Salvatore Sanfilippo(昵称:antirez)开发的一款内存高速缓存数据库。Redis 全称为 Remote Dictionary Server(远程数据服务),使用 C 语言编写,是一个 key-valu...

keke
2017/11/16
0
0
Redis复制(Replication)

概述 Redis 支持简单且易用的主从复制(master-slave replication)功能, 该功能可以让从服务器(slave server)成为主服务器(master server)的精确复制品。 以下是关于 Redis 复制功能的几个...

仝玉甫
2015/04/24
296
0
Redis的复制功能以及Redis复制机制本身的优缺点以及集群搭建问题

Redis复制流程概述 Redis的复制功能是完全建立在之前我们讨论过的基于内存快照的持久化策略基础上的,也就是说无论你的持久化策略选择的是什么,只要用到了 Redis的复制功能,就一定会有内存...

夕阳红树林
2012/06/18
558
1

没有更多内容

加载失败,请刷新页面

加载更多

关于运维,该怎么决定它的方向,这个似工作又似兴趣的存在

我之前主要从事网络、桌面、机房管理等相关工作,这些工作使我迷惘,这应该是大多数运维人都经历过的过程; 18年国庆,我从国内前三的消费金融公司裸辞,下海创业,就是想要摆脱这样的困境。...

网络小虾米
13分钟前
3
0
Java Timer的用法

Timer timer = new Timer(); timer.schedule(new TimerTask() { public void run() { System.out.println("11232"); } }, 200000 , 1000); public void schedule(TimerTask task, long delay......

林词
17分钟前
3
0
使用js动态加载外部js文件以及动态创建script脚本

动态脚本指的是在页面加载时不存在,但将来的某一时刻通过修改该DOM动态添加的脚本。和操作HTML元素一样,创建动态脚本也有两种方式:插入外部文件和直接插入JavaScript代码。 动态加载外的外...

Bing309
24分钟前
2
0
从零开始入门 K8s | Kubernetes 网络概念及策略控制

作者 | 阿里巴巴高级技术专家 叶磊 一、Kubernetes 基本网络模型 本文来介绍一下 Kubernetes 对网络模型的一些想法。大家知道 Kubernetes 对于网络具体实现方案,没有什么限制,也没有给出特...

阿里巴巴云原生
29分钟前
2
0
天气获取

本文转载于:专业的前端网站➨天气获取 $.get("http://wthrcdn.etouch.cn/WeatherApi", { citykey: cityCode }, function (d) { //创建文档对象 var parser = new ......

前端老手
29分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部