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

Redis学习

缓存定义

缓存是一个告诉数据交换的存储器,使用它可以快速的访问和操作数据。

常见缓存使用

本地缓存的常见使用:Spring Cache、MyBatis的缓存等

我的session存储和redis都放到缓存里面的,所有程序不管部署多少份,访问的都是redis。

 分布式缓存的常见使用:Redis和Memcached

Redis常用数据类型

1、String——字符串类型,使用最最最频繁,相当于Java里的hashmap,以key-value的形式进行存储。根据key来存储和获取value值的。

使用:set k1 v1

           get k1

           strlen k1  #查询字符串长度

           ex(expire)参数来设置字符串的过期时间 eg:设置k1 1000s 后过期(删除)

使用场景:存放用户(登录)信息;

                  存放文章详情和列表信息;

                  存放和累计网页的统计信息

Hash——字典类型

使用:hset myhash key1 value1

         (integer)1

           hget myhash key1

            "value" 

List——列表类型,和Java里的数组一样

使用:lpush list 1 2 3

          (integer) 3

          lpop list

          1

Set——集合类型,无序并唯一的键值集合

使用:sadd myset v1 v2 v3  #添加数据

           smember myset   #查询计划中的所有数据

使用场景:微博关注我的人和我关注的人都适合集合存储,可以保证人员不会重复

                中奖人信息也适合用集合类型存储,这样可以保证一个人不会重复中奖。

集合类型set和列表类型list区别:

        列表可以存储重复元素,集合只能存非重复的元素

        列表是按照元素的先后顺序存储元素的,而集合则是无序方式存储元素的。

ZSet——有序集合类型,相比集合类型多了一个排序属性score(分值),对于有序集合ZSet来说,每个存储元素相当于有两个值组成的,一个是有序结合的元素值,一个是排序值。有序集合的存储元素值也是不能重复的,但分值是可以重复的。

使用:zadd zset1 3 golang 4 sql 1 redis      #添加数据

           zrange zset 0 -1        #查询所有数据

持久化

Redis持久化的方式:

  • 快照方式(RDB,Redis DateBase)将某一时刻的内存数据,以二进制的方式写入磁盘;
  • 文件追加方式(AOF,Append Only File),记录所有的操作命令,并以文本的方式写入追加到文件中;
  • 混合持久化方式,Redis 4.0之后新增的方式,混合持久化是结合了RDB和AOF的优点,在写入的时候,先把当前的数据以RDB的形式写入文件的开头,再将后续的操作命令以AOF的格式存入文件,则有既能保证Redis重启时的速度,又能减低数据丢失的风险。

常见面试题

缓存雪崩

缓存穿透:查询数据库和缓存都无数据,因为数据库查询为u数据,用于容错

Redis集群(选学)

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

相关文章:

  • uni-app:实现picker下拉列表的默认值设置
  • 基于NB-iot技术实现财物跟踪的EA01-SG定位模块方案
  • 挑战吧,HarmonyOS应用开发工程师
  • 图论05-【无权无向】-图的广度优先BFS遍历-路径问题/检测环/二分图/最短路径问题
  • uniapp:谷歌地图,实现地图展示,搜索功能,H5导航
  • 关于腾讯云轻量应用服务器性能测评,看这一篇文章就够了
  • HDFS集群NameNode高可用改造
  • Spark集群中一个Worker启动失败的排错记录
  • Mysql的JDBC知识点
  • git的实际操作
  • 数据结构零基础C语言版 严蔚敏-线性表、顺序表
  • Keil uVision 5 MDK版软件安装包下载及安装教程(最详细图文教程)
  • 单目3D目标检测[基于深度辅助篇]
  • Ubuntu20.04下安装MySQL8环境
  • html鼠标悬停图片放大
  • 基于hugging face的autogptq量化实践
  • MySQL2:MySQL中一条查询SQL是如何执行的?
  • C++入门01—从hello word!开始
  • Mingw下载---运行vscodeC++文件
  • 数据安全与PostgreSQL:最佳保护策略
  • 火山引擎实时、低延时拥塞控制算法的优化实践
  • adb设备调试常用命令
  • ubuntu下Docker的简单使用并利用主机显示
  • 第12章 PyTorch图像分割代码框架-1
  • 2023CSPJ 旅游巴士 —— dijkstra
  • 数据结构之栈的讲解(源代码+图解+习题)
  • 内网渗透-内网信息收集
  • ​LeetCode解法汇总2520. 统计能整除数字的位数
  • Lua语言编写爬虫程序
  • 安防监控项目---概要