data:image/s3,"s3://crabby-images/c3bac/c3bac200d69f1593eb9841b66c4eb9d7aa4a88b2" alt=""
data:image/s3,"s3://crabby-images/49704/49704b59de9fc5135981db473f5a5b01801d4802" alt=""
缓存
data:image/s3,"s3://crabby-images/026fa/026faaa2d9a916399d71a012386db28b156910c8" alt=""
data:image/s3,"s3://crabby-images/4440f/4440fc3fa6214499c3db56981d831ce949811f27" alt=""
data:image/s3,"s3://crabby-images/146a4/146a4b42b9cf07f5a68c6abc83d0ab2668f94b79" alt=""
缓存 Guava Cache
data:image/s3,"s3://crabby-images/75d63/75d63179351f8ae11e10da0122b20c57d46d5049" alt=""
data:image/s3,"s3://crabby-images/16c04/16c04df4778e64624d2bed51d2551136b7b1e8a5" alt=""
data:image/s3,"s3://crabby-images/be7f6/be7f69c18fa5a3f1a70a3d1d216466c31f31a9f6" alt=""
data:image/s3,"s3://crabby-images/12dd3/12dd3ac9b4d78fc2e81ea40e4d0b734916b298f1" alt=""
-
学习redis网站 redis.cn
-
RedisConfig
package com.alan.concurrency.example.cache;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
@Configuration
public class RedisConfig {
@Bean(name="redisPool")
public JedisPool jedisPool(@Value("${jedis.host}") String host,
@Value("${jedis.port}") int port){
return new JedisPool(host,port);
}
}
- RedisClient
package com.alan.concurrency.example.cache;
import org.springframework.stereotype.Component;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import javax.annotation.Resource;
@Component
public class RedisClient {
@Resource(name="redisPool")
private JedisPool jedisPool;
public void set(String key,String value) throws Exception{
Jedis jedis = null;
try {
jedis = jedisPool.getResource();
jedis.set(key,value);
} finally {
if (jedis != null){
jedis.close();
}
}
}
public String get(String key) throws Exception{
Jedis jedis = null;
try {
jedis = jedisPool.getResource();
return jedis.get(key);
} finally {
if (jedis != null){
jedis.close();
}
}
}
}
- CacheController
package com.alan.concurrency.example.cache;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
@RequestMapping("/cache")
public class CacheController {
@Autowired
private RedisClient redisClient;
@RequestMapping("/set")
@ResponseBody
public String set(@RequestParam("k") String k , @RequestParam("v") String v) throws Exception{
redisClient.set(k,v);
return "SUCCESS";
}
@RequestMapping("/get")
@ResponseBody
public String get(@RequestParam("k") String k) throws Exception{
return redisClient.get(k);
}
}
高并发场景下缓存常见问题
data:image/s3,"s3://crabby-images/c5c8a/c5c8aed2592c070782d01edbd99776a3c4d42a9f" alt=""
data:image/s3,"s3://crabby-images/97b61/97b61699ceae02c9ed3400e3440837ab89ea76c0" alt=""
data:image/s3,"s3://crabby-images/49721/497213d7726db0812ee1462b0545ce3343921f67" alt=""
data:image/s3,"s3://crabby-images/fef5d/fef5d50332a5f218371dbc747df96d055fe1780c" alt=""
网友评论