Redis 是一种高性能、高可靠的内存数据存储和处理系统,它支持多种数据结构和协议,可以用于各种不同的应用场景。本文将介绍 Redis 的高级特性,包括持久化、事务、Lua 脚本等方面,以及如何使用这些特性实现高性能、高可靠的数据存储和处理。

高性能、高可用、高可扩展性的原理

  1. 基于内存的数据结构:Redis将数据存储在内存中,而不是硬盘中,因此可以实现非常高速的读写操作。
  2. 单线程的模型:Redis采用单线程的模型,避免了多线程之间的竞争问题,也减少了线程切换的开销。
  3. 高效的网络通信:Redis采用自己设计的简单协议进行通信,协议本身非常轻量级,减少了网络传输的开销。
  4. 异步非阻塞式IO:Redis采用异步非阻塞的IO模型,当IO操作完成后才会通知应用程序,避免了IO阻塞对性能的影响。
  5. 高效的持久化机制:Redis支持多种持久化机制,包括快照和AOF,可以满足不同的业务需求,同时也可以提高数据的安全性。
学会与人相处,建立良好的人际关系,
这是在职场中获得成功的关键。

持久化

Redis是一种内存数据库,它将数据存储在内存中,因此它非常快速。但是,如果Redis进程意外终止,所有数据将丢失。为了解决这个问题,Redis提供了持久化功能,它可以将内存中的数据异步写入磁盘,以便在Redis重启后可以恢复数据。

RDB持久化

RDB持久化是将Redis在某个时间点上的数据保存到硬盘上,可以看作是对Redis内存中的数据做一个快照。RDB持久化可以通过配置Redis服务器的时间间隔来自动触发,也可以手动执行。

AOF持久化

AOF持久化是将Redis的写操作以文本形式追加到文件中。AOF文件中的每个写操作都是一个Redis命令,当Redis服务器重启时,可以通过执行AOF文件中的所有命令来恢复数据。

持久化的配置

RDB配置

RDB持久化的配置文件为redis.conf。在配置文件中,可以通过以下配置项来控制RDB持久化的行为:

  • save:指定Redis自动触发RDB持久化的条件,格式为 save ,其中seconds表示时间间隔,changes表示数据变化的次数。例如,save 900 1 表示如果900秒内有至少1个键被修改,则触发RDB持久化。
  • stop-writes-on-bgsave-error:如果设置为yes,则如果RDB持久化失败,Redis服务器将停止接受写请求,直到RDB持久化成功为止。

    Redis还提供了以下与RDB持久化相关的命令:
  • save:手动触发RDB持久化。
  • bgsave:在后台异步执行RDB持久化。

AOF配置

AOF持久化的配置文件为redis.conf。在配置文件中,可以通过以下配置项来控制AOF持久化的行为:

  • appendonly:如果设置为yes,则开启AOF持久化。
  • appendfsync:指定AOF缓冲区何时将数据同步到硬盘,有以下三个选项:
    • always:每个Redis命令都会立即同步到硬盘。
    • everysec:每秒将AOF缓冲区中的数据同步到硬盘。
    • no:完全依赖操作系统将数据同步到硬盘。
  • no-appendfsync-on-rewrite:如果设置为yes,则当Redis执行AOF重写时,不将数据同步到硬盘。

    Redis还提供了以下与AOF持久化相关的命令:
  • bgrewriteaof:在后台异步执行AOF重写。
  • bgappendonly:在后台异步执行AOF缓冲区的数据同步到硬盘。

持久化的恢复

RDB的恢复

RDB持久化的恢复比较简单,只需将RDB文件复制到Redis服务器的工作目录,并在redis.conf文件中指定RDB文件的路径即可。Redis服务器启动时会自动加载RDB文件,并恢复数据。

人生如一场旅程,不要只看到目的地,
更要享受旅途中的美好。

AOF的恢复

AOF持久化的恢复相对复杂。首先,需要将AOF文件加载到Redis服务器中:

