设计模式-代理模式

代理模式

代理模式,为其他对象提供一种代理以控制对这个对象的访问。

在一些开源框架或中间件产品中,代理模式会非常常见。使用的时候越简便,框架在背后做的事就可能越复杂。这里面往往都体现着代理模式的应用,颇有移花接木的味道。

1、Dubbo

Dubbo作为一个RPC框架,其中有一个很重要的功能就是:

提供高性能的基于代理的远程调用能力,服务以接口为粒度,为开发者屏蔽远程调用底层细节。

这里我们关注两个重点:

  • 面向接口代理;
  • 屏蔽调用底层细节。

比如有一个库存服务,它提供一个扣减库存的接口。

复制代码
public interface StorageDubboService {
    int decreaseStorage(StorageDTO storage);
}

在别的服务里,需要扣减库存的时候,就会通过Dubbo引用这个接口,也比较简单。

复制代码
@Reference
StorageDubboService storageDubboService;

使用起来很简单,可StorageDubboService只是一个普通的服务类,并不具备远程调用的能力。

Dubbo就是给这些服务类,创建了代理类。通过ReferenceBean来创建并返回一个代理对象。

复制代码
public class ReferenceBean<T>{
    @Override
    public Object getObject() {
        return get();
    }
    public synchronized T get() {
        if (ref == null) {
            init();
        }
        return ref;
    }
}

在使用的时候,实则调用的是代理对象,代理对象完成复杂的远程调用。比如连接注册中心、负载均衡、集群容错、连接服务器发送消息等功能。

2、MyBatis

还有一个典型的应用,就是经常在用的MyBatis。在使用的时候,一般只操作Mapper接口,然后MyBatis会找到对应的SQL语句来执行。

复制代码
public interface UserMapper {   
    List<User> getUserList();
}

如上代码,UserMapper也只是一个普通的接口,它是怎样最终执行到SQL语句的呢?

答案也是代理。当MyBatis扫描到定义的Mapper接口时,会将其设置为MapperFactoryBean,并创建返回一个代理对象。

复制代码
protected T newInstance(SqlSession sqlSession) {
    final MapperProxy<T> mapperProxy = new MapperProxy<>(sqlSession, mapperInterface, methodCache);
    return (T) Proxy.newProxyInstance(mapperInterface.getClassLoader(), new Class[] { mapperInterface }, mapperProxy);
}

代理对象去通过请求的方法名找到MappedStatement对象,调用执行器,解析SqlSource对象来生成SQL,执行并解析返回结果等。

相关推荐
NGC_661117 小时前
静态代理和动态代理
代理模式
不光头强19 小时前
代理模式实现,静态,动态
代理模式
逆境不可逃20 小时前
【从零入门23种设计模式12】结构型之代理模式(Spring AOP + 自定义注解 + 切面的实战)
设计模式·代理模式
一碗烈酒1 天前
【使用Python临时搭建代理转发服务,内网穿透】
python·测试工具·代理模式
tsyjjOvO1 天前
代理模式详解:静态代理、JDK 动态代理、CGLIB 动态代理
java·开发语言·代理模式
柒.梧.16 天前
Java代理模式精讲:静态代理+JDK动态代理
java·开发语言·代理模式
Forget_855017 天前
RHEL——HAProxy模式
代理模式
mjhcsp20 天前
C++ 树形 DP解析
开发语言·c++·动态规划·代理模式
不想看见40420 天前
House Robber 基本动态规划:一维--力扣101算法题解笔记
笔记·算法·leetcode·代理模式
忘梓.22 天前
解锁动态规划的奥秘:从零到精通的创新思维解析(10)
c++·算法·动态规划·代理模式