C/C++教程

【手写dubbo-5】rpc调用异步转同步

本文主要是介绍【手写dubbo-5】rpc调用异步转同步,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

        一般情况下每个service的调用的过程都是同步的,例如在一个service中通过RestTemplate调用一个接口,这样也可以认为是一个远程调用,这种是同步进行的,整个调用的思路如下图。调用线程只需要等待调用结果,并且返回即可。这是一种简单的调用方式。

image-20210512181243977

        但是,在使用netty时,整个调用过程是一个异步的过程,上图那种思路就无法达到预期效果。整个调用过程如下图。结果响应之后,selector不知道将结果交给哪个线程处理。

image-20210512183219800

        解决这种异步转同步的过程比较复杂。因此为了使得之前的内容更好理解,并不曾说明此问题。只是在代码中傻傻的写了两行,休眠,然后等待其结果返回。

 //等待其返回
Thread.sleep (1000L);
Object result 
这篇关于【手写dubbo-5】rpc调用异步转同步的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!