首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >聊聊在AOP模式下的缓存方案

聊聊在AOP模式下的缓存方案

作者头像
Java_老男孩
发布2019-12-02 16:34:17
6580
发布2019-12-02 16:34:17
举报

面向方法的数据集缓存

使用了autofac做为ioc容器,使用Autofac.Extras.DynamicProxy2作为方法拦截器,缓存面向方法,直接在方法上添加CachingAttribute特性即可。

缓存注册流程
  1. 关于方法拦截器
  2. 缓存名称设计
  3. 添加ioc
  4. 添加拦截器与接口的绑定
  5. 在对应的接口实现类里,为方法添加CachingAttribute
  6. 缓存get,remove的作用
关于方法拦截器

方法拦截器是AOP面向方面编程的一个重要体现,将我们的功能点设计出现,与现有系统解耦,然后注入到项目里,哪些地方需要这个功能,就在哪个地方注入它。

AOP是以IOC容器为基础的,所以你的拦截器组件也需要提前被注入到ioc�容器里,并且,现在不论是java还是.net,都提倡统一管理对象,而不是用new来生产对象,这一点也是面向接口编程的一种体现,而你在业务层进行对象传递时,永远依赖的是抽象,而不会依赖具体的实现!

缓存名称设计

名称由key和value组成

  • key:项目名+对象名+缓存名称(CachingAttribute.key)
  • value:缓存方法的参数名+参数值的组合 例如下面的缓存方法代码
[Caching(CachingMethod.Get, value = "time")]
 DateTime GetTime(int id);

当调用为GetTime(1)时,产生的缓存key值如下:

key="DataSetCache_IUserInfoService_time"
value="id_1"
添加ioc
builder.RegisterType<CachingBehavior>();
            builder.RegisterType<DefaultUserInfoService>()
                   .As<IUserInfoService>()
                   .InstancePerLifetimeScope()
                   .InterceptedBy(typeof(CachingBehavior))
                   .EnableInterfaceInterceptors();
添加拦截器与接口的绑定
 // 下面两句表示将CachingBehavior拦截器绑定到接口上
 .InterceptedBy(typeof(CachingBehavior))
 .EnableInterfaceInterceptors();
在方法上添加CachingAttribute特性
[Caching(CachingMethod.Get,value="time")]
DateTime GetTime();

我们可以在接口的方法上添加这个特性,也可以在接口的实现类的方法上添加这个特性,根据缓存的影响程度去添加。如果缓存对接口所有实现都启作用,就放在接口方法上,反之放在类的方法上。

缓存get,remove的作用
  1. get:一般作用在带有返回值的方法上,缓存名称为项目名+类名+value,当缓存存在时,直接返回,当不存在时,执行方法后,把返回值存入缓存,再返回。
  2. remove:删除某个缓存,它直接把缓存名称value作为remove的参数注入。
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 面向方法的数据集缓存
    • 缓存注册流程
      • 关于方法拦截器
        • 缓存名称设计
          • 添加ioc
        • 添加拦截器与接口的绑定
          • 在方法上添加CachingAttribute特性
            • 缓存get,remove的作用
            相关产品与服务
            容器服务
            腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档