plaintextCopy code
redis-cli
CONFIG SET appendonly yes
BGREWRITEAOF

然后,需要清空Redis服务器中的数据:

plaintextCopy code
redis-cli
FLUSHALL

最后,执行AOF文件中的所有命令,恢复数据:

plaintextCopy code
redis-cli
CONFIG SET appendonly yes
BGREWRITEAOF

RDB和AOF的选择

在选择持久化方式时,需要根据实际的业务场景和需求来选择RDB或AOF持久化。如果对数据完整性要求较高,可以选择AOF持久化;如果对数据完整性要求不高,可以选择RDB持久化。

持久化对性能的影响

持久化会对Redis服务器的性能产生一定的影响,特别是在执行RDB持久化时,由于需要fork出子进程,会占用一定的CPU和内存资源。因此,在配置持久化时,需要根据实际情况来平衡数据安全和性能的需求。

数据的丢失问题

由于Redis的持久化是异步的,因此在Redis意外终止时,可能会丢失部分数据。为了最小化数据丢失的风险,可以使用AOF持久化,并将appendfsync设置为always。这将确保每个写操作都同步到磁盘上的AOF文件中。

事务

Redis事务是指在一次操作中执行多个命令,并且这些命令要么全部被执行,要么全部不执行。Redis事务可以保证一系列命令的原子性执行。

职场中最重要的能力并不是技术或知识,
而是沟通和协作的能力。

事务的优点

  • 原子性:Redis事务可以保证多个命令的原子性执行,即要么全部执行,要么全部不执行。
  • 性能:Redis事务可以将多个命令打包成一个批量操作,从而减少网络通信的开销,提高性能。
  • 一致性:Redis事务可以保证多个命令的一致性,即在执行事务期间,其他客户端不会对这些命令进行修改。

实现方式

  • MULTI:开始一个事务。
  • EXEC:执行事务中的所有命令。
  • DISCARD:取消事务。
  • WATCH:监视一个或多个键,如果在事务执行期间这些键被修改,事务将被取消。

示例:

/**
* 事务操作
* @param isOpenError 是否开启异常
*/
public void transactionalMethod(boolean isOpenError) {
redisTemplate.execute(new SessionCallback<List<Object>>() {
@Override
public List<Object> execute(RedisOperations operations) {
operations.multi(); // 开启事务
ValueOperations<String, String> valueOps = operations.opsForValue();
valueOps.set("key1", "value1");
if(isOpenError){
int i = 1 / 0;
}
valueOps.set("key2", "value2");
List exec = operations.exec();//提交事务
return exec;
}
});
}

注意事项

  • Redis事务不支持回滚操作。
  • 如果在执行事务期间,键被其他客户端修改,那么事务将被取消。
  • Redis事务不支持嵌套事务。
  • Redis事务中的命令不能使用事务外的数据。
  • Redis事务中的命令不支持乐观锁。

应用场景

  • 批量操作:将多个命令打包成一个事务,从而减少网络通信的开销,提高性能。
  • 保证数据一致性:在需要保证数据一致性的场景中使用Redis事务可以避免因为并发操作导致数据不一致的问题。

发布订阅

发布和订阅是 Redis 的一种消息传递机制,它可以实现多个客户端之间的消息通信。下面是一个简单的 Redis 发布和订阅的示例

实现消息订阅者

public class RedisMessageListener implements MessageListener {
@Override
public void onMessage(Message message, byte[] bytes) {
System.out.println("收到消息: " + message.toString());
}
}

注册消息订阅者

@Bean
public RedisMessageListenerContainer redisContainer() {
RedisMessageListenerContainer container = new RedisMessageListenerContainer();
container.setConnectionFactory(redisTemplate().getConnectionFactory());
container.addMessageListener(new RedisMessageListener(), new ChannelTopic("pubsub:example"));
return container;
}

发送消息

public void publish(String message) {
redisTemplate.convertAndSend("pubsub:example", message);
}

