Java教程

spring代理模式实现对已有项目redis操作监控日志

本文主要是介绍spring代理模式实现对已有项目redis操作监控日志,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

最近项目要加监控, 由于当时开发没有很好的去封装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操作日志的功能  

这篇关于spring代理模式实现对已有项目redis操作监控日志的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!