如何写一个RPC框架(二):利用Bean容器和动态代理简化客户端代码

本文是RPC框架系列的第二篇,探讨如何利用Spring Bean容器和Java动态代理来简化RPC客户端代码。通过创建带有RPCService注解的接口的动态代理,将调用远程服务的复杂逻辑隐藏,使得业务代码更加简洁。文章详细介绍了实现过程,包括获取接口、创建动态代理及注册到Bean容器,并提供了相关代码示例。
摘要由CSDN通过智能技术生成

在后续一段时间里, 我会写一系列文章来讲述如何实现一个RPC框架(我已经实现了一个示例框架, 代码在我的github上)。 这是系列第二篇文章, 主要讲述了如何利用Spring以及Java的动态代理简化调用别的服务的代码。

在本系列第一篇文章中,我们说到了RPC框架需要关注的第一个点,通过创建代理的方式来简化客户端代码。

如果不使用代理?

如果我们不用代理去帮我们操心那些服务寻址、网络通信的问题,我们的代码会怎样?

我们每调用一次远端服务,就要在业务代码中重复一遍那些复杂的逻辑,这肯定是不能接受的!

目标代码

而我们的目标是写出简洁的代码,就像这样:

//这个接口应该被单独打成一个jar包,同时被server和client所依赖
@RPCService(HelloService.class)
public interface HelloService {
   

    String hello(String name);
}

@Component
@Slf4j
public class AnotherService {
   
    @Autowired
    HelloService helloService;

    public void callHelloService() {
        //就像调用本地方法一样自如!
        log.info("Result of callHelloService: {}", helloService.hello("world"));
    }
}

@EnableRPCClients(basePackages = {
  "pw.hshen.hrpc"})
public class HelloClient {
   

    public static void main(String[] args) throws Exception {
        ApplicationContext context = new ClassPathXmlApplicationContext("spring.xml");
        AnotherService anotherService = context.getBean(AnotherService.class);
        anotherService.callHelloService();
    }
}

代码中的AnotherService可以简单调用远端的HelloService的方法,就像调用本地的service一样简单! 在这段代码中,HelloService可以视作server, 而AnotherService则是它的调用者,可以视作是client。

实现思路

1.获取要被创建代理的接口

首先,我们要知道需要为哪些接口来创建代理。

我们需要为这种特殊的接口创建一个注解来标注,即RPCService。然后我们就可以通过扫描某个包下面所有包含这个注解的interface来获取了。

那么,怎么知道要扫描哪个包呢?方法就是获取MainClass的EnableRPCClients注解的basePackages的值。

2.为这些接口创建动态代理

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值