node.js - 两个内部 Cloud Run node.js 微服务如何通过 gRPC 成功通信?
问题描述
Google Cloud Run 的新手,尝试让两个 node.js 微服务通过 gRPC 进行内部通信。
客户端界面:
constructor(address: string, credentials: grpc.ChannelCredentials, options?: object);
客户端代码:
const client: MyClient = new MyClient('my-service-abcdefgh3a-ew.a.run.app:443', grpc.credentials.createSsl());
服务器代码:
const server = new grpc.Server();
server.addService<IMyServer>(MyService, new MyServer());
server.bind(`0.0.0.0:${process.env.PORT}`, grpc.ServerCredentials.createInsecure());
server.start();
服务器设置为监听 443。
当服务对公共请求开放时,上述方法似乎有效,但当您将服务器设置为内部时无效。有任何想法吗?
解决方案
您必须在请求元数据中添加凭据。这里有一个例子
...
// Create a client for the protobuf spec
const client = new protoObj.Greeter(HOST, grpc.credentials.createInsecure());
// Build gRPC request
const metadata = new grpc.Metadata();
metadata.add('authorization', `Bearer ${JWT_AUTH_TOKEN}`);
// Execute gRPC request
client.sayHello({name: GREETEE}, metadata, (err, response) => {...
第二个问题,如何获取 JWT_AUTH_TOKEN。这里有 Cloud Run 的文档来执行此操作。但不完全,简单的获取token,在请求的元数据中使用
...
request(tokenRequestOptions)
.then((token) => {
// add the token to the metadata
});
// Make the call
...
推荐阅读
- angular - 收到 IPC 消息时视图不刷新
- javascript - 如何通过 LInkedin 分享信息
- node.js - 使用证书、私钥和 CA 的 AWS Lambda NodeJS 请求
- node.js - 添加猫鼬后如何修复nodemon应用程序崩溃
- typescript - 一个非常简单的打字稿项目的Webpack错误
- amazon-s3 - 转义 Presto 中的所有特殊字符
- java - IFileStore 无法从带有重音字符的路径中读取 Eclipse RCP
- mysql - 无法在mysql中的单个查询中更新和选择
- python - 当变量在python的if-condition中定义时,如何在if-condition之后访问变量
- java - 如何在java中模拟时间戳和日期函数?