java – Google Cloud Platform:无法从Container Engine访问Pubsub

我正在尝试从运行在Google容器引擎中的Scala应用程序(即在Kubernetes中运行)发布到现有的pubsub主题.

我已启用(我认为)底层群集的正确权限:

permissions

但是,当我尝试运行我的Scala应用程序时,出现以下错误

2016-12-10T22:22:57.811982246Z Caused by:
com.google.cloud.pubsub.PubSubException: java.lang.IllegalStateException: 
No NameResolverProviders found via ServiceLoader,including for DNS. 
This is probably due to a broken build. If using ProGuard,check your configuration

完整堆栈跟踪here.

我的Scala代码完全符合快速入门指南:

val TopicName = "my-topic"
val pubsub = PubSubOptions.getDefaultInstance.getService
val topic = pubsub.getTopic(TopicName)
...
topic.publish(Message.of(json))

我想我可能会错过一些重要的Kubernetes配置,所以非常感谢任何和所有的帮助.

最佳答案
我发现当sbt管理“com-google-cloud-pubsub”依赖时会出现这个问题.我的工作是,我创建了一个maven项目,并构建了一个只有依赖项的jar.然后我将jar添加到我的classpath和我的build.sbt中,我将“com-google-cloud-pubsub”注释为“提供”.我希望这适合你.

figuration>
                figuration>
            

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...