通过在 application.properties 文件中指定文件位置来传递服务帐户密钥文件(从 GCP 控制台生成),这似乎很简单。但是,我尝试了以下所有选项:
1. spring.cloud.gcp.credentials.location=file:/home/my_user_id/mp6key.json
2. spring.cloud.gcp.credentials.location=file:src/main/resources/mp6key.json
3. spring.cloud.gcp.credentials.location=file:./main/resources/mp6key.json
4. spring.cloud.gcp.credentials.location=file:/src/main/resources/mp6key.json
Run Code Online (Sandbox Code Playgroud)
这一切都以同样的错误结束:
java.io.FileNotFoundException: /home/my_user_id/mp6key.json (No such file or directory)
Run Code Online (Sandbox Code Playgroud)
谁能建议我应该将密钥文件放在哪里,然后我应该如何正确指定文件的路径?
相同的程序在 Ecplise 中成功运行,并使用 GCP 的 Pub/Sub 处理(使用 GCP 中生成的项目 ID/服务帐户密钥)发布和订阅消息,但在部署到 GCP 上运行后,现在仍然遇到上述问题。
我正在尝试构建 2 个微服务(在 Java Spring Boot 中)以使用 GCP Pub/Sub 相互通信。
首先,我测试了程序(在 Eclipse 中)在我的本地笔记本电脑( http://localhost )中按预期工作,即一个微服务发布了消息,另一个微服务使用在 GCP 中创建的主题/订阅者(以及凭证私钥:mypubsub.json)。
然后,我部署了相同的程序来运行 GCP,但出现以下错误:
- 2020-03-21 15:53:16.831 WARN 1 --- [bsub-publisher2] o.s.c.g.p.c.p.PubSubPublisherTemplate : Publishing to json-payload-sample-topic topic failed
- com.google.api.gax.rpc.PermissionDeniedException: io.grpc.StatusRuntimeException: PERMISSION_DENIED: Request had insufficient authentication scopes. at com.google.api.gax.rpc.ApiExceptionFactory
Run Code Online (Sandbox Code Playgroud)
我做了什么来部署程序(在容器中)以在 GCP/Kubernetes Engine 上运行:
一旦部署并公开这两个微服务,当我尝试在浏览器中访问它们时,发布消息的微服务可以很好地从数据库检索数据并处理数据,然后在尝试访问 GCP Pubsub API …
publish-subscribe google-cloud-platform google-kubernetes-engine