如何在不定义protobuf的情况下进行远程调用?
使用 NodeJS 实现网关层,接收前端的HTTP请求,然后转发到内网进行RPC调用。但是 gRPC 的官方文档和示例的 Client 实现都需要引用 protobuf 文件,例如:grpc.load("/xxxx.protobuf")
但是这样每创建一个微服务,都需要在网关层提交一份 protobuf 定义文件,感觉有点太不灵活了,尤其是涉及到更新、版本管理就更麻烦了。不知道大公司是怎么管理 protobuf 文件的。但是我觉得 JS 作为一个动态语言,本身是不需要借助 protobuf 来确定数据类型的。与 golang 等静态语言对接的时候,我们可以不考虑 RPC 的 Stream 调用,可以约束 protobuf 编写时使用基本数据类型,例如 string,int64,bool等,确保 JS 的数据总是能准确转换到静态语言可用的类型。
所以,如何在不定义 protobuf 的情况下进行远程调用?或者,有没有更好的 protobuf 组织和管理的方案?
昨天通过翻阅文档和源码,写出了如下的代码,但是会报错 RPC method not implemented
import grpc from "grpc;
const client = new grpc.Client("127.0.0.1:3005", grpc.credentials.createInsecure())
client.makeUnaryRequest("GetService",
function serialize(arg) {
return new Buffer(JSON.stringify(arg));
},
function deserialize(argBuf) {
// 未执行到此处
console.log(typeof argBuf);
return argBuf
}, {
name: "test"
},
null,
null,
function () {
// 未执行到此处
console.log(arguments);
}
)
protobuf 定义(省略了一部分)
service Finder {
rpc GetService (GetServiceRequest) returns (GetServiceReply) {}
}
message GetServiceRequest {
string name = 1;
}
message GetServiceReply {
string address = 1;
string port = 2;
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
题主后来有答案了吗?同想实现