Daprd 流式改造

Daprd
protobuf 接口:

//dapr.proto
service Dapr {
  rpc InvokeStreamService(stream InvokeServiceRequest) returns (stream common.v1.InvokeResponse) {}
}

//service_invocation.proto
service ServiceInvocation {
	rpc StreamCallLocal (stream InternalInvokeRequest) returns (stream InternalInvokeResponse) {}
}

//appcallback.proto
service AppCallback {
	rpc OnStreamInvoke (stream common.v1.InvokeRequest) returns (stream common.v1.InvokeResponse) {}
}

在 dapr 代码库下执行 make init-proto、make gen-proto 生成修改后的 grpc go 语言接口文件

Server 端:
daprd 里有两个 grpc server:
○GRPCAPIServer:面向同一个 pod 里的用户容器通信
○GRPCInternalServer:daprd sidecar 之间进行的通信

需要在两个 server 里增加流式方法的实现
○GRPCAPIServer:InvokeStreamService 方法对 client 暴露流式入参调用
○GRPCInternalServer:StreamCallLocal 方法在 sidecar 里接收其他 sidecar 发送的数据流

Client 端:
AppCallback 增加 OnStreamInvoke 方法,在 GRPCInternalServer 收到流消息的 StreamCallLocal 方法里转发调用 OnStreamInvoke。


构建 daprd 镜像:
●在 dapr 代码库下执行 make build-linux 生成二进制文件
●执行 

make docker-build DAPR_REGISTRY=xxx RELEASE_NAME=dapr DAPR_TAG=v0 TARGET_OS=linux TARGET_ARCH=amd64

生成镜像

tips:如构建镜像时下载基础 alpine 镜像超时,可在 docker/Dockerfile 里加入一行 RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.ustc.edu.cn/g' /etc/apk/repositories 换国内源。

修改 dapr 自动注入的镜像:
编辑 asi_zjk_pai_b 集群 deployment.apps/dapr-sidecar-injector,修改 SIDECAR_IMAGE 这个环境变量的值为上一步构建后的 daprd 镜像地址。

Java client
对 dapr-sdk 的依赖改为源码依赖,dapr.proto 增加流式接口定义,生成新的 java grpc 接口文件

//dapr.proto
service Dapr {
  rpc InvokeStreamService(stream InvokeServiceRequest) returns (stream common.v1.InvokeResponse) {}
}

●DaprClient 增加流式调用接口 invokeStreamMethod
●DaprClientGrpc 实现该接口,调用 grpc 接口文件的 invokeStreamService 方法;DaprClientHttp 为空实现。
●目前修改代码后方便调试是源码依赖,后续可改为二方包形式。

C++ Server
appcallback.proto 增加流式接口定义,生成新的 c++ grpc 接口文件

//appcallback.proto
service AppCallback {
	rpc OnStreamInvoke (stream common.v1.InvokeRequest) returns (stream common.v1.InvokeResponse) {}
}


●dapr_server 增加流式接口实现 OnStreamInvoke
●edge_operator 在 grpc stream 的基础上增加对 dapr stream 的处理
●重新编译后构建 aquila 基础镜像
 

参考

Dapr 源码解析 | 服务间调用 :: Cong

dapr仓库的源码学习 | Dapr学习笔记

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值