redis学习笔记(六)

redis每种数据结构的应用场景

1. 字符串 (String)
  • 应用场景 :

    • 缓存:存储频繁访问的数据,如网页缓存、会话信息等。
    • 计数器:实现统计和计数功能,如访问计数、统计数据等。
    • 键值存储:简单的键值对存储,如用户配置信息、配置参数等。
    • 消息队列:使用 SETGET 命令快速传递消息。
2. 哈希 (Hash)
  • 应用场景
    • 对象存储:将复杂的数据对象存储为哈希结构,如用户信息、商品详情等。
    • 分组数据:组织和管理相关数据,如用户的属性信息、订单的各个字段等。
    • 小型数据集:适用于存储少量字段的对象,并且可以通过字段名快速访问。
3. 列表 (List)
  • 应用场景
    • 消息队列:使用 LPUSHBRPOP 命令实现队列功能,如任务队列、消息队列等。
    • 时间序列数据:存储有序的数据集合,如日志记录、时间序列数据等。
    • 历史记录:实现浏览记录、聊天记录等有序历史记录的功能。
4. 集合 (Set)
  • 应用场景
    • 去重:使用集合的唯一性特征存储唯一元素,如用户标签、兴趣爱好等。
    • 集合运算:实现交集、并集、差集等操作,如推荐系统中的用户兴趣分析。
    • 成员管理:管理具有独特属性的集合,如社交网络中的好友列表等。
5. 有序集合 (Sorted Set)
  • 应用场景
    • 排行榜:实现游戏中的排行榜、网站的热度榜单等,支持按分数排序和范围查询。
    • 时间序列数据:按时间戳排序的数据,如实时数据流、日志记录等。
    • 任务调度:按优先级调度任务,支持根据分数快速排序和检索。
6. 位图 (Bitmap)
  • 应用场景
    • 统计分析:实现高效的布尔标记,如用户签到、活跃度统计等。
    • 压缩存储:节省存储空间,适用于大规模的数据集,如用户活跃状态的标记。
    • 位操作:进行快速的位级操作,如每日活跃用户统计。
7. 超日志 (HyperLogLog)
  • 应用场景
    • 去重计数:实现大规模数据的基数统计,如唯一访客数、独立用户数等。
    • 数据分析:进行大数据量的统计分析,减少内存占用。
8. 地理空间索引 (Geo)
  • 应用场景
    • 地理定位:存储地理位置数据,进行距离计算、位置查询等功能。
    • 位置服务:实现位置相关的服务,如附近的商家、用户位置跟踪等。
9. 流 (Stream)
  • 应用场景
    • 日志记录:实时记录和处理日志数据,如系统日志、用户活动日志等。
    • 事件流处理:处理和分析实时事件流,如用户行为数据、传感器数据等。
    • 消息队列:实现高吞吐量的消息队列,支持持久化和消息消费。

十五、Redis.conf详解

redis配置文件

十六、Redis持久化

1、rdb:redis database

快照

dump.rdb文件

触发机制

  1. save的规则满足会触发rdb规则
  2. flushall清空会默认产生一个rdb文件
  3. 退出redis,也会产生rdb文件

备份就自动生成一个dump.rdb文件

如何恢复

  1. 只要把rdb文件放到redis启动目录下就可以了
  2. 查看需要存放的位置:
 config get dir
优点:
  1. 适合大规模的数据恢复
  2. 对数据的完整性要求不高
缺点:
  1. 需要一定的时间间隔进行操作,如果redis意外宕机了,这个最后一次修改数据就没有的了
  2. fork进程的时候,会占用一定的内存空间

2、aof:append only file

appendonly.aof

记录所有写的操作。默认不开启,要手动配置。

重启redis就能生效。

如果这个aof文件有错误,这时候redis是启动不起来的,我们需要修复这个文件。

redis提供了一个工具:redis-check-aof --fix

如果文件正常,重启就可以直接恢复了

appendonly no 
appendfilename "appendonly.aof"
appendfsync everysec   #每秒执行一次
#rewrite 重写 
优点:
  1. 每一次修改都同步,文件的完整会更加好
  2. 每秒同步一次,可能会丢失一秒的数据
  3. 从不同步,效率最高
缺点:
  1. 相对于数据文件来说,aof远远打于rdb,修复的速度也比rdb慢
  2. aof运行效率也比rdb慢,所以我们redis默认配置的就是rdb持久化
### Redis 学习笔记概述 Redis 是一种高性能的键值存储系统,支持多种数据结构并提供丰富的功能。为了全面掌握 Redis 的使用方法和技术细节,一份详尽的学习笔记应当覆盖以下几个方面: #### 一、基础概念介绍 - **定义与特性** - Redis 是一个开源的内存数据结构存储库,可以用作数据库、缓存和消息中间件[^1]。 - **应用场景** - 高效的数据读写操作使其适用于高速缓存场景;持久化的选项也允许作为可靠的主数据库。 #### 二、环境搭建指南 - **安装过程** - 安装完成后可以通过 `redis-server` 命令启动服务,默认情况下这会在前台运行并且占用当前终端会话[^2]。 - **后台模式配置** - 推荐通过编辑 `/usr/local/src/redis-6.2.6/redis.conf` 文件中的设置项使 Redis 在后台稳定工作。 #### 三、核心功能解析 - **基本命令集** - 包括字符串(Strings)、哈希(Hashes)、列表(Lists)等常见数据类型的增删改查指令。 - **高级特性应用** - 发布订阅(Pub/Sub),事务处理(Transaction),Lua脚本执行等功能的应用实例。 #### 四、集成开发实践 - **Spring Boot 整合案例** - 使用 Spring Data Redis 提供的 `RedisTemplate` 对象简化 Java 应用程序同 Redis 数据源之间的交互逻辑[^3]。 #### 五、优化策略探讨 - **性能调优技巧** - 考虑到 CPU 并非主要瓶颈因素而是受制于物理 RAM 和网卡吞吐能力的影响,合理规划硬件资源分配对于提升整体效率至关重要。 - **预加载机制说明** - 当应用程序首次上线前预先填充部分热点数据至 Redis 中可以有效缓解高峰期的压力,提高响应速度[^4]。 #### 、可靠性保障措施 - **持久化方案对比** - RDB 快照方式能够在指定时间间隔内保存数据副本,确保意外断电等情况下的恢复可能性。 ```bash # 启动Redis服务器(建议采用守护进程方式) $ redis-server /path/to/redis.conf --daemonize yes ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值