使用Java操作redis

147 阅读1分钟

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)); } }

image.png

image.png 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); } }

image.png

image.png 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());//既有键也有值
	}
}`
    

image.png

原文移步:马六安