lua脚本

永远保持谦虚和学习的心态,
才能不断提升自己,赢得更多的机会和尊重。

Redis 支持 Lua 脚本,可以通过编写 Lua 脚本来实现复杂的数据操作和处理。Redis 的 Lua 脚本可以访问 Redis 数据库,Redis 提供的各种命令和函数。

下面是一个使用lua脚本实现redis自增计数器的示例

public Long increment(String key) {
DefaultRedisScript<Long> script = new DefaultRedisScript<>();
script.setScriptSource(new ResourceScriptSource(new ClassPathResource("lua/increment.lua")));
script.setResultType(Long.class);
List<String> keys = Collections.singletonList(key);
return redisTemplate.execute(script, keys);
}

lua脚本

local key = KEYS[1]
local value = redis.call('INCR', key)
return value

使用 Lua 脚本可以将多个 Redis 命令封装在一个脚本中,减少网络开销和服务器负载。此外,Lua 脚本还可以实现 Redis 不支持的数据结构和算法,可以扩展 Redis 的功能和应用范围。

管道操作

管道(pipeline)是一种高效的Redis命令执行方式,它可以在一次通信中发送多个Redis命令,并一次性获取所有命令的响应结果。这种方式可以有效地降低Redis服务器的网络延迟和通信开销,提高Redis的性能。

下面是一个使用管道操作的示例

/**
* 管道操作
* 注意管道操作不支持事务和watch命令,需要谨慎使用。
* 管道操作会将多个命令打包成一个请求发送给Redis服务器,
* 如果其中一个命令执行失败,那么整个管道操作都会失败
*/
public void pipelineExample() {
List<Object> results = redisTemplate.executePipelined(new RedisCallback<Object>() {
@Override
public Object doInRedis(RedisConnection connection) throws DataAccessException {
connection.stringCommands().set("key1".getBytes(), "value1".getBytes());
connection.stringCommands().set("key2".getBytes(), "value2".getBytes());
connection.stringCommands().set("key3".getBytes(), "value3".getBytes());
return null;
}
});
System.out.println(results); // 打印结果
}

完整代码地址

https://gitee.com/youlaiorg/youlai-learning.git

总结

本文介绍了Redis的高级特性,包括持久化、事务、发布订阅、lua脚本和管道操作。其中,持久化可以实现数据的持久化存储,事务可以保证一系列命令的原子性执行,发布订阅可以实现多个客户端之间的消息通信,lua脚本可以实现复杂的数据操作和处理,管道操作可以在一次通信中发送多个Redis命令。此外,本文还介绍了Redis高性能、高可用、高可扩展性的原理,包括基于内存的数据结构、单线程的模型、高效的网络通信、异步非阻塞式IO和高效的持久化机制。

做事要讲求团队合作,相互支持,共同进步。

