仿论坛项目--Redis,一站式高性能存储方案

2024-09-06 06:04

本文主要是介绍仿论坛项目--Redis,一站式高性能存储方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Redis入门

• Redis是一款基于键值对的NoSQL数据库,它的值支持多种数据结构:
字符串(strings)、哈希(hashes)、列表(lists)、集合(sets)、有序集合(sorted sets)等。
• Redis将所有的数据都存放在内存中,所以它的读写性能十分惊人。
同时,Redis还可以将内存中的数据以快照或日志的形式保存到硬盘上,以保证数据的安全性。
• Redis典型的应用场景包括:缓存、排行榜、计数器、社交网络、消息队列等。
下载好之后,配置环境变量。E:\work\Redis
打开cmd,输入redis-cli启动redis
默认15个库,通过命令select 1,2…选择相应的库

set test:count 1
get test:count取值
incr test:count 增加
decr test:count 减少

Spring整合Redis

• 引入依赖

  • spring-boot-starter-data-redis
    • 配置Redis
  • 配置数据库参数
  • 编写配置类,构造RedisTemplate
    • 访问Redis
  • redisTemplate.opsForValue()
  • redisTemplate.opsForHash()
  • redisTemplate.opsForList()
  • redisTemplate.opsForSet()
  • redisTemplate.opsForZSet()

点赞

• 点赞

  • 支持对帖子、评论点赞。
  • 第1次点赞,第2次取消点赞。
    • 首页点赞数量
  • 统计帖子的点赞数量。
    • 详情页点赞数量
  • 统计点赞数量。
  • 显示点赞状态。

我收到的赞

• 重构点赞功能

  • 以用户为key,记录点赞数量
  • increment(key),decrement(key)
    • 开发个人主页
  • 以用户为key,查询点赞数量

关注、取消关注

• 需求

  • 开发关注、取消关注功能。
  • 统计用户的关注数、粉丝数。
    • 关键
  • 若A关注了B,则A是B的Follower(粉丝),B是A的Followee(目标)。
  • 关注的目标可以是用户、帖子、题目等,在实现时将这些目标抽象为实体。

关注列表、粉丝列表

• 业务层

  • 查询某个用户关注的人,支持分页。
  • 查询某个用户的粉丝,支持分页。
    • 表现层
  • 处理“查询关注的人”、“查询粉丝”请求。
  • 编写“查询关注的人”、“查询粉丝”模板。

优化登录模块

• 使用Redis存储验证码

  • 验证码需要频繁的访问与刷新,对性能要求较高。
  • 验证码不需永久保存,通常在很短的时间后就会失效。
  • 分布式部署时,存在Session共享的问题。
    • 使用Redis存储登录凭证
  • 处理每次请求时,都要查询用户的登录凭证,访问的频率非常高。
    • 使用Redis缓存用户信息
  • 处理每次请求时,都要根据凭证查询用户信息,访问的频率非常高。

关于Redis的概念,下列描述错误的是()

A.NoSQL是关系型数据库之外的数据库的统称,Redis就是一个NoSQL数据库。

B.Redis以键值对的形式,将数据存储于硬盘中,其所有的kay都是字符串类型!

C.Redis的值支持多种数据类型,包括字符串、哈希、列表、集合、有序集合等。

D.Redis提供了对值进行运算的命令,如对集合求交集、并集、差集等。

解析:
A. NoSQL是关系型数据库之外的数据库的统称,Redis就是一个NoSQL数据库。

这个说法是对的。NoSQL数据库确实是指那些非关系型的数据库,而Redis正是一个NoSQL数据库。

B. Redis以键值对的形式,将数据存储于硬盘中,其所有的key都是字符串类型!

这里有一个错误。Redis默认是将数据存储在内存中的,并不是硬盘。虽然Redis可以从硬盘中读取持久化数据或把数据写入硬盘(通过RDB快照或AOF机制),但其主要特性之一就是作为内存数据库提供快速的数据访问。

C. Redis的值支持多种数据类型,包括字符串、哈希、列表、集合、有序集合等。

这个说法是正确的。Redis支持多种数据类型,包括但不限于字符串、哈希、列表、集合、有序集合等。

D. Redis提供了对值进行运算的命令,如对集合求交集、并集、差集等。

这也是正确的。Redis确实提供了针对集合和其他数据类型的命令来执行各种操作,包括但不限于交集、并集、差集等。

关于Redis的持久化,下列描述错误的是:()

A.RDS是以快照的形式,将内存中的数据整体拷贝到硬盘上。
B.执行RDS存储时会产生阻塞,因此RDS不适合实时备份,而适合定时备份。
C.AOF是以日志形式,将内存中的数据整体拷贝到硬盘上。
D.AOF的操作实时性好,但是产生的数据体积大,数据的恢复速度慢。

解析:
A. RDB(Redis Database dump,即RDS)是以快照的形式,将内存中的数据整体拷贝到硬盘上。

这个描述是正确的。RDB是Redis的一种持久化方式,它会创建一个数据快照并保存到硬盘上。

B. 执行RDB存储时会产生阻塞,因此RDB不适合实时备份,而适合定时备份。

这个描述也是准确的。在执行RDB持久化时,Redis会有一个短暂的时间内停止处理客户端请求,这可能会导致服务短暂中断或延迟,因此通常是在低峰时段进行。

C. AOF(Append Only File)是以日志形式,将内存中的数据整体拷贝到硬盘上。

这里存在错误。AOF并不是将内存中的数据整体拷贝到硬盘上,而是记录所有写入操作的命令到一个文件中。当Redis启动时,它可以通过重新执行这些命令来重建数据集。

D. AOF的操作实时性好,但是产生的数据体积大,数据的恢复速度慢。

这个描述基本是正确的。AOF因为记录的是命令,所以它的实时性较好,但由于记录了每一次写操作,文件可能变得非常大,而且在数据恢复时可能需要花费较长时间来重放这些命令。

想要返回有序集合中元素的个数,下列命令中正确的是()

A.zcard key
B.scard key
C.zlen key
D.zsize key

解析:
A.zcard key - 这个命令用于获取无序集合(Set)的大小,而不是有序集合(Sorted Set)。

B.scard key - 这个命令同样用于获取无序集合(Set)的大小,与有序集合无关。

C.zlen key - 这个命令不存在,正确的命令应该是zcount key,用于计算有序集合在指定分数范围内的元素数量。

D.zsize key - 这个命令也不存在,正确的命令应该是zcount key,用于计算有序集合在指定分数范围内的元素数量。

综上所述,选项A和B是针对无序集合的命令,选项C和D是错误的命令。实际上,要获取有序集合中元素的个数,应该使用zcard key这个命令。所以正确答案为A。

这篇关于仿论坛项目--Redis,一站式高性能存储方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1141200

相关文章

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二

MySQL之InnoDB存储页的独立表空间解读

《MySQL之InnoDB存储页的独立表空间解读》:本文主要介绍MySQL之InnoDB存储页的独立表空间,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、独立表空间【1】表空间大小【2】区【3】组【4】段【5】区的类型【6】XDES Entry区结构【

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

springboot项目打jar制作成镜像并指定配置文件位置方式

《springboot项目打jar制作成镜像并指定配置文件位置方式》:本文主要介绍springboot项目打jar制作成镜像并指定配置文件位置方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录一、上传jar到服务器二、编写dockerfile三、新建对应配置文件所存放的数据卷目录四、将配置文