我对GRPC相当陌生,而Java GRPC是我的工作目标。 我有一个GRPC服务器在使用基于X.509的证书/密钥保护的Envoy负载均衡器后成功运行。现在,在为相同客户端创建客户端时遇到了问题。
Maven存储库建议可用的最新io.grpc版本为1.17.1,Github上针对GRPC提到的示例为1.19.0-SNAPSHOT或1.17.3-SNAPSHOT。
我确实复制了整个仓库,并在运行客户端(TLS)示例以及我自己的代码时遇到问题的本地开发环境中构建/安装代码。
我的pom是
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<grpc.version>1.19.0-SNAPSHOT</grpc.version><!-- CURRENT_GRPC_VERSION -->
<protoc.version>3.5.1-1</protoc.version>
<netty.tcnative.version>2.0.20.Final</netty.tcnative.version>
<!-- required for jdk9 -->
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
我得到的错误与protoc-gen-grpc-java有关,
io.grpc:protoc-gen-grpc-java:exe:linux-x86_64:1.19.0-SNAPSHOT
我已经按照他们的git页面使用skipcodegen = true属性构建并安装了GRPC-JAVA,它应该在本地Maven存储库中本地安装所需的jar。看起来像其他还有protobuf等,但不是这个。
然后我尝试使用Maven上最新可用的1.17.1,而我的pom是
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<grpc.version>1.17.1</grpc.version><!-- CURRENT_GRPC_VERSION -->
<protobuf.version>3.5.1</protobuf.version>
<protoc.version>3.5.1-1</protoc.version>
<netty.tcnative.version>2.0.7.Final</netty.tcnative.version>
<!-- required for jdk9 -->
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
这里的错误是-
An exception occured while executing the Java class. Could not find TLS ALPN provider; no working netty-tcnative, Conscrypt, or Jetty NPN/ALPN available
我不确定问题可能是什么,任何帮助都是真的。
J
答案 0 :(得分:0)
通常不应使用SNAPSHOT版本。这些示例未将SNAPSHOT版本用于发行标签。试用示例时,请签出最新的发行标签。这样应该可以解决protoc-gen-grpc-java
丢失(由skipCodegen=true
引起)的任何问题。
在抛出“找不到TLS ALPN提供程序”异常之前,应该有INFO级别的日志。有三个重要的日志条目:“ netty-tcnative不可用(这可能是正常的)”,“未发现Conscrypt(这可能是正常的)”和“ Jetty ALPN不可用(这可能是正常的)”。他们将有例外,其他信息将使问题更加清楚。
如果仍然遇到问题,请尝试运行Google Cloud Compat Checker。它检查是否会阻止ALTS正常运行的常见问题。
您也可以参考gRPC的SECURITY.md以获得故障排除信息。