Redis08-击穿&穿透&雪崩&spring data redis
一、常见概念
击穿:
概念:redis作为缓存,设置了key的过期时间,key在过期的时候刚好出现并发访问,直接击穿redis,访问数据库
解决方案:使用setnx() ->相当于一把锁,设置的时候,发现设置过期,加锁,只有获得锁的人才可以访问DB,这样就能防止击穿。
逻辑:
1. get key
2. setnx
3. if ok addDB
else sleep
go to 1
question1:如果第一个加锁的人挂了? 可以设置过期时间
question2:如果第一个加锁的人没挂,但是锁超时了? 可以使用多线程,一个线程取库,一个线程监控前一个线程是否存活,更新锁时间。
穿透:
概念:从业务接收查询的是你系统根本不存在的数据,这时候刚好从redis穿透到数据
解决方案:
使用布隆过滤器,不存在的数据使用bitmap进行拦截
- 1.使用布隆过滤器。从客户端包含布隆过滤器的算法。
- 2.直接redis集成布隆模块。
question1:布隆过滤器只能查看,不能删除?解决方案:换cuckoo过滤器。
雪崩:
概念:大量的key同时失效,造成雪崩。
解决方案:在失效的基础上,再加入一个时间(1-5min)
二、SpringDataRedis
客户端连接,我们可以使用Jedis、lettuce、redisson...但是,我们在技术选型时,鉴于多方面考虑,选用SpringDataRedis
1.创建一个SpringBoot项目,勾选Spring Data Redis,也可以直接引入
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
2.使用序列化的方式,进行set和get值(乱码)
ValueOperations vo = redisTemplate.opsForValue();
vo.set("Hello","china");
System.out.println(vo.get("Hello"));
3.使用StringRedisTemplate来调整乱码情况
ValueOperations<String, String> svo = stringRedisTemplate.opsForValue();
svo.set("a","b");
System.out.println(svo.get("a"));
4.Hash操作
HashOperations<String,Object,Object> hash=stringRedisTemplate.opsForHash();
hash.put("sean","name","steve yu");
hash.put("sean","age","20");
hash.put("sean","sex","M");
System.out.println(hash.get("sean","name"));;
System.out.println(hash.get("sean","age"));;
System.out.println(hash.get("sean","sex"));;
5.对象操作(这边需要引入Spring Json)
HashOperations<String,Object,Object> hash=stringRedisTemplate.opsForHash();
hash.put("sean","name","steve yu");
hash.put("sean","age","20");
hash.put("sean","sex","M");
System.out.println(hash.get("sean","name"));;
System.out.println(hash.get("sean","age"));;
System.out.println(hash.get("sean","sex"));;
//5.对象转哈希存储操作
Person p=new Person();p.setAge(15);p.setName("steve yu");
Jackson2HashMapper jm = new Jackson2HashMapper(objectMapper, false);
stringRedisTemplate.setHashValueSerializer(new Jackson2JsonRedisSerializer<Object>(Object.class));
stringRedisTemplate.opsForHash().putAll("sean01",jm.toHash(p));
Map<Object, Object> map = stringRedisTemplate.opsForHash().entries("sean01");
System.out.println(map);
Person person = objectMapper.convertValue(map, Person.class);
Redis08-击穿&穿透&雪崩&spring data redis的更多相关文章
- Redis与Spring Data Redis
1.Redis概述 1.1介绍 官网:https://redis.io/ Redis是一个开源的使用ANSIC语言编写.支持网络.可基于内存 亦可持久化的日志型.Key-Value型的高性能数据库. ...
- spring data redis RedisTemplate操作redis相关用法
http://blog.mkfree.com/posts/515835d1975a30cc561dc35d spring-data-redis API:http://docs.spring.io/sp ...
- spring mvc Spring Data Redis RedisTemplate [转]
http://maven.springframework.org/release/org/springframework/data/spring-data-redis/(spring-data包下载) ...
- Spring Data Redis简介以及项目Demo,RedisTemplate和 Serializer详解
一.概念简介: Redis: Redis是一款开源的Key-Value数据库,运行在内存中,由ANSI C编写,详细的信息在Redis官网上面有,因为我自己通过google等各种渠道去学习Redis, ...
- Spring Data Redis—Pub/Sub(附Web项目源码)
一.发布和订阅机制 当一个客户端通过 PUBLISH 命令向订阅者发送信息的时候,我们称这个客户端为发布者(publisher). 而当一个客户端使用 SUBSCRIBE 或者 PSUBSCRIBE ...
- Spring data redis的一个bug
起因 前两天上线了一个新功能,导致线上业务的缓存总是无法更新,报错也是非常奇怪,redis.clients.jedis.exceptions.JedisConnectionException: Unk ...
- Spring Data Redis—Pub/Sub(附Web项目源码) (转)
一.发布和订阅机制 当一个客户端通过 PUBLISH 命令向订阅者发送信息的时候,我们称这个客户端为发布者(publisher). 而当一个客户端使用 SUBSCRIBE 或者 PSUBSCRIBE ...
- spring data redis 理解
前言 Spring Data Redis project,应用了Spring概念来开发使用键值形式的数据存储的解决方案.我们(官方)提供了一个 "template" ,这是一个高级 ...
- Spring Data Redis 详解及实战一文搞定
SDR - Spring Data Redis的简称. Spring Data Redis提供了从Spring应用程序轻松配置和访问Redis的功能.它提供了与商店互动的低级别和高级别抽象,使用户免受 ...
随机推荐
- Linux服务器上安装openoffice,以及安装字体文件
1.安装openoffice (1)将openoffice的linux安装包放到linux指定的文件下(一般放在opt下) (2)在安装包的目录下执行命令:tar -zxvf 对应的压缩包名字 (3) ...
- 双系统删除Linux系统
1.首先解决Linux的grub引导问题.电脑先安装了Windows10,然后又安装了Linux,grub直接覆盖了Windows的引导, 所以每次开机都是进入了Linux的grub引导,现在我们需要 ...
- lamp的动静分离部署
一.lamp分离部署工作图 二.LAMP的安装与配置 1.环境准备 2.对 PHP 服务器进行部署 #以下为安装PHP及其依赖 [root@php ~ ]# .tar.gz -C /usr/src [ ...
- vue-cli@webpack@4打包分析命令
一.命令 npm run build --report 该命令在打包完之后,可以分析包的大小(如下图),从而分析那一块打包太大了可以进行优化处理.
- git pull因为主线分支问题解决
方法1:如果你想保留刚才本地修改的代码,并把git服务器上的代码pull到本地(本地刚才修改的代码将会被暂时封存起来) git stashgit pull origin mastergit stash ...
- Design Snake Game
Design a Snake game that is played on a device with screen size = width x height. Play the game onli ...
- Web在线报表设计器使用指南
市面上的报表工具有很多,虽说功能大同小异,但每一个报表工具都有各自明确的定位,选择最合适的工具,才能达到事半功倍的效果. 本文将要介绍的ActiveReports报表工具,可全面满足 .NET 报表开 ...
- 啃掉Hadoop系列笔记(04)-Hadoop运行模式之伪分布式模式
伪分布式模式等同于完全分布式,只是她只有一个节点. 一) HDFS上运行MapReduce 程序 (1)配置集群 (a)配置:hadoop-env.sh Linux系统中获取jdk的安装路径:
- C#与C++的区别
C# 参考链接:https://www.runoob.com/csharp/csharp-tutorial.html ------------------C#数据类型----------------- ...
- C++多线程基础学习笔记(九)
一.std::atomic续谈 上一章说到std::atomic是针对一个变量的,这里补充一下针对的变量操作一般是++,+=,--,&=等等运算 .以下这种不可取:a=a+1; 二.std:: ...