详解Proxy代理模式的场景分析

代理模式是一个十分优秀的软件架构模式,许多应用都用到了代理模式。代理模式就是为其他对象提供一种代理以控制对这个对象的访问。在某些情况下,一个对象不合适或者不能直接引用另一个对象,而代理对象可以在客户端和目标对象之间起到中介的作用。

这次主要讲解一下代理模式的实例,解决的问题部分。

在java的框架中有一种框架就用到了动态代理模式,弹簧框架中的AOP技术,基于代理模式。下面我将以beforeAdvice来进行这个模式的介绍。

详解Proxy代理模式的场景分析_第1张图片
图片

这张图反映了参与到AOP过程中的几个关键组件(以@Before建议为例):

  1. 调用者Beans - 即调用发起者,它只知道目标方法所在Bean,并不清楚代理以及Advice的存在
  2. 目标方法所在Bean - 被调用的目标方法
  3. 生成的代理 - 由Spring AOP为目标方法所在Bean生成的一个代理对象
  4. 建议 - 切面的执行逻辑

它们之间的调用先后次序反映在上图的序号中:

  1. 调用者豆尝试调用目标方法,但是被生成的代理截了胡
  2. 代理根据建议的种类(本例中是@Before Advice),对建议首先进行调用
  3. 代理调用目标方法
  4. 返回调用结果给调用者豆(由代理返回,没有体现在图中)

在使用Spring AOP的时候可能遇到的一个问题。类似这种间接调用不会触发建议的原因在于调用发生在目标方法所在Bean的内部,和外面的代理对象可以没有半毛钱的关系哦。我们可以把这个代理想象成一个中介,只有它知道咨询的存在,调用者豆和目标方法所在豆知道彼此的存在,但是对于代理或者是忠告却是一无所知的。因此,没有通过代理的调用是绝无可能触发建议的逻辑的。

代理模式的应用场景还有延迟加载场景,延迟加载的思想:如果当前没有使用这个组件时,则不需要真正地去初始化它,而是用一个代理对象去替代它的原有位置当真正需要使用的时候,才对它进行加载使用代理模式实现延迟加载是很有意义的,首先从时间轴上分散系统的压力,尤其在系统启动时,不必完成所有的初始化工作,从而加速启动时间。其次,对于很多真事主题而言,在软件启动到系统关闭的整个过程,可能都不会被调用,初始化这些数据无疑是一种资源的浪费。

假设某客户端软件,根据用户请求,去数据库查询数据的功能。在数据库查询前需要获得数据库连接。在系统启动时,初始化系统所有的类,此时尝试获得数据库连接。当系统存在大量类似的操作时(XML解析等),所有这些初始化操作都必须叠加,使得系统很慢。为此,使用代理模式,使用代理类,封装对数据库的查询操作。当系统启动时,初始化这个代理类,而非真实的数据库查询类,而代理类什么都不做。当真正开始查询的时候,才初始化查询对象。

代理模式的应用场景主要还是分为4类:

远程代理:为一个对象在不同地址空间提供局部代表这样可以隐藏一个对象存在于不同地址空间的事实,例如:老阮(MrRuan)在地点A,老李在地点B,餐厅柜台也在地点乙,那么老李和老软住在一起(都在地点甲住),那么老李就是餐厅(地点B)在老软与老李住处(地点A)的代表。

   虚拟代理:是根据需要创建开销很大的对象。通过它来存放实例化需要很长时间的真是对象,例如:老阮(MrRuan)在地点A,到餐厅柜台(地点B),因为距离远却是很费劲,而老李刚好在这里(地点B)上班,所以让老李去办是很可行的办法。(不太恰当)

   安全代理:用来控制真是对象访问时的权限,例如:老阮跟餐厅的柜台MM刚分手不方便去办理,所以需要借助老李去完成事项的办理。

   智能代理:是指当调用真是的对象时,代理去处理另外一些事情,例如:老李帮助老阮办理卡片激活时,顺便说说老阮的好话,让她俩能够和好。

WebService的也是应用到了代理模式,我们来看一下web服务的示例过程:

详解Proxy代理模式的场景分析_第2张图片
图片

实现一个完整的网络服务包括以下步骤:

◆Web服务提供者设计实现Web服务,并将调试正确后的Web服务通过Web服务中介者发布,并在UDDI注册中心注册;(发布)

◆Web服务请求者向Web服务中介者请求特定的服务,中介者根据请求查询UDDI注册中心,为请求者寻找满足请求的服务;(发现)

◆Web服务中介者向Web服务请求者返回满足条件的Web服务描述信息,该描述信息用WSDL写成,各种支持Web服务的机器都能阅读;(发现)

◆利用从Web服务中介者返回的描述信息生成相应的SOAP消息,发送给Web服务提供者,以实现Web服务的调用;(绑定)

◆Web服务提供者按SOAP消息执行相应的Web服务,并将服务结果返回给Web服务请求者。(绑定)

总之,许多都应用到了代理模式,在使用的时候认真查看原理,对代理模式加深自己的理解。

Java的的架构师学习公众号!

一个专注分享架构干货的微信公众号


你可能感兴趣的:(java,程序员,架构,互联网)