2017-01-23 10 views
1

からのBigtableに接続できませんは、私はこのような接続を作成するときのBigtableと正常に動作し、スタンドアロンのアプリケーションを持っている春のブートアプリケーション

<dependency> 
    <groupId>com.google.apis</groupId> 
    <artifactId>google-api-services-storage</artifactId> 
    <version>v1-rev78-1.22.0</version> 
</dependency> 
<dependency> 
    <groupId>com.google.apis</groupId> 
    <artifactId>google-api-services-pubsub</artifactId> 
    <version>v1-rev11-1.22.0</version> 
</dependency> 
<dependency> 
    <groupId>com.google.cloud.bigtable</groupId> 
    <artifactId>bigtable-hbase-1.2</artifactId> 
    <version>0.9.5</version> 
</dependency> 
<dependency> 
    <groupId>org.apache.hbase</groupId> 
    <artifactId>hbase-client</artifactId> 
    <version>1.2.4</version> 
</dependency> 
<dependency> 
    <groupId>io.netty</groupId> 
    <artifactId>netty-tcnative-boringssl-static</artifactId> 
    <version>1.1.33.Fork26</version> 
</dependency> 

私は春のブートWebアプリケーションに今それを変換していますので、私はこの依存関係を追加する必要がありました:

<dependency> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-web</artifactId> 
    <version>1.4.2.RELEASE</version> 
</dependency> 

私は、全く何も変わっていないはちょうどこれら5行を追加し、今私はこのエラーを取得しています:

java.lang.IllegalStateException: Could not find an appropriate constructor for com.google.cloud.bigtable.hbase1_1.BigtableConnection 
    at com.google.cloud.bigtable.hbase.BigtableConfiguration.connect(BigtableConfiguration.java:88) 
    at com.google.cloud.bigtable.hbase.BigtableConfiguration.connect(BigtableConfiguration.java:72) 
    at poc.google.cloud.BigtableTest.testHelloWorld(BigtableTest.java:57) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:47) 
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:44) 
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:271) 
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:70) 
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50) 
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238) 
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63) 
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236) 
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53) 
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229) 
    at org.junit.runners.ParentRunner.run(ParentRunner.java:309) 
    at org.junit.runner.JUnitCore.run(JUnitCore.java:160) 
    at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:78) 
    at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:212) 
    at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:68) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
    at com.intellij.rt.execution.application.AppMain.main(AppMain.java:140) 
Caused by: java.lang.reflect.InvocationTargetException 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62) 
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) 
    at java.lang.reflect.Constructor.newInstance(Constructor.java:422) 
    at com.google.cloud.bigtable.hbase.BigtableConfiguration.connect(BigtableConfiguration.java:85) 
    ... 28 more 
Caused by: java.lang.IllegalStateException: Neither Jetty ALPN nor OpenSSL via netty-tcnative were properly configured. 
    at com.google.cloud.bigtable.grpc.BigtableSession.<init>(BigtableSession.java:258) 
    at org.apache.hadoop.hbase.client.AbstractBigtableConnection.<init>(AbstractBigtableConnection.java:137) 
    at org.apache.hadoop.hbase.client.AbstractBigtableConnection.<init>(AbstractBigtableConnection.java:104) 
    at com.google.cloud.bigtable.hbase1_1.BigtableConnection.<init>(BigtableConnection.java:48) 
    ... 33 more 
+0

私は私が今までtcnative Fork26テストとは思わないとFork19で運を持っていました。それが問題なのかどうかはわかりません。私はjettyやtomcat環境での問題の発注に由来するtcnativeに関するさまざまなクラスパスを実行しました。たとえば、https://github.com/GoogleCloudPlatform/cloud-bigtable-client/issues/876とhttp://stackoverflow.com/questions/39421958/google-cloud-bigtable-java-client-tcnative-errors。私は問題をデバッグすることができませんでした –

+0

私は '1.1.33.Fork19'を運行なしで試しました。今のところ私は、 'spring-boot-starter-web'によってもたらされる' org.apache.tomcat.embed:spring-boot-starter-tomcat'の推移依存性と関係があることを知ります。 – cahen

+0

tcnativeの 'tc'風袋を表します。 tcnativeとtomcatの両方が利用可能な場合、いくつかの矛盾があります。 1つの可能性のある代替案は、alpn_bootを使用することですが、gRPCはそうすることを強く推奨します... https://github.com/grpc/grpc-java/blob/master/SECURITY.md#tls-with-jdk-jetty-alpnnpn –

答えて

2

のBigtableへの接続に使用するライブラリは、との競合のいくつかの種類を持っているように見えますTomcatライブラリはデフォルトでSpringBootによって使用されます。

回避策として、TomcatではなくJettyを使用してください。

また、この移行後にcom.google.protobuf:protobuf-javaが欠落していたので、も追加することを忘れないでください。

これは、あなたが春ブーツに桟橋のためにTomcatを交換する方法である:

<dependency> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-web</artifactId> 
    <exclusions> 
     <exclusion> 
      <groupId>org.springframework.boot</groupId> 
      <artifactId>spring-boot-starter-tomcat</artifactId> 
     </exclusion> 
    </exclusions> 
</dependency> 
<dependency> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-jetty</artifactId> 
</dependency> 
<!-- Excluding spring-boot-starter-tomcat from Spring Boot and adding spring-boot-starter-jetty 
made protobuf-java disappear although it's still needed --> 
<dependency> 
    <groupId>com.google.protobuf</groupId> 
    <artifactId>protobuf-java</artifactId> 
    <version>3.1.0</version> 
</dependency>