W3Cschool
恭喜您成為首批注冊用戶
獲得88經驗值獎勵
在 Dubbo 中發(fā)起異步調用
從 2.7.0 開始,Dubbo 的所有異步編程接口開始以 CompletableFuture 為基礎
基于 NIO 的非阻塞實現(xiàn)并行調用,客戶端不需要啟動多線程即可完成并行調用多個遠程服務,相對多線程開銷較小。
需要服務提供者事先定義 CompletableFuture 簽名的服務,具體參見服務端異步執(zhí)行接口定義:
public interface AsyncService {
CompletableFuture<String> sayHello(String name);
}
注意接口的返回類型是? CompletableFuture<String>
?。
XML引用服務:
<dubbo:reference id="asyncService" timeout="10000" interface="com.alibaba.dubbo.samples.async.api.AsyncService"/>
調用遠程服務:
// 調用直接返回CompletableFuture
CompletableFuture<String> future = asyncService.sayHello("async call request");
// 增加回調
future.whenComplete((v, t) -> {
if (t != null) {
t.printStackTrace();
} else {
System.out.println("Response: " + v);
}
});
// 早于結果輸出
System.out.println("Executed before response return.");
在 consumer.xml 中配置:
<dubbo:reference id="asyncService" interface="org.apache.dubbo.samples.governance.api.AsyncService">
<dubbo:method name="sayHello" async="true" />
</dubbo:reference>
調用代碼:
// 此調用會立即返回null
asyncService.sayHello("world");
// 拿到調用的Future引用,當結果返回后,會被通知和設置到此Future
CompletableFuture<String> helloFuture = RpcContext.getContext().getCompletableFuture();
// 為Future添加回調
helloFuture.whenComplete((retValue, exception) -> {
if (exception == null) {
System.out.println(retValue);
} else {
exception.printStackTrace();
}
});
或者,你也可以這樣做異步調用:
CompletableFuture<String> future = RpcContext.getContext().asyncCall(
() -> {
asyncService.sayHello("oneway call request1");
}
);
future.get();
如果你只有這樣的同步服務定義,而又不喜歡 RpcContext 的異步使用方式。
public interface GreetingsService {
String sayHi(String name);
}
那還有一種方式,就是利用 Java 8 提供的 default 接口實現(xiàn),重載一個帶有 CompletableFuture 簽名的方法。
CompletableFuture 簽名的方法目前只支持 Dubbo 協(xié)議,其他協(xié)議由于第三方實現(xiàn)問題,需要視具體情況而定。
有兩種方式來實現(xiàn):
public interface GreetingsService {
String sayHi(String name);
// AsyncSignal is totally optional, you can use any parameter type as long as java allows your to do that.
default CompletableFuture<String> sayHi(String name, AsyncSignal signal) {
return CompletableFuture.completedFuture(sayHi(name));
}
}
你也可以設置是否等待消息發(fā)出(異步總是不等待返回):
sent="true"
? 等待消息發(fā)出,消息發(fā)送失敗將拋出異常。sent="false"
?不等待消息發(fā)出,將消息放入 IO 隊列,即刻返回。<dubbo:method name="findFoo" async="true" sent="true" />
如果你只是想異步,完全忽略返回值,可以配置 ?return="false"
?,以減少 Future 對象的創(chuàng)建和管理成本:
<dubbo:method name="findFoo" async="true" return="false" />
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: