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

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: 带你读《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

相关文章
|
2月前
|
Dubbo Java 应用服务中间件
Spring Cloud Dubbo:微服务通信的高效解决方案
【10月更文挑战第15天】随着信息技术的发展,微服务架构成为企业应用开发的主流。Spring Cloud Dubbo结合了Dubbo的高性能RPC和Spring Cloud的生态系统,提供高效、稳定的微服务通信解决方案。它支持多种通信协议,具备服务注册与发现、负载均衡及容错机制,简化了服务调用的复杂性,使开发者能更专注于业务逻辑的实现。
67 2
|
3月前
|
监控 安全 搜索推荐
设置 HTTPS 协议以确保数据传输的安全性
设置 HTTPS 协议以确保数据传输的安全性
|
2月前
|
安全 网络协议 算法
HTTPS网络通信协议揭秘:WEB网站安全的关键技术
HTTPS网络通信协议揭秘:WEB网站安全的关键技术
187 4
HTTPS网络通信协议揭秘:WEB网站安全的关键技术
|
2月前
|
Dubbo Java 应用服务中间件
Dubbo学习圣经:从入门到精通 Dubbo3.0 + SpringCloud Alibaba 微服务基础框架
尼恩团队的15大技术圣经,旨在帮助开发者系统化、体系化地掌握核心技术,提升技术实力,从而在面试和工作中脱颖而出。本文介绍了如何使用Dubbo3.0与Spring Cloud Gateway进行整合,解决传统Dubbo架构缺乏HTTP入口的问题,实现高性能的微服务网关。
|
2月前
|
存储 网络安全 对象存储
缺乏中间证书导致通过HTTPS协议访问OSS异常
【10月更文挑战第4天】缺乏中间证书导致通过HTTPS协议访问OSS异常
109 4
|
3月前
|
安全 网络协议 网络安全
在实现HTTPS时,有哪些常见的安全协议
在实现HTTPS时,有哪些常见的安全协议
138 1
|
2月前
|
安全 应用服务中间件 Shell
网站在后台启用了https协议之后重新登录就不进去后台的解决方法
网站在后台启用了https协议之后重新登录就不进去后台的解决方法
|
2月前
|
SQL Java API
Apache Flink 2.0-preview released
Apache Flink 社区正积极筹备 Flink 2.0 的发布,这是自 Flink 1.0 发布以来的首个重大更新。Flink 2.0 将引入多项激动人心的功能和改进,包括存算分离状态管理、物化表、批作业自适应执行等,同时也包含了一些不兼容的变更。目前提供的预览版旨在让用户提前尝试新功能并收集反馈,但不建议在生产环境中使用。
727 13
Apache Flink 2.0-preview released
|
2月前
|
存储 缓存 算法
分布式锁服务深度解析:以Apache Flink的Checkpointing机制为例
【10月更文挑战第7天】在分布式系统中,多个进程或节点可能需要同时访问和操作共享资源。为了确保数据的一致性和系统的稳定性,我们需要一种机制来协调这些进程或节点的访问,避免并发冲突和竞态条件。分布式锁服务正是为此而生的一种解决方案。它通过在网络环境中实现锁机制,确保同一时间只有一个进程或节点能够访问和操作共享资源。
81 3
|
3月前
|
SQL 消息中间件 关系型数据库
Apache Doris Flink Connector 24.0.0 版本正式发布
该版本新增了对 Flink 1.20 的支持,并支持通过 Arrow Flight SQL 高速读取 Doris 中数据。

热门文章

最新文章

推荐镜像

更多