当前位置: 首页 > news >正文

1. Redis简介与安装

1.1 什么是Redis

Redis(Remote Dictionary Server)是一个开源的、基于内存的数据结构存储系统,支持多种数据结构,如字符串、列表、集合、有序集合和哈希。它不仅能作为一个高效的缓存工具,还能作为消息队列、分布式锁和持久化存储等广泛的场景中使用。

Redis的历史

Redis 由意大利开发者 Salvatore Sanfilippo 于 2009 年发布,最初是为了优化 LLOOGG 的性能问题,该应用需要高效地处理实时 Web 流量分析。后来,Redis 逐渐发展成为一个广泛使用的 NoSQL 数据库,并于 2015 年由 Redis Labs 负责商业维护与支持。

1.2 Redis的特性

Redis 之所以在众多场景中被广泛采用,与它的以下特性息息相关:

  1. 高效的内存操作:Redis 是基于内存的数据存储,所有数据都存储在内存中,这使得读写速度极快,非常适合用作缓存。

  2. 丰富的数据结构:Redis 不仅支持基本的键值对存储,还支持多种高级数据结构,如列表、集合、哈希和有序集合等,便于开发者灵活处理复杂的数据需求。

  3. 持久化机制:Redis 提供了两种持久化机制:

    • RDB快照:定期对内存数据进行快照保存。
    • AOF日志:将每次写操作记录到日志文件中,可以在服务器重启时恢复数据。
  4. 主从复制:Redis 支持主从复制,可以通过配置多个副本(slave)来实现读写分离和数据备份。

  5. 集群与高可用性:Redis 提供了 Redis Cluster 和 Redis Sentinel 两种机制,前者用于横向扩展,后者用于高可用性管理。

  6. Lua脚本:Redis 支持原生的 Lua 脚本,可以实现复杂的原子操作,避免数据不一致性问题。

  7. 事务支持:虽然 Redis 不支持真正的关系型数据库事务,但通过 MULTI、EXEC、WATCH 等命令,Redis 提供了一种简单的事务功能。

  8. 轻量级与易部署:Redis 使用 C 语言编写,性能高效,二进制文件很小,且无需繁杂的安装步骤,支持在大多数操作系统上运行。

1.3 Redis的应用场景

由于 Redis 是一个高效的内存存储系统,且支持多种数据结构和丰富的功能,以下是它的几个常见应用场景:

  1. 缓存系统:Redis 可以用作高效的缓存服务器,缓存频繁访问的数据,减轻后端数据库的压力,降低数据访问延迟。例如,电商平台可以缓存用户的购物车信息、商品价格等。

  2. 计数器/排行榜:Redis 支持原子性递增/递减操作,适合用作计数器应用场景,如记录网站访问量、视频播放量等。

  3. 会话管理:Redis 可以存储用户会话信息,特别是在 Web 应用中,用户登录后可以将其 Session 存储在 Redis 中,实现分布式会话管理。

  4. 消息队列:Redis 支持 List 数据结构和发布/订阅(Pub/Sub)模式,因此可以用作简单的消息队列系统,适合用于异步任务处理。

  5. 分布式锁:通过 Redis 的原子性命令,可以实现分布式锁,用来协调多个系统之间的并发访问控制。

  6. 实时数据分析:借助 Redis 高速读写的特点,可以实现高效的实时数据分析。例如,社交平台可以用 Redis 实现用户动态的实时统计分析。

1.4 Redis与其他数据库的对比

Redis 与其他常见数据库(如关系型数据库、NoSQL 数据库)存在显著差异,适用于不同的使用场景。以下是 Redis 与其他数据库的一些对比:

特性RedisMySQL(关系型数据库)MongoDB(NoSQL数据库)
数据存储内存存储+持久化磁盘存储磁盘存储
数据结构多种复杂数据结构表、行、列文档(JSON格式)
性能非常高,内存操作相对较慢高效,但不如Redis快
持久化可选持久化默认持久化默认持久化
事务支持基本支持完整事务支持基本事务支持
适用场景缓存、队列、实时分析复杂查询、持久存储大规模非结构化数据
1.5 安装Redis

