1.缓存穿透
客户端发起请求时 缓存中没有 数据库也没有
2.缓存击穿
缓存中的数据过期时,多个请求同时进入缓存,由于数据过期,于是请求直接访问到数据库
3.缓存雪崩
①aof将缓存的数据存到本地硬盘,如果本地内存满了,同时硬盘坏掉了,那么造成缓存雪崩
②某一时间大量的数据进入缓存
③某一时间大量的数据进入缓存,设置了过期时间,过期了之后又会有大量数据进入数据库
4.服务预热
提前将数据放入redis中
一、建立maven项目
pom.xml中导入redis依赖
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.9.0</version>
</dependency>
二、连接port
@Test
void test() {
Jedis jedis=new Jedis("192.168.95.110", 6379);
/*jedis.auth("123456");*/
System.out.println(jedis.ping());
}
控制台输出pong算成功
hash测试
public void testHash() {
j.hset("user", "name", "马六安");
j.hset("user", "sex", "男");
Map<String, String> hgetAll = j.hgetAll("user");
for (String a : hgetAll.keySet()) {
System.out.println(a+"----"+hgetAll.get(a));
}
}
list测试
@Test
public void testList() {
// j.lpush("num", "1","2","3");
List<String> lrange = j.lrange("num", 0, -1);
for (String a : lrange) {
System.out.println(a);
}
}
zset测试
@Test
public void testZset() {
j.zadd("top", 1111,"aaa");
j.zadd("top", 3333,"bbb");
j.zadd("top", 2222,"ccc");
Set<String> set = j.zrange("top", 0, 1);//从小到大
for (String s : set) {
System.out.println(s);
}
Set<String> set1 = j.zrevrange("top", 0, 2);//reverse反转 从大到小
set1.forEach(System.out::println);
Set<Tuple> set2 = j.zrangeWithScores("top", 0, 2);
for (Tuple t : set2) {
System.out.println(t.getScore()+"--"+t.getElement());//既有键也有值
}
}