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 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());//既有键也有值
}
}`
原文移步:马六安