0

Web ページから Apache Hive を呼び出す Eclipse で GWT プロジェクトに取り組んでいます。アーキテクチャはこのようなものです。

GWT プロジェクト内。使用は、Web ページにハイブ クエリを配置します。Web ページは、GWT RPC を使用してこのクエリをサーバー クラスに送信します。サーバーは、別の Eclipse プロジェクト内の別の Java クラスを呼び出します。このプロジェクトには、VM (CDH3) で実行されているハイブを呼び出すハイブ jdbc ドライバーがあります。

GWT サーバー クラスを呼び出して Hive クエリを送信し、正常に実行される単体テストを作成しましたが、プロジェクトを実行して Web ページからクエリを送信しようとすると、実行時エラーをスローします。Hive JDBC ドライバーを持つ 2 番目の Eclipse プロジェクトに含まれる slf4j クラスと競合しているようです。実行時に呼び出される GWT サーバー クラスと、他のプロジェクトに含まれる slf4j クラスとの間に競合があると思います。ちなみに、2 番目のプロジェクトは最初のプロジェクトのビルド パスに含まれていますが、その逆ではありません。

エラーは次のとおりです。

[WARN] Exception while dispatching incoming RPC call
com.google.gwt.user.server.rpc.UnexpectedException: Service method 'public abstract java.lang.String com.unitest.client.GreetingService.greetServer(java.lang.String) throws java.lang.IllegalArgumentException' threw an unexpected exception: java.lang.NoClassDefFoundError: Could not initialize class org.apache.thrift.transport.TSocket
    at com.google.gwt.user.server.rpc.RPC.encodeResponseForFailure(RPC.java:385)
    at com.google.gwt.user.server.rpc.RPC.invokeAndEncodeResponse(RPC.java:588)
    at com.google.gwt.user.server.rpc.RemoteServiceServlet.processCall(RemoteServiceServlet.java:208)
    at com.google.gwt.user.server.rpc.RemoteServiceServlet.processPost(RemoteServiceServlet.java:248)
    at com.google.gwt.user.server.rpc.AbstractRemoteServiceServlet.doPost(AbstractRemoteServiceServlet.java:62)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:487)
    at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:362)
    at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
    at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181)
    at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:729)
    at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:405)
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
    at org.mortbay.jetty.handler.RequestLogHandler.handle(RequestLogHandler.java:49)
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
    at org.mortbay.jetty.Server.handle(Server.java:324)
    at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:505)
    at org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:843)
    at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:647)
    at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:211)
    at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:380)
    at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:395)
    at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:488)
Caused by: java.lang.NoClassDefFoundError: Could not initialize class org.apache.thrift.transport.TSocket
    at org.apache.hadoop.hive.jdbc.HiveConnection.<init>(HiveConnection.java:92)
    at org.apache.hadoop.hive.jdbc.HiveDriver.connect(HiveDriver.java:104)
    at java.sql.DriverManager.getConnection(Unknown Source)
    at java.sql.DriverManager.getConnection(Unknown Source)
4

1 に答える 1

0

サーバー側の依存関係はWEB-INF/lib、GWT プロジェクト内に存在する必要があります (他の WAR と同様)。

于 2012-10-04T12:20:45.727 に答える