redis缓存层实现redission

该博客介绍了一种在调用数据库Mapper层之前增加缓存层的方法,通过实现EntityInterface,使得实体类具备keyId和keyName属性。在获取数据时,首先检查Redis缓存,如果缓存中存在则直接返回,否则从数据库查询并存入缓存。更新和删除操作时,相应地清除缓存。这种设计提高了数据访问速度并减少了数据库压力。

在调用数据库mapper层之前,增加一个缓存层。

先让实体类实现2个key的返回接口

public interface EntityInterface {

  Integer getKeyId();

  String getKeyName();
}

原调用mapper的改为调用这个类

@Service("CacheDecorator")
@Scope("prototype")
public class CacheDecoratorImpl<T extends EntityInterface,U extends EntityMapper> implements CacheDecorator { @Autowired RedisUtil redisUtil; private static final String ID_NAME_CACHE = "_id_name"; @Autowired private U entityMapper; @Override public T getById(Integer id) { if (id == null) { return null; } String metaName = getTClass(); Object keyName = redisUtil.getMapField(metaName + ID_NAME_CACHE, id.toString()); if (keyName != null) { Object obj = redisUtil.getMapField(metaName, keyName.toString()); if (obj != null) { return (T) obj; } } else { EntityInterface Entity = entityMapper.getById(id); if (Entity != null) { redisUtil.getMap(metaName).put(Entity.getKeyName(), Entity); redisUtil.getMap(metaName + ID_NAME_CACHE).put(id.toString(), Entity.getKeyName()); } return (T) Entity; } return null; } @Override public T getByName(String name) { if (name == null) { return null; } String metaName = getTClass(); Object obj = redisUtil.getMapField(metaName, name); if (obj != null) { return (T) obj; } else { EntityInterface e = entityMapper.getByName(name); if (e != null) { redisUtil.getMap(metaName).put(name, e); redisUtil.getMap(metaName + ID_NAME_CACHE).put(e.getKeyId().toString(), e.getKeyName()); } return (T) e; } } @Override public void update(EntityInterface Entity) { entityMapper.update(Entity); String metaName = getTClass(); redisUtil.getMap(metaName).remove(Entity.getKeyName()); redisUtil.getMap(metaName + ID_NAME_CACHE).remove(Entity.getKeyId().toString()); } @Override public void deleteById(Integer id) { entityMapper.deleteById(id); String metaName = getTClass(); redisUtil.getMap(metaName + ID_NAME_CACHE).remove(id.toString()); } @Override public void deleteByName(String name) { entityMapper.deleteByName(name); String metaName = getTClass(); redisUtil.getMap(metaName).remove(name); } @Override public void invalidate(String name) { String metaName = getTClass(); redisUtil.getMap(metaName).remove(name); } @Override public void invalidate(Integer id) { String metaName = getTClass(); redisUtil.getMap(metaName + ID_NAME_CACHE).remove(id.toString()); } public String getTClass() { String name = ""; try { InvocationHandler h = Proxy.getInvocationHandler(entityMapper); Field f = h.getClass().getDeclaredField("mapperInterface"); f.setAccessible(true); name = f.get(h).toString(); } catch (Exception e) { } return name; }

 自定义注入方式

@Component
public class CacheDecoratorConfig {

  CacheDecorator<JobMeta, JobMetaMapper> jobCacheDecorator;

  CacheDecoratorConfig(CacheDecorator<JobMeta, JobMetaMapper> jobCacheDecorator) {
    cacheDecorator.setMapper(indicatorMetaMapper);
    this.jobCacheDecorator = jobCacheDecorator;
  }

  @Bean("jobCacheDecorator")
  public CacheDecorator<JobMeta, JobMetaMapper> getJobCacheDecorator() {
    return jobCacheDecorator;
  }
}

实际使用方原写法:

@Autowired
AMapper aMapper;

现在改为:


@Resource
CacheDecorator<AMeta, AMapper> jobCacheDecorator;

调用时原写法:

aMapper.getById(id);

现在改为:

jobCacheDecorator.getById(id);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lxr1908

用钱砸我

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值