最近项目要加监控, 由于当时开发没有很好的去封装stringRedisTemplate操作接口。所以业务代码直接使用stringRedisTempate.set() 的等操作redis了, 没有做到很好的分层。
然后想了三种方法实现解耦方式的加redis日志:
1 首先, 最简单的方法是加一层代理层, stringRedisTemplateProxy 实现业务层的所有模板操作方法。如 set, get ,setNX, expire等操作 ,然后业务层 使用stringRedisTemplateProxy 代替之前的redistempate模板方法, 然后aop切面来切stringRedisTemplateProxy为业务点,环绕通知从而实现redis操作日志。
2 第二种方法: 可以在bean初始化后, 实现beanPostProcesser接口 从而实现redisbeanFactory动态代理工厂方法, 使用方法引用为通知,当具体操作redistemplate方法时, 在给LettRedisConnection = redisFactory.getConnection() 实现动态代理, 然后 ,过滤isPlp ,close,等方法, 拦截set, get等方法 从而实现加redis 操作日志
3 第三种, 和第二种类似, 首先,给redistemplate 加aop切面拦截, 然后由于 操作opsValueOpertion.是在template内部new出来的无法实现代理, 所以 要重新创建代理。在切面中拦截到redistempte方法 如果是opsvalueOpertion对象,则在给对象创建代理类, 加advios加通知,从而实现加reids操作日志的功能