带你读《Apache Dubbo微服务开发从入门到精通》——三、 迁移到 HTTP/2 协议(3)

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
任务调度 XXL-JOB 版免费试用,400 元额度,开发版规格
性能测试 PTS,5000VUM额度
简介: 带你读《Apache Dubbo微服务开发从入门到精通》——三、 迁移到 HTTP/2 协议(3)

《Apache Dubbo微服务开发从入门到精通》——迁移到 Dubbo3——三、 迁移到 HTTP/2 协议(2): https://developer.aliyun.com/article/1223559


4) 开启 Triple 新特性——Stream(流)


Stream Dubbo3 新提供的一调用类型,在以下场景时建议使用流的方式

需要量数据,这些数据在一RPC 应中,需要分应用按照传统的多次 RPC 方式和性能的问题,如需要保有序,则行发

流式场景,数据需要按照理,数据本有确定边界的。

场景,多个在同一调用的上下文中被发理。


Stream 分为以下三:

SERVER_STREAM(服务端流)

image.pngimage.png

CLIENT_STREAM户端流)

image.png

BIDIRECTIONAL_STREAM双向流)

image.png

注:

java 语言的限制,BIDIRECTIONAL_STREAM CLIENT_STREAM 的实现是一样的。


Dubbo3 中,流式SteamObserver 和使用,用户可以通过使用和实现这个接理流的数据、异结束


注:

对于 Dubbo2 用户,可能会对 StreamObserver 生,Dubbo3 定义的一类型Dubbo2 并不Stream 类型对于迁移场景有任何影响


流的语义保

提供边界,可以方便地

有序,发端的

工,发不需要等待

支持取


a) 非 PB 序列化的流


apimage.png

注:

Stream 的方入参和返回的,为错而,Dubbo3框架了对参数的检查,如出错


对于双向流(BIDIRECTIONAL_STREAM),需要注意参数中的StreamObserver 是响应流,返回参数中的 StreamObserver 求流。


实现

public class WrapGreeterImpl implements WrapGreeter {
 //...
 @Override
 public StreamObserver<String> 
sayHelloStream(StreamObserver<String> response) {
 return new StreamObserver<String>() {
 @Override
 public void onNext(String data) {
 System.out.println(data);
 response.onNext("hello,"+data);
 @Override
 public void onError(Throwable throwable) {
 throwable.printStackTrace();
 }
 @Override
 public void onCompleted() {
 System.out.println("onCompleted");
 response.onCompleted();
 }
 };
 }
 @Override
 public void sayHelloServerStream(String request, 
StreamObserver<String> response) {
 for (int i = 0; i < 10; i++) {
 response.onNext("hello," + request);
 }
 response.onCompleted();
 }
}

调用方式

delegate.sayHelloServerStream("server stream", new 
StreamObserver<String>() {
 @Override
 public void onNext(String data) {
 System.out.println(data);
 }
 @Override
 public void onError(Throwable throwable) {
 throwable.printStackTrace();
 }
 @Override
 public void onCompleted() {
 System.out.println("onCompleted");
 }
});
StreamObserver<String> request = delegate.sayHelloStream(new 
StreamObserver<String>() {
 @Override
 public void onNext(String data) {
 System.out.println(data);
 }
 @Override
 public void onError(Throwable throwable) {
 throwable.printStackTrace();
 }
 @Override
 public void onCompleted() {
 System.out.println("onCompleted");
 }
});
for (int i = 0; i < n; i++) {
 request.onNext("stream request" + i);
}
request.onCompleted();


《Apache Dubbo微服务开发从入门到精通》——迁移到 Dubbo3——三、 迁移到 HTTP/2 协议(4) https://developer.aliyun.com/article/1223556

相关文章
|
5天前
|
缓存 安全 数据处理
Objective-C开发:从HTTP请求到文件存储的实战
Objective-C开发:从HTTP请求到文件存储的实战
|
1月前
|
网络协议 网络安全 数据安全/隐私保护
HTTP 协议浅析
通过对HTTP协议的深入了解,开发者可以更好地设计和优化Web应用,提高数据传输效率和用户体验。
114 21
|
2月前
|
缓存 网络协议 前端开发
Web 性能优化|了解 HTTP 协议后才能理解的预加载
本文旨在探讨和分享多种预加载技术及其在提升网站性能、优化用户体验方面的应用。
Web 性能优化|了解 HTTP 协议后才能理解的预加载
|
2月前
|
XML JSON 前端开发
HTTP协议,Content-Type格式介绍篇
通过理解和正确使用Content-Type头字段,可以确保数据在网络上传输时的正确性和高效性,提升网络应用的可靠性和用户体验。
246 25
|
2月前
|
XML JSON 前端开发
HTTP协议,Content-Type格式介绍篇
通过理解和正确使用Content-Type头字段,可以确保数据在网络上传输时的正确性和高效性,提升网络应用的可靠性和用户体验
140 28
|
2月前
|
XML JSON 前端开发
HTTP协议,Content-Type格式介绍篇
通过理解和正确使用Content-Type头字段,可以确保数据在网络上传输时的正确性和高效性,提升网络应用的可靠性和用户体验。
296 18
|
3月前
|
前端开发 网络协议 安全
【网络原理】——HTTP协议、fiddler抓包
HTTP超文本传输,HTML,fiddler抓包,URL,urlencode,HTTP首行方法,GET方法,POST方法
|
3月前
|
缓存 网络协议 算法
从零开始掌握HTTP协议
本文介绍HTTP协议的演变,从HTTP1.0到HTTP2.0。HTTP1.0为无状态连接,每次请求独立;HTTP1.1引入持久连接、管道化请求和更多状态码;HTTP2.0采用二进制分帧、多路复用、头部压缩及服务器主动推送,大幅提升性能与用户体验。了解这些区别有助于开发者优化应用和服务。
|
3月前
|
域名解析 缓存 网络协议
Web基础与HTTP协议
通过掌握这些基础知识和技术,开发者可以更加高效地构建和优化Web应用,提供更好的用户体验和系统性能。
98 15
|
4月前
|
Dubbo 安全 应用服务中间件
Apache Dubbo 正式发布 HTTP/3 版本 RPC 协议,弱网效率提升 6 倍
在 Apache Dubbo 3.3.0 版本之后,官方推出了全新升级的 Triple X 协议,全面支持 HTTP/1、HTTP/2 和 HTTP/3 协议。本文将围绕 Triple 协议对 HTTP/3 的支持进行详细阐述,包括其设计目标、实际应用案例、性能测试结果以及源码架构分析等内容。
305 10

推荐镜像

更多