全面了解 Redis 高级特性,实现高性能、高可靠的数据存储和处理的更多相关文章

  1. redis 高级特性 不要太好用

    Redis高级特性及应用场景 redis中键的生存时间(expire) redis中可以使用expire命令设置一个键的生存时间,到时间后redis会自动删除它. 过期时间可以设置为秒或者毫秒精度. ...

  2. 【Redis】二、Redis高级特性

    (三) Redis高级特性   前面我们介绍了Redis的五种基本的数据类型,灵活运用这五种数据类型是使用Redis的基础,除此之外,Redis还有一些特性,掌握这些特性能对Redis有进一步的了解, ...

  3. Redis高级特性及应用场景

    Redis高级特性及应用场景 redis中键的生存时间(expire) redis中可以使用expire命令设置一个键的生存时间,到时间后redis会自动删除它. 过期时间可以设置为秒或者毫秒精度. ...

  4. Redis高级特性介绍及实例分析

    转自:http://www.jianshu.com/p/af7043e6c8f9   Redis基础类型回顾 String Redis中最基本,也是最简单的数据类型.注意,VALUE既可以是简单的St ...

  5. Redis高级特性介绍以及实例分析

    Redis基础类型回顾 转自:http://www.jianshu.com/p/af7043e6c8f9 String Redis中最基本,也是最简单的数据类型.注意,VALUE既可以是简单的Stri ...

  6. 【MySQL高级特性】高性能MySQL第七章

    2017-07-25 14:15:43 前言:MYSQL从5.0和5.1版本开始引入了很多高级特性,例如分区.触发器等,这对有其他关系型数据库使用 背景的用户来说可能并不陌生.这些新特性吸引了很多用户 ...

  7. Redis高级功能-1、高并发基本概述

    1.可能的问题 要将redis运用到工程项目中,只使用一台redis是万万不能的,原因如下: (1)从结构上,单个redis服务器会发生单点故障,并且一台服务器需要处理所有的请求负载,压力较大. (2 ...

  8. Redis高级特性

    redis的事务(transaction) 转载:https://blog.csdn.net/fmwind/article/details/78065236 redis中的事务是一组命令的集合.事务同 ...

  9. Redis 高级特性

    Redis 数据结构 Redis 常用的数据类型主要有以下五种: String Hash List Set Sorted set Redis 内部使用一个 redisObject 对象来表示所有的 k ...

  10. [Redis]Redis高级特性的配置及使用

    ---------------------------------------------------------------------------- [Redis安全性] 一 . 默认我们进入Re ...

随机推荐

  1. .gitignore忽略文件无效的解决办法

    .gitignore中已经标明忽略的文件目录下的文件,git push的时候还会出现在push的目录中,原因是因为在git忽略目录中,新建的文件在git中会有缓存,如果某些文件已经被纳入了版本管理中, ...

  2. fiddler everywhere 抓包工具的使用

    1.功能 手机微信或者浏览器访问网址都可以在fidder里面抓到http请求 2.配置 电脑fidder setting->允许安卓手机远程访问 安卓手机 设置->wifi代理 主机名是电 ...

  3. python基础篇 15-常用模块:random string sorted lambda函数

    一.random import os,random,sys,time,string print(random.randint(1,10)) # 产生随机的整数 print(random.uniform ...

  4. 零知识证明(Zero-Knowledge Proof)

    零知识证明(Zero Knowledge Proof)指的是,证明的人可以向验证的人,在不透露任何有用信息的情况下,使得验证者相信该结论是对的. 三种零知识证明技术:zk-SNARKs, Zk-STA ...

  5. 上传路径Class替换无效

    路径配置文件使用的常量,其它文件使用路径时,编译class时为静态常量信息,改变不同的路径常量则不生效

  6. 微信小程序开发遇到的注意事项及奇怪事

    1.wx.uploadFile上传文件时只支持本地文件(相册或者拍摄的),网络文件不可以,可以将网络文件用wx.downloadFile下载到本地在下载,下载以后会返回一个微信临时地址然后再下载 2. ...

  7. python基于word模板批量生成word文件

    1.需要用到docxtpl库,用于操作word模板 安装:pip insatll docxtpl 处理之前的word模板 处理后的word 下面直接上代码揭开它的神秘面纱:第一步,读取excel中的内 ...

  8. 【python】第二模块 步骤一 第二课、数据库表的相关操作

    第二课.数据库表的相关操作 一.课程介绍 1.1 课程介绍 学习目标 管理逻辑库和数据表 创建.删除.修改逻辑库和数据表 了解常用的数据类型和约束 字符串.整数.浮点数.精确数字.日期.枚举.主要约束 ...

  9. js 复制链接内容

    <script type="text/javascript">//复制活动地址 function shareUrl(id) { var url = 'http://H5 ...

  10. springboot配置类@ConfigurationProperties报错Not registered via @EnableConfigurationProperties or marked as Spring component

    添加一个@Component可以解决此问题,只有这个组件是容器中的组件,才能使用容器提供的@ConfigurationProperties功能.