该部分引入了redis缓存。
为什么要使用redis缓存,我们不是已经添加了ehcache缓存吗?
首先redis缓存相比于ehcache具有一定优势:
- 集群环境下,那么每台服务器的ehcache是不同步的,这样会出问题的,ehcache只适合单机环境
- redis是设置单独的缓存服务器,所有集群服务器统一访问redis,不会出现缓存不同步的情况,也就是redis缓存是共享的
- 并且redis的效率更高
由于不想删除ehcache缓存,我直接在ehcache上添加了一层redis缓存,最终为redis+ehcache,当然这样并不如直接使用redis效率高
本部分,我们将商品和商品详情信息都添加到了redis缓存,在所有需要查询商品和详情的地方都进行了优化。比如主页homepage和订单页
十三、redis缓存
在linux中安装redis
1.redis命令
cd redis-3.2.11/src //进入到redis目录
./redis-server //启动redis
./redis-cli shutdown //关闭redis
./redis-cli //启动客户端
2.redis配置
我们需要配置redis.conf文件
因为redis默认只能本地访问,访问的地址为127.0.0.1,所以我们需要将绑定的地址注释,并且将保护模式关闭
3.redis缓存的实现步骤:
- 缓存是在service层进行的,在web层调用的
- 我们只需要将原来没有缓存的serviceimpl修改成含有缓存的serviceimpl就行了
- 我们在web层中调用的service如果是含有缓存的service方法就会先查询缓存里是否包含该数据,如果redis缓存包含该数据,就直接返回;如果redis不包含该缓存,就去cache缓存查询,如果cache不包含,才从数据库查询。
13.2 实现过程
1.配置pom引入redis和spring和dubbo相关包
2.实现要使用redis服务的service接口和接口的实现类
- 该接口实现类下面需要自动注入RedisUtil ,获取redis容器
public class MsproductRedisServiceImpl implements MsproductRedisService{
@Autowired
private MsproductCacheService msproductCacheService;
@Autowired
private RedisUtil redisUtil;
/**
* 根据秒杀商品id查询秒杀商品
* @param msproductinfo
*/
public Msproductinfo querymsproductByid(int id){
Msproductinfo msproductinfo = null;
Object value = redisUtil.get("product:"+id);
if(value == null){
msproductinfo = msproductCacheService.querymsproductByid(id);
redisUtil.set("product:"+id, msproductinfo);
}else{
System.out.println("come into redis -- querymsproductByid");
msproductinfo = (Msproductinfo)value;
}
return msproductinfo;
}
}
3.配置redis项目,包括redis配置和dubbo配置
redis配置:
application-context-redis.xml
<!-- 加载配置文件 -->
<context:property-placeholder location="classpath:*.properties" />
<!-- redis连接池配置-->
<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig" >
<!--最大空闲数-->
<property name="maxIdle" value="${redis.maxIdle}"