1

Jettyをhttpおよびhttpsのプロキシとして構成しようとしています。2つの異なるバージョンのjettyをダウンロードしましたが、両方とも同じ問題があります。

私が現在使用しているバージョンは、CentOs6.2で実行されているjetty-distribution-8.1.8.v20121106です。

tar.gzを解凍した後、start.iniファイルを変更して、etc/jetty-proxy.xmlを構成ファイルのリストに追加しました。

#etc/jetty-jmx.xml
etc/jetty.xml
<b>etc/jetty-proxy.xml</b>
etc/jetty-annotations.xml
etc/jetty-ssl.xml
# etc/jetty-requestlog.xml
etc/jetty-deploy.xml
#etc/jetty-overlay.xml
etc/jetty-webapps.xml
etc/jetty-contexts.xml
etc/jetty-testrealm.xml

突堤は定期的に始動します。私はそれにアクセスすることができます:

http://localhost:8080/
https://localhost:8443/

ログファイルを読み取ると、ポート8080、8443、および8888で3つの抽象コネクタが開始されているようです。

2012-12-04 12:40:03.400:INFO:oejs.AbstractConnector:Started SelectChannelConnector@0.0.0.0:8080
2012-12-04 12:40:03.666:INFO:oejus.SslContextFactory:[SSLv2Hello、SSLv3、TLSv1]の有効なプロトコル[SSLv2Hello、SSLv3、TLSv1]
2012-12-04 12:40:03.668:INFO:oejs.AbstractConnector:Started SslSelectChannelConnector@0.0.0.0:8443
2012-12-04 12:40:03.668:INFO:oejs.Server:jetty-8.1.8.v20121106
2012-12-04 12:40:03.732:INFO:oejs.AbstractConnector:Started SelectChannelConnector@0.0.0.0:8888

ポート8888でプロキシにアクセスするようにブラウザを設定すると、次の例外を除いてjettyが失敗します。

2012-12-04 12:40:13.463:WARN:oejs.ServletHandler:Error for /search
java.lang.NoClassDefFoundError: org/eclipse/jetty/client/HttpExchange
    at java.lang.Class.getDeclaredConstructors0(Native Method)
    at java.lang.Class.privateGetDeclaredConstructors(Class.java:2389)
    at java.lang.Class.getConstructor0(Class.java:2699)
    at java.lang.Class.newInstance0(Class.java:326)
    at java.lang.Class.newInstance(Class.java:308)
    at org.eclipse.jetty.servlet.ServletHolder.newInstance(ServletHolder.java:941)
    at org.eclipse.jetty.servlet.ServletHolder.initServlet(ServletHolder.java:501)
    at org.eclipse.jetty.servlet.ServletHolder.getServlet(ServletHolder.java:402)
    at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:642)
    at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:455)
    at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:384)
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:135)
    at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:116)
    at org.eclipse.jetty.server.Server.handle(Server.java:365)
    at org.eclipse.jetty.server.AbstractHttpConnection.handleRequest(AbstractHttpConnection.java:485)
    at org.eclipse.jetty.server.AbstractHttpConnection.headerComplete(AbstractHttpConnection.java:926)
    at org.eclipse.jetty.server.AbstractHttpConnection$RequestHandler.headerComplete(AbstractHttpConnection.java:988)
    at org.eclipse.jetty.http.HttpParser.parseNext(HttpParser.java:635)
    at org.eclipse.jetty.http.HttpParser.parseAvailable(HttpParser.java:235)
    at org.eclipse.jetty.server.AsyncHttpConnection.handle(AsyncHttpConnection.java:82)
    at org.eclipse.jetty.io.nio.SelectChannelEndPoint.handle(SelectChannelEndPoint.java:628)
    at org.eclipse.jetty.io.nio.SelectChannelEndPoint$1.run(SelectChannelEndPoint.java:52)
    at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:608)
    at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:543)
    at java.lang.Thread.run(Thread.java:662)
Caused by: 
java.lang.ClassNotFoundException: org.eclipse.jetty.client.HttpExchange
    at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
...

$ JETTY_HOME/libフォルダーにjarファイルが含まれていることを確認しました。

jetty-client-8.1.8.v20121106.jar 

クラスorg.eclipse.jetty.client.HttpExchangeが含まれています。jettyを実行するには、次のコマンドを使用します:bin / jetty.sh start

コマンドbin/jetty.shチェックは、次の情報を返します。

Checking arguments to Jetty: 
JETTY_HOME     =  /home/dude/Downloads/jetty-distribution-8.1.8.v20121106
JETTY_CONF     =  /home/dude/Downloads/jetty-distribution-8.1.8.v20121106/etc/jetty.conf
JETTY_RUN      =  /tmp
JETTY_PID      =  /tmp/jetty.pid
JETTY_PORT     =  
JETTY_LOGS     =  
START_INI      =  /home/dude/Downloads/jetty-distribution-8.1.8.v20121106/start.ini
CONFIGS        =  --pre=etc/jetty-logging.xml
JAVA_OPTIONS   =   -Djetty.home=/home/dude/Downloads/jetty-distribution-8.1.8.v20121106-Djava.io.tmpdir=/tmp
JAVA           =  /data/dude/java/bin/java
CLASSPATH      =  
RUN_CMD        =  /data/dude/java/bin/java -Djetty.home=/home/dude/Downloads/jetty-distribution-8.1.8.v20121106 -Djava.io.tmpdir=/tmp -jar /home/dude/Downloads/jetty-distribution-8.1.8.v20121106/start.jar --pre=etc/jetty-logging.xml

Jetty running pid=15498

ありがとうございました

4

1 に答える 1

2

start.ini add client の OPTIONS で、プロキシ環境ではクライアント アーティファクトが使用可能である必要があります。ProxyServlet を使用する場合と同様に、サーブレットの web-inf/lib ディレクトリに jetty-client とその依存関係が必要です。

とにかく、これにより、可能なオプションと、実行時にクラスパスに追加されるものが表示されます。start.jar は、jetty が実行される環境を構築するのに役立ちます。

java -jar start.jar --list-options

これは、構成が与えられた場合に配置されるコマンドラインの例を提供することにより、現在どのようにセットアップされているかを示します。

java -jar start.jar --dry-run

詳細については、次を参照してください。

java -jar start.jar --help

またはここを見てください:

http://wiki.eclipse.org/Jetty/Feature/Start.jar

于 2012-12-04T18:57:03.630 に答える