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 基础镜像