DubboInvoker中
data:image/s3,"s3://crabby-images/56e9d/56e9d85c5f04d4935131065c1975485a6841cc0f" alt=""
中判断是同步还是异步
如是异步时,HeaderExchangeChannel中调用request()
data:image/s3,"s3://crabby-images/d2c64/d2c645408e717085bc4e05a6e3eb36e5417fa5c8" alt=""
new Request()中生成新的请求,每个请求都有一个Id
data:image/s3,"s3://crabby-images/0d086/0d08637525238acc1b0eb6c61cb31bdb8e501e8f" alt=""
对应的Future 存放在Context
FutureFilter中
data:image/s3,"s3://crabby-images/dec84/dec84a1b76ba2616efabbf79a8f76f215a880950" alt=""
data:image/s3,"s3://crabby-images/3cfe1/3cfe1634b5a611df4c5dc884b25dbfc1c194f669" alt=""
等异步收到响应后
data:image/s3,"s3://crabby-images/e68aa/e68aabe6196632d7924b632d47d5e17063819827" alt=""
再调用callback处理
同步
DubboInvoker中
data:image/s3,"s3://crabby-images/46038/46038e9581b8961497269517b95a2553f3f697b2" alt=""
调用get()
data:image/s3,"s3://crabby-images/d10c2/d10c24e6ffcfb0622b6ef6a96ed75fde2135efb0" alt=""
DubboInvoker中
中判断是同步还是异步
如是异步时,HeaderExchangeChannel中调用request()
new Request()中生成新的请求,每个请求都有一个Id
对应的Future 存放在Context
FutureFilter中
等异步收到响应后
再调用callback处理
DubboInvoker中
调用get()
本文标题:Dubbo同步异步调用2
本文链接:https://www.haomeiwen.com/subject/euvzeftx.html
网友评论