Redis 的安装相对简单,支持多种操作系统,包括 Linux、macOS 和 Windows。以下是在常见操作系统上的安装步骤:

1.5.1 在Linux上安装Redis
  1. 使用 aptyum 安装 Redis(取决于你的 Linux 发行版):

    sudo apt update
    sudo apt install redis-server
    
  2. 安装完成后,启动 Redis 服务:

    sudo systemctl start redis-server
    
  3. 检查 Redis 是否正常运行:

    redis-cli ping
    

    如果返回 PONG,说明 Redis 运行正常。

1.5.2 在macOS上安装Redis
  1. 使用 Homebrew 安装 Redis:

    brew update
    brew install redis
    
  2. 安装完成后,启动 Redis:

    redis-server /usr/local/etc/redis.conf
    
  3. 验证安装:

    redis-cli ping
    
1.5.3 在Windows上安装Redis
  1. Redis 官方并未正式提供 Windows 版本,但可以使用第三方提供的 Windows 版本,如 Microsoft 开源的 Windows Redis 版本。
  2. 也可以通过 WSL(Windows Subsystem for Linux)在 Windows 上安装并运行 Redis。
1.6 Redis的基本配置与运行

Redis 提供了多种配置选项,以下是几个常见的基本配置:

  1. 修改默认端口:默认情况下,Redis 运行在 6379 端口。如果你想修改端口,可以编辑 redis.conf 文件中的 port 配置项:

    port 6380
    
  2. 最大客户端连接数:可以通过 maxclients 配置项来限制同时连接 Redis 服务器的客户端数:

    maxclients 10000
    
  3. 日志文件:通过 logfile 配置项可以指定 Redis 的日志文件路径:

    logfile "/var/log/redis/redis-server.log"
    
  4. 数据持久化配置:可以在 redis.conf 中启用或禁用 RDB 和 AOF 持久化功能:

    save 900 1  # 每900秒至少有1次写操作时保存数据快照
    appendonly yes  # 启用AOF日志
    
  5. 启动与停止 Redis

    • 启动 Redis:

      redis-server /path/to/redis.conf
      
    • 停止 Redis:

      redis-cli shutdown
      

通过这些基本的安装和配置,用户可以快速地搭建起一个 Redis 服务器,并用于生产环境或测试环境。

http://www.lryc.cn/news/468032.html

相关文章:

  • Redis的持久化存储和集群管理操作
  • Auto-encoder(自编码器)
  • Vue+sortable+el-table表格排序使用指南
  • 表数据删一半,为什么表文件大小不变?
  • MoCoOp: Mixture of Prompt Learning for Vision Language Models
  • YOLOv8 onnx 部署
  • 在文件里引用目录文件下的静态资源图片不显示
  • vue使用 jsplumb 生成流程图
  • 攻坚金融关键业务系统,OceanBase亮相2024金融科技大会
  • 《纳瓦尔宝典:财富和幸福指南》读书随笔
  • C++ | STL | 侯捷 | 学习笔记
  • C函数基础
  • html和css实现页面
  • Github_以太网开源项目verilog-ethernet代码阅读与移植(八)——移植工程分享
  • 【大模型实战篇】大模型分词算法BPE(Byte-Pair Encoding tokenization)及代码示例
  • 低功耗4G模组LCD应用示例超全教程!不会的小伙伴看这篇就够了!
  • Java while语句练习 C语言的函数递归
  • illustrator免费插件 截图识别文字插件 textOCR
  • 提升数据管理效率:ETLCloud与达梦数据库的完美集成
  • 头歌——人工智能(搜索策略)
  • gorm.io/sharding改造:赋能单表,灵活支持多分表策略(下)
  • 域渗透AD渗透攻击利用 MS14-068漏洞利用过程 以及域渗透中票据是什么 如何利用
  • C++进阶-->继承(inheritance)
  • 可视化项目 gis 资源复用思路(cesium)
  • SQL实战测试
  • Java 基础教学:基础语法-变量与常量
  • vue3使用element-plus手动更改url后is-active和菜单的focus颜色不同步问题
  • 每天五分钟深度学习框架pytorch:从底层实现一元线性回归模型
  • 编辑器加载与AB包加载组合
  • 【c++】vector中的back()函数