diff --git a/jetty-documentation/src/main/asciidoc/administration/logging/chapter.adoc b/jetty-documentation/src/main/asciidoc/administration/logging/chapter.adoc index 6803f87e661e..67f09a301ce1 100644 --- a/jetty-documentation/src/main/asciidoc/administration/logging/chapter.adoc +++ b/jetty-documentation/src/main/asciidoc/administration/logging/chapter.adoc @@ -26,4 +26,4 @@ include::default-logging-with-stderrlog.adoc[] include::configuring-jetty-request-logs.adoc[] include::configuring-logging-modules.adoc[] include::example-logback-centralized-logging.adoc[] -include::dump-tool.adoc[] +include::jetty-server-dump.adoc[] diff --git a/jetty-documentation/src/main/asciidoc/administration/logging/dump-tool.adoc b/jetty-documentation/src/main/asciidoc/administration/logging/dump-tool.adoc deleted file mode 100644 index 7ca291e34d7d..000000000000 --- a/jetty-documentation/src/main/asciidoc/administration/logging/dump-tool.adoc +++ /dev/null @@ -1,837 +0,0 @@ -// -// ======================================================================== -// Copyright (c) 1995-2020 Mort Bay Consulting Pty Ltd and others. -// ======================================================================== -// All rights reserved. This program and the accompanying materials -// are made available under the terms of the Eclipse Public License v1.0 -// and Apache License v2.0 which accompanies this distribution. -// -// The Eclipse Public License is available at -// http://www.eclipse.org/legal/epl-v10.html -// -// The Apache License v2.0 is available at -// http://www.opensource.org/licenses/apache2.0.php -// -// You may elect to redistribute this code under either of these licenses. -// ======================================================================== -// - -[[jetty-dump-tool]] -=== Jetty Dump Tool - -The dump feature in Jetty provides a good snapshot of the status of the threadpool, select sets, classloaders, and so forth. -To get maximum detail from the dump, you need to `setDetailDump(true)` on any `QueuedThreadPools` you are using. -You can do this by a direct call if you are embedding Jetty, or in `jetty.xml`. - -[[configuring-dump-feature]] -==== Configuring the Dump Feature in jetty.xml - -You can request that Jetty do a dump immediately after starting and just before stopping by calling the appropriate setters on the `Server` instance. -This can be accomplished in `jetty.xml` with: - -[source, xml, subs="{sub-order}"] ----- -true -true ----- - -[[extra-threadpool-info]] -==== Extra ThreadPool Information - -You can get additional detail from the `QueuedThreadPool` if `setDetailedDump(true)` is called on the thread pool instance. -Do this in `jetty.xml` as follows: - -[source, xml, subs="{sub-order}"] ----- - - - - - - - - 10 - 200 - true - - ----- - -[[dump-tool-via-jmx]] -==== Using the Dump Feature via JMX - -The `dump` method is on the Server instance and many of its nested components (Handlers, Connectors, and so forth). -Dumps may be obtained by calling these methods either in code or via JMX (see xref:using-jmx[]). - -The Server MBean has a `dump()` method, which dumps everything, plus a `dumpStdErr()` operation that dumps to StdErr rather than replying to JConsole. - -[[examing-jetty-distro-dump]] -==== Examining a Jetty Distribution Dump - -This is a dump of the stock jetty-distribution with extra threadpool information: - -.... -org.eclipse.jetty.server.Server@76f08fe1 - STARTING - += qtp1062680061{STARTED,10<=13<=200,i=1,q=0} - STARTED - | +- 12 qtp1062680061-12-selector-0 RUNNABLE - | | +- sun.nio.ch.KQueueArrayWrapper.kevent0(Native Method) - | | +- sun.nio.ch.KQueueArrayWrapper.poll(KQueueArrayWrapper.java:159) - | | +- sun.nio.ch.KQueueSelectorImpl.doSelect(KQueueSelectorImpl.java:103) - | | +- sun.nio.ch.SelectorImpl.lockAndDoSelect(SelectorImpl.java:87) - | | +- sun.nio.ch.SelectorImpl.select(SelectorImpl.java:98) - | | +- sun.nio.ch.SelectorImpl.select(SelectorImpl.java:102) - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:459) - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.run(SelectorManager.java:435) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:596) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:527) - | | +- java.lang.Thread.run(Thread.java:722) - | +- 13 qtp1062680061-13-selector-6 RUNNABLE - | | +- sun.nio.ch.KQueueArrayWrapper.kevent0(Native Method) - | | +- sun.nio.ch.KQueueArrayWrapper.poll(KQueueArrayWrapper.java:159) - | | +- sun.nio.ch.KQueueSelectorImpl.doSelect(KQueueSelectorImpl.java:103) - | | +- sun.nio.ch.SelectorImpl.lockAndDoSelect(SelectorImpl.java:87) - | | +- sun.nio.ch.SelectorImpl.select(SelectorImpl.java:98) - | | +- sun.nio.ch.SelectorImpl.select(SelectorImpl.java:102) - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:459) - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.run(SelectorManager.java:435) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:596) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:527) - | | +- java.lang.Thread.run(Thread.java:722) - | +- 14 qtp1062680061-14-selector-5 RUNNABLE - | | +- sun.nio.ch.KQueueArrayWrapper.kevent0(Native Method) - | | +- sun.nio.ch.KQueueArrayWrapper.poll(KQueueArrayWrapper.java:159) - | | +- sun.nio.ch.KQueueSelectorImpl.doSelect(KQueueSelectorImpl.java:103) - | | +- sun.nio.ch.SelectorImpl.lockAndDoSelect(SelectorImpl.java:87) - | | +- sun.nio.ch.SelectorImpl.select(SelectorImpl.java:98) - | | +- sun.nio.ch.SelectorImpl.select(SelectorImpl.java:102) - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:459) - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.run(SelectorManager.java:435) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:596) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:527) - | | +- java.lang.Thread.run(Thread.java:722) - | +- 15 qtp1062680061-15-acceptor-0-ServerConnector@3d0f282{HTTP/1.1}{0.0.0.0:9090} BLOCKED - | | +- sun.nio.ch.ServerSocketChannelImpl.accept(ServerSocketChannelImpl.java:210) - | | +- org.eclipse.jetty.server.ServerConnector.accept(ServerConnector.java:284) - | | +- org.eclipse.jetty.server.AbstractConnector$Acceptor.run(AbstractConnector.java:460) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:596) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:527) - | | +- java.lang.Thread.run(Thread.java:722) - | +- 16 qtp1062680061-16-selector-1 RUNNABLE - | | +- sun.nio.ch.KQueueArrayWrapper.kevent0(Native Method) - | | +- sun.nio.ch.KQueueArrayWrapper.poll(KQueueArrayWrapper.java:159) - | | +- sun.nio.ch.KQueueSelectorImpl.doSelect(KQueueSelectorImpl.java:103) - | | +- sun.nio.ch.SelectorImpl.lockAndDoSelect(SelectorImpl.java:87) - | | +- sun.nio.ch.SelectorImpl.select(SelectorImpl.java:98) - | | +- sun.nio.ch.SelectorImpl.select(SelectorImpl.java:102) - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:459) - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.run(SelectorManager.java:435) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:596) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:527) - | | +- java.lang.Thread.run(Thread.java:722) - | +- 17 qtp1062680061-17-selector-2 RUNNABLE - | | +- sun.nio.ch.KQueueArrayWrapper.kevent0(Native Method) - | | +- sun.nio.ch.KQueueArrayWrapper.poll(KQueueArrayWrapper.java:159) - | | +- sun.nio.ch.KQueueSelectorImpl.doSelect(KQueueSelectorImpl.java:103) - | | +- sun.nio.ch.SelectorImpl.lockAndDoSelect(SelectorImpl.java:87) - | | +- sun.nio.ch.SelectorImpl.select(SelectorImpl.java:98) - | | +- sun.nio.ch.SelectorImpl.select(SelectorImpl.java:102) - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:459) - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.run(SelectorManager.java:435) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:596) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:527) - | | +- java.lang.Thread.run(Thread.java:722) - | +- 18 qtp1062680061-18-selector-3 RUNNABLE - | | +- sun.nio.ch.KQueueArrayWrapper.kevent0(Native Method) - | | +- sun.nio.ch.KQueueArrayWrapper.poll(KQueueArrayWrapper.java:159) - | | +- sun.nio.ch.KQueueSelectorImpl.doSelect(KQueueSelectorImpl.java:103) - | | +- sun.nio.ch.SelectorImpl.lockAndDoSelect(SelectorImpl.java:87) - | | +- sun.nio.ch.SelectorImpl.select(SelectorImpl.java:98) - | | +- sun.nio.ch.SelectorImpl.select(SelectorImpl.java:102) - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:459) - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.run(SelectorManager.java:435) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:596) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:527) - | | +- java.lang.Thread.run(Thread.java:722) - | +- 19 qtp1062680061-19-selector-4 RUNNABLE - | | +- sun.nio.ch.KQueueArrayWrapper.kevent0(Native Method) - | | +- sun.nio.ch.KQueueArrayWrapper.poll(KQueueArrayWrapper.java:159) - | | +- sun.nio.ch.KQueueSelectorImpl.doSelect(KQueueSelectorImpl.java:103) - | | +- sun.nio.ch.SelectorImpl.lockAndDoSelect(SelectorImpl.java:87) - | | +- sun.nio.ch.SelectorImpl.select(SelectorImpl.java:98) - | | +- sun.nio.ch.SelectorImpl.select(SelectorImpl.java:102) - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:459) - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.run(SelectorManager.java:435) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:596) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:527) - | | +- java.lang.Thread.run(Thread.java:722) - | +- 20 qtp1062680061-20-selector-7 RUNNABLE - | | +- sun.nio.ch.KQueueArrayWrapper.kevent0(Native Method) - | | +- sun.nio.ch.KQueueArrayWrapper.poll(KQueueArrayWrapper.java:159) - | | +- sun.nio.ch.KQueueSelectorImpl.doSelect(KQueueSelectorImpl.java:103) - | | +- sun.nio.ch.SelectorImpl.lockAndDoSelect(SelectorImpl.java:87) - | | +- sun.nio.ch.SelectorImpl.select(SelectorImpl.java:98) - | | +- sun.nio.ch.SelectorImpl.select(SelectorImpl.java:102) - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:459) - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.run(SelectorManager.java:435) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:596) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:527) - | | +- java.lang.Thread.run(Thread.java:722) - | +- 21 qtp1062680061-21-acceptor-1-ServerConnector@3d0f282{HTTP/1.1}{0.0.0.0:9090} RUNNABLE - | | +- sun.nio.ch.ServerSocketChannelImpl.accept0(Native Method) - | | +- sun.nio.ch.ServerSocketChannelImpl.accept(ServerSocketChannelImpl.java:226) - | | +- org.eclipse.jetty.server.ServerConnector.accept(ServerConnector.java:284) - | | +- org.eclipse.jetty.server.AbstractConnector$Acceptor.run(AbstractConnector.java:460) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:596) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:527) - | | +- java.lang.Thread.run(Thread.java:722) - | +- 49 qtp1062680061-49-acceptor-2-ServerConnector@3d0f282{HTTP/1.1}{0.0.0.0:9090} BLOCKED - | | +- sun.nio.ch.ServerSocketChannelImpl.accept(ServerSocketChannelImpl.java:210) - | | +- org.eclipse.jetty.server.ServerConnector.accept(ServerConnector.java:284) - | | +- org.eclipse.jetty.server.AbstractConnector$Acceptor.run(AbstractConnector.java:460) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:596) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:527) - | | +- java.lang.Thread.run(Thread.java:722) - | +- 50 qtp1062680061-50-acceptor-3-ServerConnector@3d0f282{HTTP/1.1}{0.0.0.0:9090} BLOCKED - | | +- sun.nio.ch.ServerSocketChannelImpl.accept(ServerSocketChannelImpl.java:210) - | | +- org.eclipse.jetty.server.ServerConnector.accept(ServerConnector.java:284) - | | +- org.eclipse.jetty.server.AbstractConnector$Acceptor.run(AbstractConnector.java:460) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:596) - | | +- org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:527) - | | +- java.lang.Thread.run(Thread.java:722) - | +- 52 qtp1062680061-52 TIMED_WAITING IDLE - += org.eclipse.jetty.util.thread.ScheduledExecutorScheduler@725f5 - STARTED - += org.eclipse.jetty.server.handler.HandlerCollection@58b37561 - STARTED - | += org.eclipse.jetty.server.handler.ContextHandlerCollection@64c6e290 - STARTED - | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | += o.e.j.w.WebAppContext@7ea88b1c{/async-rest,[file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/, jar:file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/lib/example-async-rest-jar-9.0.2.v20130417.jar!/META-INF/resources/],AVAILABLE}{/async-rest.war} - STARTED - | | | += org.eclipse.jetty.server.session.SessionHandler@6dfb8d2e - STARTED - | | | | += org.eclipse.jetty.server.session.HashSessionManager@6cb83869 - STARTED - | | | | += org.eclipse.jetty.security.ConstraintSecurityHandler@2848c90e - STARTED - | | | | | +- org.eclipse.jetty.security.DefaultAuthenticatorFactory@52b12fef - | | | | | += org.eclipse.jetty.servlet.ServletHandler@46bac287 - STARTED - | | | | | | += default@5c13d641==org.eclipse.jetty.servlet.DefaultServlet,0,true - STARTED - | | | | | | | +- maxCacheSize=256000000 - | | | | | | | +- etags=true - | | | | | | | +- dirAllowed=true - | | | | | | | +- gzip=true - | | | | | | | +- maxCachedFileSize=200000000 - | | | | | | | +- redirectWelcome=false - | | | | | | | +- acceptRanges=true - | | | | | | | +- welcomeServlets=false - | | | | | | | +- aliases=false - | | | | | | | +- useFileMappedBuffer=true - | | | | | | | +- maxCachedFiles=2048 - | | | | | | +- [/]=>default - | | | | | | += jsp@19c47==org.apache.jasper.servlet.JspServlet,0,true - STARTED - | | | | | | | +- logVerbosityLevel=DEBUG - | | | | | | | +- fork=false - | | | | | | | +- com.sun.appserv.jsp.classpath=/home/user/jetty-distribution-{VERSION}/lib/jetty-xml-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/servlet-api-3.0.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-http-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-continuation-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-server-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-security-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-servlet-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-webapp-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-deploy-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-client-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-jmx-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/com.sun.el-2.2.0.v201303151357.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.el-2.2.0.v201303151357.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp.jstl-1.2.0.v201105211821.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp-2.2.0.v201112011158.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.jasper.glassfish-2.2.2.v201112011158.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.taglibs.standard.glassfish-1.2.0.v201112081803.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.eclipse.jdt.core-3.8.2.v20130121.jar:/home/user/jetty-distribution-{VERSION}/resources:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-api-9.0.2.v20130417.jar:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-common-9.0.2.v20130417.jar:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-server-9.0.2.v20130417.jar:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-servlet-9.0.2.v20130417.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-util-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-io-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/start.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/dnsns.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/localedata.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/sunec.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/sunjce_provider.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/sunpkcs11.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/zipfs.jar:/opt/local/lib/libsvnjavahl-1.0.dylib:/System/Library/Java/Extensions/AppleScriptEngine.jar:/System/Library/Java/Extensions/dns_sd.jar:/System/Library/Java/Extensions/j3daudio.jar:/System/Library/Java/Extensions/j3dcore.jar:/System/Library/Java/Extensions/j3dutils.jar:/System/Library/Java/Extensions/jai_codec.jar:/System/Library/Java/Extensions/jai_core.jar:/System/Library/Java/Extensions/libAppleScriptEngine.jnilib:/System/Library/Java/Extensions/libJ3D.jnilib:/System/Library/Java/Extensions/libJ3DAudio.jnilib:/System/Library/Java/Extensions/libJ3DUtils.jnilib:/System/Library/Java/Extensions/libmlib_jai.jnilib:/System/Library/Java/Extensions/libQTJNative.jnilib:/System/Library/Java/Extensions/mlibwrapper_jai.jar:/System/Library/Java/Extensions/MRJToolkit.jar:/System/Library/Java/Extensions/QTJava.zip:/System/Library/Java/Extensions/vecmath.jar:/usr/lib/java/libjdns_sd.jnilib - | | | | | | | +- scratchdir=/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/jsp - | | | | | | | +- xpoweredBy=false - | | | | | | +- [*.jsp, *.jspf, *.jspx, *.xsp, *.JSP, *.JSPF, *.JSPX, *.XSP]=>jsp - | | | | | | += SerialRestServlet@461411d==org.eclipse.jetty.example.asyncrest.SerialRestServlet,-1,false - STARTED - | | | | | | +- [/testSerial]=>SerialRestServlet - | | | | | | += AsyncRestServlet@73eb9bd5==org.eclipse.jetty.example.asyncrest.AsyncRestServlet,-1,false - STARTED - | | | | | | +- [/testAsync]=>AsyncRestServlet - | | | | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | | | += HashLoginService[Test Realm] - STARTED - | | | | | +- org.eclipse.jetty.security.DefaultIdentityService@d2539a6 - | | | | | +- org.eclipse.jetty.security.authentication.BasicAuthenticator@7b239469 - | | | | | | - | | | | | +> HashLoginService[Test Realm] - STARTED - | | | | | +> org.eclipse.jetty.security.DefaultIdentityService@d2539a6 - | | | | | +> org.eclipse.jetty.security.authentication.BasicAuthenticator@7b239469 - | | | | | +> [] - | | | | | +> /={TRACE={RoleInfo,F,C[]}} - | | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | += org.eclipse.jetty.servlet.ErrorPageErrorHandler@3c121009 - STARTED - | | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | | - | | | +> WebAppClassLoader=Async REST Webservice Example@52934ea0 - | | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/classes/ - | | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/lib/example-async-rest-jar-9.0.2.v20130417.jar - | | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/lib/jetty-client-{VERSION}.jar - | | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/lib/jetty-http-{VERSION}.jar - | | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/lib/jetty-io-{VERSION}.jar - | | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/lib/jetty-util-{VERSION}.jar - | | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/lib/jetty-util-ajax-{VERSION}.jar - | | | | +- startJarLoader@7194b34a - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-xml-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/servlet-api-3.0.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-http-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-continuation-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-server-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-security-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-servlet-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-webapp-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-deploy-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-client-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-jmx-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/com.sun.el-2.2.0.v201303151357.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.el-2.2.0.v201303151357.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp.jstl-1.2.0.v201105211821.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp-2.2.0.v201112011158.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.jasper.glassfish-2.2.2.v201112011158.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.taglibs.standard.glassfish-1.2.0.v201112081803.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.eclipse.jdt.core-3.8.2.v20130121.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/resources/ - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-api-9.0.2.v20130417.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-common-9.0.2.v20130417.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-server-9.0.2.v20130417.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-servlet-9.0.2.v20130417.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-util-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-io-{VERSION}.jar - | | | | +- sun.misc.Launcher$AppClassLoader@19d1b44b - | | | | +- file:/home/user/jetty-distribution-{VERSION}/start.jar - | | | | +- sun.misc.Launcher$ExtClassLoader@1693b52b - | | | +> javax.servlet.context.tempdir=/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any- - | | | +> org.apache.catalina.jsp_classpath=/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/classes:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/lib/example-async-rest-jar-9.0.2.v20130417.jar:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/lib/jetty-client-{VERSION}.jar:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/lib/jetty-http-{VERSION}.jar:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/lib/jetty-io-{VERSION}.jar:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/lib/jetty-util-{VERSION}.jar:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/lib/jetty-util-ajax-{VERSION}.jar - | | | +> org.eclipse.jetty.server.webapp.ContainerIncludeJarPattern=.*/servlet-api-[^/]*\.jar$ - | | | +> com.sun.jsp.taglibraryCache={} - | | | +> com.sun.jsp.tagFileJarUrlsCache={} - | | += o.e.j.s.h.MovedContextHandler@5e0c8d24{/oldContextPath,null,AVAILABLE} - STARTED - | | | += org.eclipse.jetty.server.handler.MovedContextHandler$Redirector@2a4200d3 - STARTED - | | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | | - | | | +> No ClassLoader - | | | +> org.eclipse.jetty.server.webapp.ContainerIncludeJarPattern=.*/servlet-api-[^/]*\.jar$ - | | += o.e.j.w.WebAppContext@6f01ba6f{/,file:/home/user/jetty-distribution-{VERSION}/webapps/ROOT/,AVAILABLE}{/ROOT} - STARTED - | | | += org.eclipse.jetty.server.session.SessionHandler@5a770658 - STARTED - | | | | += org.eclipse.jetty.server.session.HashSessionManager@746a95ae - STARTED - | | | | += org.eclipse.jetty.security.ConstraintSecurityHandler@1890e38 - STARTED - | | | | | +- org.eclipse.jetty.security.DefaultAuthenticatorFactory@6242c657 - | | | | | += org.eclipse.jetty.servlet.ServletHandler@debac27 - STARTED - | | | | | | += default@5c13d641==org.eclipse.jetty.servlet.DefaultServlet,0,true - STARTED - | | | | | | | +- maxCacheSize=256000000 - | | | | | | | +- etags=true - | | | | | | | +- dirAllowed=true - | | | | | | | +- gzip=true - | | | | | | | +- maxCachedFileSize=200000000 - | | | | | | | +- redirectWelcome=false - | | | | | | | +- acceptRanges=true - | | | | | | | +- welcomeServlets=false - | | | | | | | +- aliases=false - | | | | | | | +- useFileMappedBuffer=true - | | | | | | | +- maxCachedFiles=2048 - | | | | | | +- [/]=>default - | | | | | | += jsp@19c47==org.apache.jasper.servlet.JspServlet,0,true - STARTED - | | | | | | | +- logVerbosityLevel=DEBUG - | | | | | | | +- fork=false - | | | | | | | +- com.sun.appserv.jsp.classpath=/home/user/jetty-distribution-{VERSION}/lib/jetty-xml-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/servlet-api-3.0.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-http-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-continuation-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-server-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-security-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-servlet-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-webapp-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-deploy-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-client-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-jmx-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/com.sun.el-2.2.0.v201303151357.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.el-2.2.0.v201303151357.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp.jstl-1.2.0.v201105211821.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp-2.2.0.v201112011158.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.jasper.glassfish-2.2.2.v201112011158.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.taglibs.standard.glassfish-1.2.0.v201112081803.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.eclipse.jdt.core-3.8.2.v20130121.jar:/home/user/jetty-distribution-{VERSION}/resources:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-api-9.0.2.v20130417.jar:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-common-9.0.2.v20130417.jar:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-server-9.0.2.v20130417.jar:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-servlet-9.0.2.v20130417.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-util-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-io-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/start.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/dnsns.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/localedata.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/sunec.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/sunjce_provider.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/sunpkcs11.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/zipfs.jar:/opt/local/lib/libsvnjavahl-1.0.dylib:/System/Library/Java/Extensions/AppleScriptEngine.jar:/System/Library/Java/Extensions/dns_sd.jar:/System/Library/Java/Extensions/j3daudio.jar:/System/Library/Java/Extensions/j3dcore.jar:/System/Library/Java/Extensions/j3dutils.jar:/System/Library/Java/Extensions/jai_codec.jar:/System/Library/Java/Extensions/jai_core.jar:/System/Library/Java/Extensions/libAppleScriptEngine.jnilib:/System/Library/Java/Extensions/libJ3D.jnilib:/System/Library/Java/Extensions/libJ3DAudio.jnilib:/System/Library/Java/Extensions/libJ3DUtils.jnilib:/System/Library/Java/Extensions/libmlib_jai.jnilib:/System/Library/Java/Extensions/libQTJNative.jnilib:/System/Library/Java/Extensions/mlibwrapper_jai.jar:/System/Library/Java/Extensions/MRJToolkit.jar:/System/Library/Java/Extensions/QTJava.zip:/System/Library/Java/Extensions/vecmath.jar:/usr/lib/java/libjdns_sd.jnilib - | | | | | | | +- scratchdir=/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-ROOT-_-any-/jsp - | | | | | | | +- xpoweredBy=false - | | | | | | +- [*.jsp, *.jspf, *.jspx, *.xsp, *.JSP, *.JSPF, *.JSPX, *.XSP]=>jsp - | | | | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | | | +~ HashLoginService[Test Realm] - STARTED - | | | | | +- org.eclipse.jetty.security.DefaultIdentityService@d2539a6 - | | | | | +- org.eclipse.jetty.security.authentication.BasicAuthenticator@6b733b94 - | | | | | | - | | | | | +> HashLoginService[Test Realm] - STARTED - | | | | | +> org.eclipse.jetty.security.DefaultIdentityService@d2539a6 - | | | | | +> org.eclipse.jetty.security.authentication.BasicAuthenticator@6b733b94 - | | | | | +> [] - | | | | | +> /={TRACE={RoleInfo,F,C[]}} - | | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | += org.eclipse.jetty.servlet.ErrorPageErrorHandler@3c41a9ce - STARTED - | | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | | - | | | +> WebAppClassLoader=ROOT@7af33249 - | | | | +- startJarLoader@7194b34a - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-xml-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/servlet-api-3.0.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-http-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-continuation-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-server-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-security-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-servlet-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-webapp-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-deploy-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-client-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-jmx-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/com.sun.el-2.2.0.v201303151357.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.el-2.2.0.v201303151357.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp.jstl-1.2.0.v201105211821.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp-2.2.0.v201112011158.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.jasper.glassfish-2.2.2.v201112011158.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.taglibs.standard.glassfish-1.2.0.v201112081803.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.eclipse.jdt.core-3.8.2.v20130121.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/resources/ - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-api-9.0.2.v20130417.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-common-9.0.2.v20130417.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-server-9.0.2.v20130417.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-servlet-9.0.2.v20130417.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-util-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-io-{VERSION}.jar - | | | | +- sun.misc.Launcher$AppClassLoader@19d1b44b - | | | | +- file:/home/user/jetty-distribution-{VERSION}/start.jar - | | | | +- sun.misc.Launcher$ExtClassLoader@1693b52b - | | | +> javax.servlet.context.tempdir=/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-ROOT-_-any- - | | | +> org.eclipse.jetty.server.webapp.ContainerIncludeJarPattern=.*/servlet-api-[^/]*\.jar$ - | | | +> com.sun.jsp.taglibraryCache={} - | | | +> com.sun.jsp.tagFileJarUrlsCache={} - | | += o.e.j.s.h.ContextHandler@7b2dffdf{/javadoc,file:/home/user/jetty-distribution-{VERSION}/javadoc,AVAILABLE} - STARTED - | | | += org.eclipse.jetty.server.handler.ResourceHandler@8f9c8a7 - STARTED - | | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | | - | | | +> No ClassLoader - | | | +> org.eclipse.jetty.server.webapp.ContainerIncludeJarPattern=.*/servlet-api-[^/]*\.jar$ - | | += o.e.j.w.WebAppContext@716d9094{/test,file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/,AVAILABLE}{/test.war} - STARTED - | | | += org.eclipse.jetty.server.session.SessionHandler@336abd81 - STARTED - | | | | += org.eclipse.jetty.server.session.HashSessionManager@1246f8d0 - STARTED - | | | | += org.eclipse.jetty.security.ConstraintSecurityHandler@7179290f - STARTED - | | | | | +- org.eclipse.jetty.security.DefaultAuthenticatorFactory@17d41d12 - | | | | | += org.eclipse.jetty.servlet.ServletHandler@5034037e - STARTED - | | | | | | += default@5c13d641==org.eclipse.jetty.servlet.DefaultServlet,0,true - STARTED - | | | | | | | +- maxCacheSize=256000000 - | | | | | | | +- etags=true - | | | | | | | +- dirAllowed=true - | | | | | | | +- gzip=true - | | | | | | | +- maxCachedFileSize=200000000 - | | | | | | | +- redirectWelcome=false - | | | | | | | +- acceptRanges=true - | | | | | | | +- welcomeServlets=false - | | | | | | | +- aliases=false - | | | | | | | +- useFileMappedBuffer=true - | | | | | | | +- maxCachedFiles=2048 - | | | | | | +- [/]=>default - | | | | | | += jsp@19c47==org.apache.jasper.servlet.JspServlet,0,true - STARTED - | | | | | | | +- logVerbosityLevel=DEBUG - | | | | | | | +- fork=false - | | | | | | | +- com.sun.appserv.jsp.classpath=/home/user/jetty-distribution-{VERSION}/lib/jetty-xml-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/servlet-api-3.0.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-http-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-continuation-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-server-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-security-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-servlet-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-webapp-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-deploy-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-client-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-jmx-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/com.sun.el-2.2.0.v201303151357.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.el-2.2.0.v201303151357.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp.jstl-1.2.0.v201105211821.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp-2.2.0.v201112011158.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.jasper.glassfish-2.2.2.v201112011158.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.taglibs.standard.glassfish-1.2.0.v201112081803.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.eclipse.jdt.core-3.8.2.v20130121.jar:/home/user/jetty-distribution-{VERSION}/resources:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-api-9.0.2.v20130417.jar:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-common-9.0.2.v20130417.jar:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-server-9.0.2.v20130417.jar:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-servlet-9.0.2.v20130417.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-util-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-io-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/start.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/dnsns.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/localedata.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/sunec.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/sunjce_provider.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/sunpkcs11.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/zipfs.jar:/opt/local/lib/libsvnjavahl-1.0.dylib:/System/Library/Java/Extensions/AppleScriptEngine.jar:/System/Library/Java/Extensions/dns_sd.jar:/System/Library/Java/Extensions/j3daudio.jar:/System/Library/Java/Extensions/j3dcore.jar:/System/Library/Java/Extensions/j3dutils.jar:/System/Library/Java/Extensions/jai_codec.jar:/System/Library/Java/Extensions/jai_core.jar:/System/Library/Java/Extensions/libAppleScriptEngine.jnilib:/System/Library/Java/Extensions/libJ3D.jnilib:/System/Library/Java/Extensions/libJ3DAudio.jnilib:/System/Library/Java/Extensions/libJ3DUtils.jnilib:/System/Library/Java/Extensions/libmlib_jai.jnilib:/System/Library/Java/Extensions/libQTJNative.jnilib:/System/Library/Java/Extensions/mlibwrapper_jai.jar:/System/Library/Java/Extensions/MRJToolkit.jar:/System/Library/Java/Extensions/QTJava.zip:/System/Library/Java/Extensions/vecmath.jar:/usr/lib/java/libjdns_sd.jnilib - | | | | | | | +- scratchdir=/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/jsp - | | | | | | | +- xpoweredBy=false - | | | | | | +- [*.jsp, *.jspf, *.jspx, *.xsp, *.JSP, *.JSPF, *.JSPX, *.XSP]=>jsp - | | | | | | += QoSFilter - STARTED - | | | | | | | +- managedAttr=true - | | | | | | | +- maxRequests=10000 - | | | | | | +- [/*]/[]==0=>QoSFilter - | | | | | | += MultiPart - STARTED - | | | | | | | +- deleteFiles=true - | | | | | | +- [/dump/*]/[]==0=>MultiPart - | | | | | | += GzipFilter - STARTED - | | | | | | | +- bufferSize=8192 - | | | | | | | +- excludedAgents=MSIE 6.0 - | | | | | | | +- userAgent=(?:Mozilla[^\(]*\(compatible;\s*+([^;]*);.*)|(?:.*?([^\s]+/[^\s]+).*) - | | | | | | | +- mimeTypes=text/plain,application/xml - | | | | | | | +- uncheckedPrintWriter=true - | | | | | | | +- cacheSize=1024 - | | | | | | | +- minGzipSize=2048 - | | | | | | +- [/dump/gzip/*, *.txt]/[]==0=>GzipFilter - | | | | | | += Login@462ff49==com.acme.LoginServlet,1,true - STARTED - | | | | | | +- [/login/*]=>Login - | | | | | | += Hello@42628b2==com.acme.HelloWorld,1,true - STARTED - | | | | | | +- [/hello/*]=>Hello - | | | | | | += Dump@20ae14==com.acme.Dump,1,true - STARTED - | | | | | | | +- servlet-override-example=a servlet value - | | | | | | +- [/dump/*, *.dump]=>Dump - | | | | | | += Session@d9891a76==com.acme.SessionDump,5,true - STARTED - | | | | | | +- [/session/*]=>Session - | | | | | | += Cookie@78a4f684==com.acme.CookieDump,1,true - STARTED - | | | | | | +- [/cookie/*]=>Cookie - | | | | | | += Dispatch@14d3a89a==com.acme.DispatchServlet,1,true - STARTED - | | | | | | +- [/dispatch/*]=>Dispatch - | | | | | | += CGI@10465==org.eclipse.jetty.servlets.CGI,1,true - STARTED - | | | | | | +- [/cgi-bin/*]=>CGI - | | | | | | += Chat@200778==com.acme.ChatServlet,1,true - STARTED - | | | | | | +- [/chat/*]=>Chat - | | | | | | += WSChat@99274454==com.acme.WebSocketChatServlet,1,true - STARTED - | | | | | | +- [/ws/*]=>WSChat - | | | | | | += Rewrite@a4dac96c==com.acme.RewriteServlet,-1,false - STARTED - | | | | | | +- [/rewritten/*, /redirected/*]=>Rewrite - | | | | | | += SecureMode@d45951da==com.acme.SecureModeServlet,1,true - STARTED - | | | | | | +- [/secureMode/*]=>SecureMode - | | | | | | += foo.jsp@d7583f1f==org.apache.jasper.servlet.JspServlet,-1,false - STARTED - | | | | | | +- [/jsp/foo/]=>foo.jsp - | | | | | | +- [*.more]=>Dump - | | | | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | | | | += RegoTest@dafcd1ad==com.acme.RegTest,-1,false - STARTED - | | | | | | +- [/rego/*]=>RegoTest - | | | | | | += RegoTest2@849d6425==com.acme.RegTest,-1,false - STARTED - | | | | | | +- [/rego2/*]=>RegoTest2 - | | | | | | += TestFilter - STARTED - | | | | | | | +- remote=false - | | | | | | +- [/*]/[]==31=>TestFilter - | | | | | += HashLoginService[Test Realm] - STARTED - | | | | | +- org.eclipse.jetty.security.authentication.FormAuthenticator@1fa291f2 - | | | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | | | +- org.eclipse.jetty.security.DefaultIdentityService@41917d6d - | | | | | | - | | | | | +> HashLoginService[Test Realm] - STARTED - | | | | | +> org.eclipse.jetty.security.DefaultIdentityService@41917d6d - | | | | | +> org.eclipse.jetty.security.authentication.FormAuthenticator@1fa291f2 - | | | | | +> [server-administrator, *, admin, user] - | | | | | +> /rego2/*={*={RoleInfo,C[server-administrator]}} - | | | | | +> *.htm={*={RoleInfo,C[server-administrator, *, admin, user]}} - | | | | | +> /dump/auth/ssl/*={*={RoleInfo[]}} - | | | | | +> /dump/auth/noaccess/*={*={RoleInfo,F,C[]}} - | | | | | +> /auth/*={*={RoleInfo,F,C[]}} - | | | | | +> /dump/auth/admin/*={*={RoleInfo,C[admin]}} - | | | | | +> /dump/auth/relax/*={GET={RoleInfo[]}, HEAD={RoleInfo[]}} - | | | | | +> /rego/*={*={RoleInfo,C[admin]}} - | | | | | +> /dump/auth/*={*={RoleInfo,C[server-administrator, *, admin, user]}} - | | | | | +> /={TRACE={RoleInfo,F,C[]}} - | | | | | +> /auth/relax.txt={GET={RoleInfo[]}, HEAD={RoleInfo[]}} - | | | | | +> /auth2/*={*={RoleInfo,C[server-administrator, *, admin, user]}} - | | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | += org.eclipse.jetty.servlet.ErrorPageErrorHandler@24bf7a86 - STARTED - | | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | +- org.eclipse.jetty.servlets.QoSFilter@6df3d1f5 - | | | | - | | | +> WebAppClassLoader=Test WebApp@3e2f3adb - | | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/WEB-INF/classes/ - | | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/WEB-INF/lib/jetty-continuation-{VERSION}.jar - | | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/WEB-INF/lib/jetty-http-{VERSION}.jar - | | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/WEB-INF/lib/jetty-io-{VERSION}.jar - | | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/WEB-INF/lib/jetty-servlets-{VERSION}.jar - | | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/WEB-INF/lib/jetty-util-{VERSION}.jar - | | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/WEB-INF/lib/websocket-api-9.0.2.v20130417.jar - | | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/WEB-INF/lib/websocket-servlet-9.0.2.v20130417.jar - | | | | +- startJarLoader@7194b34a - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-xml-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/servlet-api-3.0.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-http-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-continuation-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-server-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-security-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-servlet-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-webapp-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-deploy-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-client-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-jmx-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/com.sun.el-2.2.0.v201303151357.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.el-2.2.0.v201303151357.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp.jstl-1.2.0.v201105211821.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp-2.2.0.v201112011158.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.jasper.glassfish-2.2.2.v201112011158.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.taglibs.standard.glassfish-1.2.0.v201112081803.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.eclipse.jdt.core-3.8.2.v20130121.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/resources/ - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-api-9.0.2.v20130417.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-common-9.0.2.v20130417.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-server-9.0.2.v20130417.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-servlet-9.0.2.v20130417.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-util-{VERSION}.jar - | | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-io-{VERSION}.jar - | | | | +- sun.misc.Launcher$AppClassLoader@19d1b44b - | | | | +- file:/home/user/jetty-distribution-{VERSION}/start.jar - | | | | +- sun.misc.Launcher$ExtClassLoader@1693b52b - | | | +> org.eclipse.jetty.server.context.ManagedAttributes=QoSFilter,TransparentProxy.ThreadPool,TransparentProxy.HttpClient - | | | +> context-override-example=a context value - | | | +> javax.servlet.context.tempdir=/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any- - | | | +> org.apache.catalina.jsp_classpath=/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/WEB-INF/classes:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/WEB-INF/lib/jetty-continuation-{VERSION}.jar:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/WEB-INF/lib/jetty-http-{VERSION}.jar:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/WEB-INF/lib/jetty-io-{VERSION}.jar:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/WEB-INF/lib/jetty-servlets-{VERSION}.jar:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/WEB-INF/lib/jetty-util-{VERSION}.jar:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/WEB-INF/lib/websocket-api-9.0.2.v20130417.jar:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/WEB-INF/lib/websocket-servlet-9.0.2.v20130417.jar - | | | +> org.eclipse.jetty.server.webapp.ContainerIncludeJarPattern=.*/servlet-api-[^/]*\.jar$ - | | | +> QoSFilter=org.eclipse.jetty.servlets.QoSFilter@6df3d1f5 - | | | +> com.sun.jsp.taglibraryCache={} - | | | +> com.sun.jsp.tagFileJarUrlsCache={} - | | += o.e.j.w.WebAppContext@4ac92718{/proxy,file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any-/webapp/,AVAILABLE}{/xref-proxy.war} - STARTED - | | += org.eclipse.jetty.server.session.SessionHandler@5c25bf03 - STARTED - | | | += org.eclipse.jetty.server.session.HashSessionManager@33053093 - STARTED - | | | += org.eclipse.jetty.security.ConstraintSecurityHandler@3bab0b5a - STARTED - | | | | +- org.eclipse.jetty.security.DefaultAuthenticatorFactory@11ad5296 - | | | | += org.eclipse.jetty.servlet.ServletHandler@a08feeb - STARTED - | | | | | += default@5c13d641==org.eclipse.jetty.servlet.DefaultServlet,0,true - STARTED - | | | | | | +- maxCacheSize=256000000 - | | | | | | +- etags=true - | | | | | | +- dirAllowed=true - | | | | | | +- gzip=true - | | | | | | +- maxCachedFileSize=200000000 - | | | | | | +- redirectWelcome=false - | | | | | | +- acceptRanges=true - | | | | | | +- welcomeServlets=false - | | | | | | +- aliases=false - | | | | | | +- useFileMappedBuffer=true - | | | | | | +- maxCachedFiles=2048 - | | | | | +- [/]=>default - | | | | | += jsp@19c47==org.apache.jasper.servlet.JspServlet,0,true - STARTED - | | | | | | +- logVerbosityLevel=DEBUG - | | | | | | +- fork=false - | | | | | | +- com.sun.appserv.jsp.classpath=/home/user/jetty-distribution-{VERSION}/lib/jetty-xml-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/servlet-api-3.0.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-http-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-continuation-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-server-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-security-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-servlet-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-webapp-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-deploy-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-client-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-jmx-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/com.sun.el-2.2.0.v201303151357.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.el-2.2.0.v201303151357.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp.jstl-1.2.0.v201105211821.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp-2.2.0.v201112011158.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.jasper.glassfish-2.2.2.v201112011158.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.taglibs.standard.glassfish-1.2.0.v201112081803.jar:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.eclipse.jdt.core-3.8.2.v20130121.jar:/home/user/jetty-distribution-{VERSION}/resources:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-api-9.0.2.v20130417.jar:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-common-9.0.2.v20130417.jar:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-server-9.0.2.v20130417.jar:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-servlet-9.0.2.v20130417.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-util-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/lib/jetty-io-{VERSION}.jar:/home/user/jetty-distribution-{VERSION}/start.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/dnsns.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/localedata.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/sunec.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/sunjce_provider.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/sunpkcs11.jar:/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre/lib/ext/zipfs.jar:/opt/local/lib/libsvnjavahl-1.0.dylib:/System/Library/Java/Extensions/AppleScriptEngine.jar:/System/Library/Java/Extensions/dns_sd.jar:/System/Library/Java/Extensions/j3daudio.jar:/System/Library/Java/Extensions/j3dcore.jar:/System/Library/Java/Extensions/j3dutils.jar:/System/Library/Java/Extensions/jai_codec.jar:/System/Library/Java/Extensions/jai_core.jar:/System/Library/Java/Extensions/libAppleScriptEngine.jnilib:/System/Library/Java/Extensions/libJ3D.jnilib:/System/Library/Java/Extensions/libJ3DAudio.jnilib:/System/Library/Java/Extensions/libJ3DUtils.jnilib:/System/Library/Java/Extensions/libmlib_jai.jnilib:/System/Library/Java/Extensions/libQTJNative.jnilib:/System/Library/Java/Extensions/mlibwrapper_jai.jar:/System/Library/Java/Extensions/MRJToolkit.jar:/System/Library/Java/Extensions/QTJava.zip:/System/Library/Java/Extensions/vecmath.jar:/usr/lib/java/libjdns_sd.jnilib - | | | | | | +- scratchdir=/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any-/jsp - | | | | | | +- xpoweredBy=false - | | | | | +- [*.jsp, *.jspf, *.jspx, *.xsp, *.JSP, *.JSPF, *.JSPX, *.XSP]=>jsp - | | | | | += XrefTransparentProxy@b0222797==org.eclipse.jetty.proxy.ProxyServlet$Transparent,1,true - STARTED - | | | | | | +- proxyTo=http://download.eclipse.org/jetty/stable-9 - | | | | | | +- hostHeader=download.eclipse.org - | | | | | +- [/xref/*]=>XrefTransparentProxy - | | | | | += JavadocTransparentProxy@8ab9c012==org.eclipse.jetty.proxy.ProxyServlet$Transparent,1,true - STARTED - | | | | | | +- proxyTo=http://download.eclipse.org/jetty/stable-9 - | | | | | | +- hostHeader=download.eclipse.org - | | | | | +- [/apidocs/*]=>JavadocTransparentProxy - | | | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | | +~ HashLoginService[Test Realm] - STARTED - | | | | +- org.eclipse.jetty.security.DefaultIdentityService@d2539a6 - | | | | +- org.eclipse.jetty.security.authentication.BasicAuthenticator@5497fb72 - | | | | | - | | | | +> HashLoginService[Test Realm] - STARTED - | | | | +> org.eclipse.jetty.security.DefaultIdentityService@d2539a6 - | | | | +> org.eclipse.jetty.security.authentication.BasicAuthenticator@5497fb72 - | | | | +> [] - | | | | +> /={TRACE={RoleInfo,F,C[]}} - | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | += org.eclipse.jetty.servlet.ErrorPageErrorHandler@321f8d38 - STARTED - | | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | | | - | | +> WebAppClassLoader=Transparent Proxy WebApp@3570713d - | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any-/webapp/WEB-INF/classes/ - | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any-/webapp/WEB-INF/lib/jetty-client-{VERSION}.jar - | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any-/webapp/WEB-INF/lib/jetty-http-{VERSION}.jar - | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any-/webapp/WEB-INF/lib/jetty-io-{VERSION}.jar - | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any-/webapp/WEB-INF/lib/jetty-proxy-{VERSION}.jar - | | | +- file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any-/webapp/WEB-INF/lib/jetty-util-{VERSION}.jar - | | | +- startJarLoader@7194b34a - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-xml-{VERSION}.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/servlet-api-3.0.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-http-{VERSION}.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-continuation-{VERSION}.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-server-{VERSION}.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-security-{VERSION}.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-servlet-{VERSION}.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-webapp-{VERSION}.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-deploy-{VERSION}.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-client-{VERSION}.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-jmx-{VERSION}.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/com.sun.el-2.2.0.v201303151357.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.el-2.2.0.v201303151357.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp.jstl-1.2.0.v201105211821.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp-2.2.0.v201112011158.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.jasper.glassfish-2.2.2.v201112011158.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.taglibs.standard.glassfish-1.2.0.v201112081803.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.eclipse.jdt.core-3.8.2.v20130121.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/resources/ - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-api-9.0.2.v20130417.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-common-9.0.2.v20130417.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-server-9.0.2.v20130417.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-servlet-9.0.2.v20130417.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-util-{VERSION}.jar - | | | +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-io-{VERSION}.jar - | | | +- sun.misc.Launcher$AppClassLoader@19d1b44b - | | | +- file:/home/user/jetty-distribution-{VERSION}/start.jar - | | | +- sun.misc.Launcher$ExtClassLoader@1693b52b - | | +> javax.servlet.context.tempdir=/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any- - | | +> org.apache.catalina.jsp_classpath=/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any-/webapp/WEB-INF/classes:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any-/webapp/WEB-INF/lib/jetty-client-{VERSION}.jar:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any-/webapp/WEB-INF/lib/jetty-http-{VERSION}.jar:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any-/webapp/WEB-INF/lib/jetty-io-{VERSION}.jar:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any-/webapp/WEB-INF/lib/jetty-proxy-{VERSION}.jar:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any-/webapp/WEB-INF/lib/jetty-util-{VERSION}.jar - | | +> org.eclipse.jetty.server.webapp.ContainerIncludeJarPattern=.*/servlet-api-[^/]*\.jar$ - | | +> JavadocTransparentProxy.HttpClient=org.eclipse.jetty.client.HttpClient@580f016d - | | +> XrefTransparentProxy.HttpClient=org.eclipse.jetty.client.HttpClient@70c7e52b - | | +> com.sun.jsp.taglibraryCache={} - | | +> com.sun.jsp.tagFileJarUrlsCache={} - | += org.eclipse.jetty.server.handler.DefaultHandler@4de4926a - STARTED - | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | += org.eclipse.jetty.server.handler.RequestLogHandler@3dc087a2 - STARTED - | | += org.eclipse.jetty.server.AsyncNCSARequestLog@108a1cf6 - STARTED - | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - +- org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | +- [/rego/*]=>RegoTest=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=RegoTest,id=0 - | +- org.eclipse.jetty.security.DefaultAuthenticatorFactory@17d41d12=org.eclipse.jetty.security:context=test,type=defaultauthenticatorfactory,id=0 - | +- org.eclipse.jetty.server.session.HashSessionManager@1246f8d0=org.eclipse.jetty.server.session:context=test,type=hashsessionmanager,id=0 - | +- org.eclipse.jetty.security.ConstraintSecurityHandler@1890e38=org.eclipse.jetty.security:context=ROOT,type=constraintsecurityhandler,id=0 - | +- WSChat@99274454==com.acme.WebSocketChatServlet,1,true=org.eclipse.jetty.servlet:context=test,type=servletholder,name=WSChat,id=0 - | +- org.eclipse.jetty.deploy.DeploymentManager@c8e4be2=org.eclipse.jetty.deploy:type=deploymentmanager,id=0 - | +- org.eclipse.jetty.jmx.MBeanContainer@644a5ddd=org.eclipse.jetty.jmx:type=mbeancontainer,id=0 - | +- [/dump/gzip/*, *.txt]/[]==0=>GzipFilter=org.eclipse.jetty.servlet:context=test,type=filtermapping,name=GzipFilter,id=0 - | +- Hello@42628b2==com.acme.HelloWorld,1,true=org.eclipse.jetty.servlet:context=test,type=servletholder,name=Hello,id=0 - | +- [/]=>default=org.eclipse.jetty.servlet:context=xref-proxy,type=servletmapping,name=default,id=0 - | +- [/login/*]=>Login=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=Login,id=0 - | +- org.eclipse.jetty.server.handler.DefaultHandler@4de4926a=org.eclipse.jetty.server.handler:type=defaulthandler,id=0 - | +- org.eclipse.jetty.server.session.SessionHandler@5c25bf03=org.eclipse.jetty.server.session:context=xref-proxy,type=sessionhandler,id=0 - | +- [/ws/*]=>WSChat=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=WSChat,id=0 - | +- o.e.j.w.WebAppContext@6f01ba6f{/,file:/home/user/jetty-distribution-{VERSION}/webapps/ROOT/,AVAILABLE}{/ROOT}=org.eclipse.jetty.webapp:context=ROOT,type=webappcontext,id=0 - | +- o.e.j.w.WebAppContext@7ea88b1c{/async-rest,[file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/, jar:file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/lib/example-async-rest-jar-9.0.2.v20130417.jar!/META-INF/resources/],AVAILABLE}{/async-rest.war}=org.eclipse.jetty.webapp:context=async-rest,type=webappcontext,id=0 - | +- ServerConnector@3d0f282{HTTP/1.1}{0.0.0.0:9090}=org.eclipse.jetty.server:context=HTTP/1.1@3d0f282,type=serverconnector,id=0 - | +- org.eclipse.jetty.security.DefaultAuthenticatorFactory@6242c657=org.eclipse.jetty.security:context=ROOT,type=defaultauthenticatorfactory,id=0 - | +- JavadocTransparentProxy@8ab9c012==org.eclipse.jetty.proxy.ProxyServlet$Transparent,1,true=org.eclipse.jetty.servlet:context=xref-proxy,type=servletholder,name=JavadocTransparentProxy,id=0 - | +- [/dump/*, *.dump]=>Dump=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=Dump,id=0 - | +- [/jsp/foo/]=>foo.jsp=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=foo.jsp,id=0 - | +- org.eclipse.jetty.servlet.ServletHandler@46bac287=org.eclipse.jetty.servlet:context=async-rest,type=servlethandler,id=0 - | +- GzipFilter=org.eclipse.jetty.servlet:context=test,type=filterholder,name=GzipFilter,id=0 - | +- o.e.j.w.WebAppContext@4ac92718{/proxy,file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any-/webapp/,AVAILABLE}{/xref-proxy.war}=org.eclipse.jetty.webapp:context=xref-proxy,type=webappcontext,id=0 - | +- qtp1062680061{STARTED,10<=13<=200,i=1,q=0}=org.eclipse.jetty.util.thread:type=queuedthreadpool,id=0 - | +- org.eclipse.jetty.server.session.HashSessionManager@33053093=org.eclipse.jetty.server.session:context=xref-proxy,type=hashsessionmanager,id=0 - | +- org.eclipse.jetty.security.DefaultAuthenticatorFactory@52b12fef=org.eclipse.jetty.security:context=async-rest,type=defaultauthenticatorfactory,id=0 - | +- Login@462ff49==com.acme.LoginServlet,1,true=org.eclipse.jetty.servlet:context=test,type=servletholder,name=Login,id=0 - | +- org.eclipse.jetty.security.authentication.BasicAuthenticator@7b239469=org.eclipse.jetty.security.authentication:context=async-rest,type=basicauthenticator,id=0 - | +- MultiPart=org.eclipse.jetty.servlet:context=test,type=filterholder,name=MultiPart,id=0 - | +- default@5c13d641==org.eclipse.jetty.servlet.DefaultServlet,0,true=org.eclipse.jetty.servlet:context=xref-proxy,type=servletholder,name=default,id=0 - | +- default@5c13d641==org.eclipse.jetty.servlet.DefaultServlet,0,true=org.eclipse.jetty.servlet:context=ROOT,type=servletholder,name=default,id=0 - | +- default@5c13d641==org.eclipse.jetty.servlet.DefaultServlet,0,true=org.eclipse.jetty.servlet:context=async-rest,type=servletholder,name=default,id=0 - | +- default@5c13d641==org.eclipse.jetty.servlet.DefaultServlet,0,true=org.eclipse.jetty.servlet:context=test,type=servletholder,name=default,id=0 - | +- org.eclipse.jetty.server.session.HashSessionManager@746a95ae=org.eclipse.jetty.server.session:context=ROOT,type=hashsessionmanager,id=0 - | +- RegoTest2@849d6425==com.acme.RegTest,-1,false=org.eclipse.jetty.servlet:context=test,type=servletholder,name=RegoTest2,id=0 - | +- org.eclipse.jetty.server.ServerConnector$ServerConnectorManager@6f0ac4be=org.eclipse.jetty.server:context=HTTP/1.1@3d0f282,type=serverconnector$serverconnectormanager,id=0 - | +- [/]=>default=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=default,id=0 - | +- SecureMode@d45951da==com.acme.SecureModeServlet,1,true=org.eclipse.jetty.servlet:context=test,type=servletholder,name=SecureMode,id=0 - | +- org.eclipse.jetty.security.authentication.BasicAuthenticator@6b733b94=org.eclipse.jetty.security.authentication:context=ROOT,type=basicauthenticator,id=0 - | +- org.eclipse.jetty.server.session.SessionHandler@6dfb8d2e=org.eclipse.jetty.server.session:context=async-rest,type=sessionhandler,id=0 - | +- org.eclipse.jetty.security.DefaultIdentityService@41917d6d=org.eclipse.jetty.security:context=test,type=defaultidentityservice,id=0 - | +- jsp@19c47==org.apache.jasper.servlet.JspServlet,0,true=org.eclipse.jetty.servlet:context=xref-proxy,type=servletholder,name=jsp,id=0 - | +- jsp@19c47==org.apache.jasper.servlet.JspServlet,0,true=org.eclipse.jetty.servlet:context=ROOT,type=servletholder,name=jsp,id=0 - | +- jsp@19c47==org.apache.jasper.servlet.JspServlet,0,true=org.eclipse.jetty.servlet:context=async-rest,type=servletholder,name=jsp,id=0 - | +- jsp@19c47==org.apache.jasper.servlet.JspServlet,0,true=org.eclipse.jetty.servlet:context=test,type=servletholder,name=jsp,id=0 - | +- [/*]/[]==31=>TestFilter=org.eclipse.jetty.servlet:context=test,type=filtermapping,name=TestFilter,id=0 - | +- org.eclipse.jetty.server.session.HashSessionManager@6cb83869=org.eclipse.jetty.server.session:context=async-rest,type=hashsessionmanager,id=0 - | +- org.eclipse.jetty.io.ArrayByteBufferPool@30ad8942=org.eclipse.jetty.io:context=HTTP/1.1@3d0f282,type=arraybytebufferpool,id=0 - | +- [/cgi-bin/*]=>CGI=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=CGI,id=0 - | +- org.eclipse.jetty.server.handler.HandlerCollection@58b37561=org.eclipse.jetty.server.handler:type=handlercollection,id=0 - | +- Session@d9891a76==com.acme.SessionDump,5,true=org.eclipse.jetty.servlet:context=test,type=servletholder,name=Session,id=0 - | +- org.eclipse.jetty.servlet.ServletHandler@a08feeb=org.eclipse.jetty.servlet:context=xref-proxy,type=servlethandler,id=0 - | +- org.eclipse.jetty.util.thread.ScheduledExecutorScheduler@725f5=org.eclipse.jetty.util.thread:type=scheduledexecutorscheduler,id=0 - | +- [/*]/[]==0=>QoSFilter=org.eclipse.jetty.servlet:context=test,type=filtermapping,name=QoSFilter,id=0 - | +- org.eclipse.jetty.server.session.SessionHandler@5a770658=org.eclipse.jetty.server.session:context=ROOT,type=sessionhandler,id=0 - | +- org.eclipse.jetty.server.session.SessionHandler@336abd81=org.eclipse.jetty.server.session:context=test,type=sessionhandler,id=0 - | +- o.e.j.s.h.ContextHandler@7b2dffdf{/javadoc,file:/home/user/jetty-distribution-{VERSION}/javadoc,AVAILABLE}=org.eclipse.jetty.server.handler:context=javadoc,type=contexthandler,id=0 - | +- org.eclipse.jetty.servlets.QoSFilter@6df3d1f5=org.eclipse.jetty.servlets:context=test,type=qosfilter,id=0 - | +- [*.more]=>Dump=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=Dump,id=1 - | +- Dump@20ae14==com.acme.Dump,1,true=org.eclipse.jetty.servlet:context=test,type=servletholder,name=Dump,id=0 - | +- HttpConnectionFactory@5e47b1b9{HTTP/1.1}=org.eclipse.jetty.server:context=HTTP/1.1@3d0f282,type=httpconnectionfactory,id=0 - | +- org.eclipse.jetty.servlet.ServletHandler@debac27=org.eclipse.jetty.servlet:context=ROOT,type=servlethandler,id=0 - | +- [*.jsp, *.jspf, *.jspx, *.xsp, *.JSP, *.JSPF, *.JSPX, *.XSP]=>jsp=org.eclipse.jetty.servlet:context=xref-proxy,type=servletmapping,name=jsp,id=0 - | +- org.eclipse.jetty.server.handler.MovedContextHandler$Redirector@2a4200d3=org.eclipse.jetty.server.handler:context=oldContextPath,type=movedcontexthandler$redirector,id=0 - | +- TestFilter=org.eclipse.jetty.servlet:context=test,type=filterholder,name=TestFilter,id=0 - | +- Rewrite@a4dac96c==com.acme.RewriteServlet,-1,false=org.eclipse.jetty.servlet:context=test,type=servletholder,name=Rewrite,id=0 - | +- [/dispatch/*]=>Dispatch=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=Dispatch,id=0 - | +- [/testSerial]=>SerialRestServlet=org.eclipse.jetty.servlet:context=async-rest,type=servletmapping,name=SerialRestServlet,id=0 - | +- org.eclipse.jetty.servlet.ErrorPageErrorHandler@24bf7a86=org.eclipse.jetty.servlet:context=test,type=errorpageerrorhandler,id=0 - | +- [/secureMode/*]=>SecureMode=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=SecureMode,id=0 - | +- [/]=>default=org.eclipse.jetty.servlet:context=async-rest,type=servletmapping,name=default,id=0 - | +- Dispatch@14d3a89a==com.acme.DispatchServlet,1,true=org.eclipse.jetty.servlet:context=test,type=servletholder,name=Dispatch,id=0 - | +- org.eclipse.jetty.server.handler.ContextHandlerCollection@64c6e290=org.eclipse.jetty.server.handler:type=contexthandlercollection,id=0 - | +- org.eclipse.jetty.security.ConstraintSecurityHandler@2848c90e=org.eclipse.jetty.security:context=async-rest,type=constraintsecurityhandler,id=0 - | +- [/rego2/*]=>RegoTest2=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=RegoTest2,id=0 - | +- [/rewritten/*, /redirected/*]=>Rewrite=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=Rewrite,id=0 - | +- org.eclipse.jetty.servlet.ServletHandler@5034037e=org.eclipse.jetty.servlet:context=test,type=servlethandler,id=0 - | +- org.eclipse.jetty.servlet.ErrorPageErrorHandler@3c121009=org.eclipse.jetty.servlet:context=async-rest,type=errorpageerrorhandler,id=0 - | +- sun.nio.ch.ServerSocketChannelImpl[/0:0:0:0:0:0:0:0:9090]=sun.nio.ch:context=HTTP/1.1@3d0f282,type=serversocketchannelimpl,id=0 - | +- org.eclipse.jetty.security.ConstraintSecurityHandler@7179290f=org.eclipse.jetty.security:context=test,type=constraintsecurityhandler,id=0 - | +- org.eclipse.jetty.server.session.HashSessionIdManager@289eb857=org.eclipse.jetty.server.session:type=hashsessionidmanager,id=0 - | +- org.eclipse.jetty.security.authentication.BasicAuthenticator@5497fb72=org.eclipse.jetty.security.authentication:context=xref-proxy,type=basicauthenticator,id=0 - | +- org.eclipse.jetty.security.DefaultAuthenticatorFactory@11ad5296=org.eclipse.jetty.security:context=xref-proxy,type=defaultauthenticatorfactory,id=0 - | +- [/dump/*]/[]==0=>MultiPart=org.eclipse.jetty.servlet:context=test,type=filtermapping,name=MultiPart,id=0 - | +- o.e.j.s.h.MovedContextHandler@5e0c8d24{/oldContextPath,null,AVAILABLE}=org.eclipse.jetty.server.handler:context=oldContextPath,type=movedcontexthandler,id=0 - | +- QoSFilter=org.eclipse.jetty.servlet:context=test,type=filterholder,name=QoSFilter,id=0 - | +- org.eclipse.jetty.security.authentication.FormAuthenticator@1fa291f2=org.eclipse.jetty.security.authentication:context=test,type=formauthenticator,id=0 - | +- o.e.j.w.WebAppContext@716d9094{/test,file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/,AVAILABLE}{/test.war}=org.eclipse.jetty.webapp:context=test,type=webappcontext,id=0 - | +- [/]=>default=org.eclipse.jetty.servlet:context=ROOT,type=servletmapping,name=default,id=0 - | +- [/hello/*]=>Hello=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=Hello,id=0 - | +- [/chat/*]=>Chat=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=Chat,id=0 - | +- [/testAsync]=>AsyncRestServlet=org.eclipse.jetty.servlet:context=async-rest,type=servletmapping,name=AsyncRestServlet,id=0 - | +- org.eclipse.jetty.security.DefaultIdentityService@d2539a6=org.eclipse.jetty.security:context=async-rest,type=defaultidentityservice,id=0 - | +- org.eclipse.jetty.server.handler.RequestLogHandler@3dc087a2=org.eclipse.jetty.server.handler:type=requestloghandler,id=0 - | +- org.eclipse.jetty.servlet.ErrorPageErrorHandler@321f8d38=org.eclipse.jetty.servlet:context=xref-proxy,type=errorpageerrorhandler,id=0 - | +- org.eclipse.jetty.server.handler.ResourceHandler@8f9c8a7=org.eclipse.jetty.server.handler:context=javadoc,type=resourcehandler,id=0 - | +- CGI@10465==org.eclipse.jetty.servlets.CGI,1,true=org.eclipse.jetty.servlet:context=test,type=servletholder,name=CGI,id=0 - | +- SerialRestServlet@461411d==org.eclipse.jetty.example.asyncrest.SerialRestServlet,-1,false=org.eclipse.jetty.servlet:context=async-rest,type=servletholder,name=SerialRestServlet,id=0 - | +- HashLoginService[Test Realm]=org.eclipse.jetty.security:type=hashloginservice,id=0 - | +- AsyncRestServlet@73eb9bd5==org.eclipse.jetty.example.asyncrest.AsyncRestServlet,-1,false=org.eclipse.jetty.servlet:context=async-rest,type=servletholder,name=AsyncRestServlet,id=0 - | +- org.eclipse.jetty.server.Server@76f08fe1=org.eclipse.jetty.server:type=server,id=0 - | +- org.eclipse.jetty.servlet.ErrorPageErrorHandler@3c41a9ce=org.eclipse.jetty.servlet:context=ROOT,type=errorpageerrorhandler,id=0 - | +- [/apidocs/*]=>JavadocTransparentProxy=org.eclipse.jetty.servlet:context=xref-proxy,type=servletmapping,name=JavadocTransparentProxy,id=0 - | +- Chat@200778==com.acme.ChatServlet,1,true=org.eclipse.jetty.servlet:context=test,type=servletholder,name=Chat,id=0 - | +- [/cookie/*]=>Cookie=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=Cookie,id=0 - | +- [/session/*]=>Session=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=Session,id=0 - | +- org.eclipse.jetty.deploy.providers.WebAppProvider@7b26b7df=org.eclipse.jetty.deploy.providers:type=webappprovider,id=0 - | +- org.eclipse.jetty.server.AsyncNCSARequestLog@108a1cf6=org.eclipse.jetty.server:type=asyncncsarequestlog,id=0 - | +- [*.jsp, *.jspf, *.jspx, *.xsp, *.JSP, *.JSPF, *.JSPX, *.XSP]=>jsp=org.eclipse.jetty.servlet:context=test,type=servletmapping,name=jsp,id=0 - | +- [*.jsp, *.jspf, *.jspx, *.xsp, *.JSP, *.JSPF, *.JSPX, *.XSP]=>jsp=org.eclipse.jetty.servlet:context=ROOT,type=servletmapping,name=jsp,id=0 - | +- HashLoginService[Test Realm]=org.eclipse.jetty.security:context=test,type=hashloginservice,id=0 - | +- [*.jsp, *.jspf, *.jspx, *.xsp, *.JSP, *.JSPF, *.JSPX, *.XSP]=>jsp=org.eclipse.jetty.servlet:context=async-rest,type=servletmapping,name=jsp,id=0 - | +- foo.jsp@d7583f1f==org.apache.jasper.servlet.JspServlet,-1,false=org.eclipse.jetty.servlet:context=test,type=servletholder,name=foo.jsp,id=0 - | +- RegoTest@dafcd1ad==com.acme.RegTest,-1,false=org.eclipse.jetty.servlet:context=test,type=servletholder,name=RegoTest,id=0 - | +- [/xref/*]=>XrefTransparentProxy=org.eclipse.jetty.servlet:context=xref-proxy,type=servletmapping,name=XrefTransparentProxy,id=0 - | +- org.eclipse.jetty.security.ConstraintSecurityHandler@3bab0b5a=org.eclipse.jetty.security:context=xref-proxy,type=constraintsecurityhandler,id=0 - | +- HttpConfiguration@703b16bb{32768,8192/8192,https://:8443,[]}=org.eclipse.jetty.server:context=HTTP/1.1@3d0f282,type=httpconfiguration,id=0 - | +- org.eclipse.jetty.util.log.Log@dda4f7b=org.eclipse.jetty.util.log:type=log,id=0 - | +- Cookie@78a4f684==com.acme.CookieDump,1,true=org.eclipse.jetty.servlet:context=test,type=servletholder,name=Cookie,id=0 - | +- XrefTransparentProxy@b0222797==org.eclipse.jetty.proxy.ProxyServlet$Transparent,1,true=org.eclipse.jetty.servlet:context=xref-proxy,type=servletholder,name=XrefTransparentProxy,id=0 - +- org.eclipse.jetty.util.log.Log@dda4f7b - += ServerConnector@3d0f282{HTTP/1.1}{0.0.0.0:9090} - STARTED - | +~ org.eclipse.jetty.server.Server@76f08fe1 - STARTING - | +~ qtp1062680061{STARTED,10<=13<=200,i=1,q=0} - STARTED - | +~ org.eclipse.jetty.util.thread.ScheduledExecutorScheduler@725f5 - STARTED - | +- org.eclipse.jetty.io.ArrayByteBufferPool@30ad8942 - | += HttpConnectionFactory@5e47b1b9{HTTP/1.1} - STARTED - | | +- HttpConfiguration@703b16bb{32768,8192/8192,https://:8443,[]} - | | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | += org.eclipse.jetty.server.ServerConnector$ServerConnectorManager@6f0ac4be - STARTED - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector@61454787 keys=0 selected=0 id=0 - | | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:459) - | | | +- sun.nio.ch.KQueueSelectorImpl@a0c508b keys=0 - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector@2e7bdad4 keys=0 selected=0 id=1 - | | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:459) - | | | +- sun.nio.ch.KQueueSelectorImpl@5825168 keys=0 - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector@2eae85ab keys=0 selected=0 id=2 - | | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:459) - | | | +- sun.nio.ch.KQueueSelectorImpl@6faa85f6 keys=0 - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector@244112c0 keys=0 selected=0 id=3 - | | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:459) - | | | +- sun.nio.ch.KQueueSelectorImpl@10c6f695 keys=0 - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector@7666b8cd keys=0 selected=0 id=4 - | | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:459) - | | | +- sun.nio.ch.KQueueSelectorImpl@17836c59 keys=0 - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector@353e531e keys=0 selected=0 id=5 - | | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:459) - | | | +- sun.nio.ch.KQueueSelectorImpl@2095f259 keys=0 - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector@5459c1c5 keys=0 selected=0 id=6 - | | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:459) - | | | +- sun.nio.ch.KQueueSelectorImpl@142c7195 keys=0 - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector@71d4f78b keys=0 selected=0 id=7 - | | +- org.eclipse.jetty.io.SelectorManager$ManagedSelector.select(SelectorManager.java:459) - | | +- sun.nio.ch.KQueueSelectorImpl@16bdab45 keys=0 - | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - | +- sun.nio.ch.ServerSocketChannelImpl[/0:0:0:0:0:0:0:0:9090] - += org.eclipse.jetty.deploy.DeploymentManager@c8e4be2 - STARTED - | +~ org.eclipse.jetty.deploy.providers.WebAppProvider@7b26b7df - STARTED - | +~ org.eclipse.jetty.jmx.MBeanContainer@644a5ddd - +~ HashLoginService[Test Realm] - STARTED - += org.eclipse.jetty.server.session.HashSessionIdManager@289eb857 - STARTED - | - +> startJarLoader@7194b34a - +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-xml-{VERSION}.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/servlet-api-3.0.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-http-{VERSION}.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-continuation-{VERSION}.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-server-{VERSION}.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-security-{VERSION}.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-servlet-{VERSION}.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-webapp-{VERSION}.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-deploy-{VERSION}.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-client-{VERSION}.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-jmx-{VERSION}.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/com.sun.el-2.2.0.v201303151357.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.el-2.2.0.v201303151357.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp.jstl-1.2.0.v201105211821.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/javax.servlet.jsp-2.2.0.v201112011158.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.jasper.glassfish-2.2.2.v201112011158.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.apache.taglibs.standard.glassfish-1.2.0.v201112081803.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jsp/org.eclipse.jdt.core-3.8.2.v20130121.jar - +- file:/home/user/jetty-distribution-{VERSION}/resources/ - +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-api-9.0.2.v20130417.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-common-9.0.2.v20130417.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-server-9.0.2.v20130417.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/websocket/websocket-servlet-9.0.2.v20130417.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-util-{VERSION}.jar - +- file:/home/user/jetty-distribution-{VERSION}/lib/jetty-io-{VERSION}.jar - +- sun.misc.Launcher$AppClassLoader@19d1b44b - +- file:/home/user/jetty-distribution-{VERSION}/start.jar - +- sun.misc.Launcher$ExtClassLoader@1693b52b -2013-04-29 14:38:39.422:INFO:oejs.Server:Thread-2: Graceful shutdown org.eclipse.jetty.server.Server@76f08fe1 by Mon Apr 29 14:38:44 CDT 2013 -2013-04-29 14:38:39.429:INFO:oejs.ServerConnector:Thread-2: Stopped ServerConnector@3d0f282{HTTP/1.1}{0.0.0.0:9090} -2013-04-29 14:38:39.444:INFO:oejsl.ELContextCleaner:Thread-2: javax.el.BeanELResolver purged -2013-04-29 14:38:39.444:INFO:oejsh.ContextHandler:Thread-2: stopped o.e.j.w.WebAppContext@4ac92718{/proxy,file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-xref-proxy.war-_xref-proxy-any-/webapp/,UNAVAILABLE}{/xref-proxy.war} -2013-04-29 14:38:39.447:INFO:oejsl.ELContextCleaner:Thread-2: javax.el.BeanELResolver purged -2013-04-29 14:38:39.447:INFO:oejsh.ContextHandler:Thread-2: stopped o.e.j.w.WebAppContext@716d9094{/test,file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-test.war-_test-any-/webapp/,UNAVAILABLE}{/test.war} -2013-04-29 14:38:39.455:INFO:oejsh.ContextHandler:Thread-2: stopped o.e.j.s.h.ContextHandler@7b2dffdf{/javadoc,file:/home/user/jetty-distribution-{VERSION}/javadoc,UNAVAILABLE} -2013-04-29 14:38:39.456:INFO:oejsl.ELContextCleaner:Thread-2: javax.el.BeanELResolver purged -2013-04-29 14:38:39.456:INFO:oejsh.ContextHandler:Thread-2: stopped o.e.j.w.WebAppContext@6f01ba6f{/,file:/home/user/jetty-distribution-{VERSION}/webapps/ROOT/,UNAVAILABLE}{/ROOT} -2013-04-29 14:38:39.456:INFO:oejsh.ContextHandler:Thread-2: stopped o.e.j.s.h.MovedContextHandler@5e0c8d24{/oldContextPath,null,UNAVAILABLE} -2013-04-29 14:38:39.457:INFO:oejsl.ELContextCleaner:Thread-2: javax.el.BeanELResolver purged -2013-04-29 14:38:39.457:INFO:oejsh.ContextHandler:Thread-2: stopped o.e.j.w.WebAppContext@7ea88b1c{/async-rest,[file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/, jar:file:/private/var/folders/br/kbs2g3753c54wmv4j31pnw5r0000gn/T/jetty-0.0.0.0-9090-async-rest.war-_async-rest-any-/webapp/WEB-INF/lib/example-async-rest-jar-9.0.2.v20130417.jar!/META-INF/resources/],UNAVAILABLE}{/async-rest.war} -.... diff --git a/jetty-documentation/src/main/asciidoc/administration/logging/jetty-server-dump.adoc b/jetty-documentation/src/main/asciidoc/administration/logging/jetty-server-dump.adoc new file mode 100644 index 000000000000..103e0ba3176d --- /dev/null +++ b/jetty-documentation/src/main/asciidoc/administration/logging/jetty-server-dump.adoc @@ -0,0 +1,189 @@ +// +// ======================================================================== +// Copyright (c) 1995-2020 Mort Bay Consulting Pty Ltd and others. +// ======================================================================== +// All rights reserved. This program and the accompanying materials +// are made available under the terms of the Eclipse Public License v1.0 +// and Apache License v2.0 which accompanies this distribution. +// +// The Eclipse Public License is available at +// http://www.eclipse.org/legal/epl-v10.html +// +// The Apache License v2.0 is available at +// http://www.opensource.org/licenses/apache2.0.php +// +// You may elect to redistribute this code under either of these licenses. +// ======================================================================== +// + +[[jetty-server-dump]] +=== Jetty Server Dump + +The dump feature in Jetty provides a snapshot of the bean containment tree of the main Jetty components together with a summary of their configuration. This includes threadpool, connectors, contexts, webapplications, servlets and so forth. + +[[configuring-dump-feature]] +==== Configuring the Jetty Server Dump + +You can request that Jetty do a dump immediately after starting and just before stopping by calling the appropriate setters on the `Server` instance. +For embedded usage this can be used by calling the setters directly. +```java +server.setDumpAfterStart(true); +server.setDumpBeforeStop(true); +``` + +Standalone Jetty uses two properties to control this behaviour which are referenced in `jetty.xml` to call these setters. +These properties are `jetty.server.dumpAfterStart` and `jetty.server.dumpBeforeStop`. + +These can be temporarily enabled by supplying these properties as command line arguments, +or they can be enabled via the `server.ini` file (see xref:quick-start-configure[]). +``` +java -jar $JETTY_HOME/start.jar jetty.server.dumpAfterStart=true jetty.server.dumpBeforeStop=true +``` + +[[extra-threadpool-info]] +==== Extra ThreadPool Information + +To get maximum detail from the `QueuedThreadPool` in the dump, you need to `setDetailDump(true)` on any instances of `QueuedThreadPool` you are using. +This extra detail in the detailed dump consists of full stack traces for every running thread, and a list of queued jobs waiting to be run. + +For embedded usage this can be used by calling the setters directly. +```java +threadPool.setDetailedDump(true); +``` + +For standalone jetty you can enable the `threadpool` module and configure the `jetty.threadPool.detailedDump` property. +See xref:startup-modules[] for information on how to enable a module. +This same property can also be set via the command line the same as the server dump property. + +[[dump-tool-via-jmx]] +==== Using the Dump Feature via JMX + +The `dump` method is on the Server instance and many of its nested components (Handlers, Connectors, and so forth). +Dumps may be obtained by calling these methods either in code or via JMX (see xref:using-jmx[]). + +The Server MBean has a `dump()` method, which dumps everything, plus a `dumpStdErr()` operation that dumps to StdErr rather than replying to JConsole. + +[[examing-jetty-distro-dump]] +==== Explanation of the Dump Key + +- `+- bean` is a java POJO that is contained by the parent object as a bean added with the addBean method. +- `+= managed` is a bean that is also a LifeCycle that is started and stopped with the parent object. +- `+~ unmanaged` is a bean that is also a LifeCycle that is started and stopped with the parent object. It is typically shared with other objects (hence its children are not dumped). +- `+? auto` is a bean that has been added to an unstarted parent. If it is a LifeCycle that is not started when the parent is started, then it is started and becomes a managed bean, otherwise it becomes either unmanaged or just a bean. +- `+: iterable` is an object that is contained within an iterable field of the parent (eg a list, set etc). +- `+] array` is an object that is contained within an array field of the parent. +- `+@ map` is an object that is contained within an map field of the parent. +- `+> undefined` is an object that is contained within the parent by an undefined relationship. + +==== Jetty Server Dump Example + +This is a dump of the OneServletContext embedded example with extra threadpool information: + +.... +Server@59906517{STARTED}[9.4.32-SNAPSHOT] - STARTED ++= QueuedThreadPool[qtp1740189450]@67b92f0a{STARTED,8<=8<=200,i=5,r=4,q=0}[ReservedThreadExecutor@77e4c80f{s=0/4,p=0}] - STARTED +| += ReservedThreadExecutor@77e4c80f{s=0/4,p=0} - STARTED +| +> threads size=8 +| | +> 12 qtp1740189450-12 SELECTING RUNNABLE 5 +| | +> 14 qtp1740189450-14-acceptor-0@4c78251c-ServerConnector@76707e36{HTTP/1.1, (http/1.1)}{0.0.0.0:8080} ACCEPTING RUNNABLE 3 +| | +> 16 qtp1740189450-16 IDLE TIMED_WAITING 5 +| | +> 18 qtp1740189450-18 IDLE TIMED_WAITING 5 +| | +> 15 qtp1740189450-15 SELECTING RUNNABLE 5 +| | +> 19 qtp1740189450-19 IDLE TIMED_WAITING 5 +| | +> 17 qtp1740189450-17 IDLE TIMED_WAITING 5 +| | +> 13 qtp1740189450-13 IDLE TIMED_WAITING 5 +| +> jobs size=0 ++= ServerConnector@76707e36{HTTP/1.1, (http/1.1)}{0.0.0.0:8080} - STARTED +| +~ Server@59906517{STARTED}[9.4.32-SNAPSHOT] - STARTED +| +~ QueuedThreadPool[qtp1740189450]@67b92f0a{STARTED,8<=8<=200,i=5,r=4,q=0}[ReservedThreadExecutor@77e4c80f{s=0/4,p=0}] - STARTED +| += ScheduledExecutorScheduler@7fe8ea47{STARTED} - STARTED +| +- org.eclipse.jetty.io.ArrayByteBufferPool@226a82c4 +| += HttpConnectionFactory@711f39f9[HTTP/1.1] - STARTED +| | +- HttpConfiguration@731f8236{32768/8192,8192/8192,https://:0,[]} +| | +> customizers size=0 +| | +> formEncodedMethods size=2 +| | | +> POST +| | | +> PUT +| | +> outputBufferSize=32768 +| | +> outputAggregationSize=8192 +| | +> requestHeaderSize=8192 +| | +> responseHeaderSize=8192 +| | +> headerCacheSize=1024 +| | +> secureScheme=https +| | +> securePort=0 +| | +> idleTimeout=-1 +| | +> blockingTimeout=-1 +| | +> sendDateHeader=true +| | +> sendServerVersion=true +| | +> sendXPoweredBy=false +| | +> delayDispatchUntilContent=true +| | +> persistentConnectionsEnabled=true +| | +> maxErrorDispatches=10 +| | +> minRequestDataRate=0 +| | +> minResponseDataRate=0 +| | +> cookieCompliance=RFC6265 +| | +> setRequestCookieCompliance=RFC6265 +| | +> notifyRemoteAsyncErrors=true +| | +> relativeRedirectAllowed=false +| += SelectorManager@ServerConnector@76707e36{HTTP/1.1, (http/1.1)}{0.0.0.0:8080} - STARTED +| | += ManagedSelector@564718df{STARTED} id=0 keys=0 selected=0 updates=0 - STARTED +| | | += EatWhatYouKill@51b7e5df/SelectorProducer@18a70f16/PRODUCING/p=false/QueuedThreadPool[qtp1740189450]@67b92f0a{STARTED,8<=8<=200,i=5,r=4,q=0}[ReservedThreadExecutor@77e4c80f{s=0/4,p=0}][pc=0,pic=0,pec=0,epc=0]@2020-08-26T08:51:02.711784+10:00 - STARTED +| | | | +- SelectorProducer@18a70f16 +| | | | +~ QueuedThreadPool[qtp1740189450]@67b92f0a{STARTED,8<=8<=200,i=5,r=4,q=0}[ReservedThreadExecutor@77e4c80f{s=0/4,p=0}] - STARTED +| | | +> updates @ 2020-08-26T08:51:02.705944+10:00 size=0 +| | | +> keys @ 2020-08-26T08:51:02.706914+10:00 size=0 +| | += ManagedSelector@62e136d3{STARTED} id=1 keys=0 selected=0 updates=0 - STARTED +| | += EatWhatYouKill@c8e4bb0/SelectorProducer@6279cee3/PRODUCING/p=false/QueuedThreadPool[qtp1740189450]@67b92f0a{STARTED,8<=8<=200,i=5,r=4,q=0}[ReservedThreadExecutor@77e4c80f{s=0/4,p=0}][pc=0,pic=0,pec=0,epc=0]@2020-08-26T08:51:02.717119+10:00 - STARTED +| | | +- SelectorProducer@6279cee3 +| | | +~ QueuedThreadPool[qtp1740189450]@67b92f0a{STARTED,8<=8<=200,i=5,r=4,q=0}[ReservedThreadExecutor@77e4c80f{s=0/4,p=0}] - STARTED +| | +> updates @ 2020-08-26T08:51:02.715887+10:00 size=0 +| | +> keys @ 2020-08-26T08:51:02.716158+10:00 size=0 +| +- sun.nio.ch.ServerSocketChannelImpl[/0:0:0:0:0:0:0:0:8080] +| +- qtp1740189450-14-acceptor-0@4c78251c-ServerConnector@76707e36{HTTP/1.1, (http/1.1)}{0.0.0.0:8080} ++= AttributeContainerMap@4206a205{size=0} - STARTED ++= o.e.j.s.ServletContextHandler@4ba2ca36{/,file:///tmp/,AVAILABLE} - STARTED +| += org.eclipse.jetty.server.session.SessionHandler2007331442==dftMaxIdleSec=-1 - STARTED +| | += ServletHandler@29ba4338{STARTED} - STARTED +| | | +> listeners ServletHandler@29ba4338{STARTED} size=2 +| | | | +> ListenerHolder@57175e74{STARTED}: org.eclipse.jetty.embedded.OneServletContext$InitListener - STARTED +| | | | +> ListenerHolder@7bb58ca3{STARTED}: org.eclipse.jetty.embedded.OneServletContext$RequestListener - STARTED +| | | +> filters ServletHandler@29ba4338{STARTED} size=2 +| | | | +> org.eclipse.jetty.embedded.OneServletContext$TestFilter-29b5cd00@29b5cd00==org.eclipse.jetty.embedded.OneServletContext$TestFilter,inst=true,async=true - STARTED +| | | | | +> org.eclipse.jetty.embedded.OneServletContext$TestFilter@c540f5a +| | | | +> org.eclipse.jetty.embedded.OneServletContext$TestFilter-7113b13f@7113b13f==org.eclipse.jetty.embedded.OneServletContext$TestFilter,inst=true,async=true - STARTED +| | | | +> org.eclipse.jetty.embedded.OneServletContext$TestFilter@770c2e6b +| | | +> filterMappings ServletHandler@29ba4338{STARTED} size=2 +| | | | +> [/test/*]/[]/[REQUEST]=>org.eclipse.jetty.embedded.OneServletContext$TestFilter-29b5cd00 +| | | | +> [*.test]/[]/[REQUEST, ASYNC]=>org.eclipse.jetty.embedded.OneServletContext$TestFilter-7113b13f +| | | +> servlets ServletHandler@29ba4338{STARTED} size=3 +| | | | +> org.eclipse.jetty.embedded.HelloServlet-6b57696f@99887e98==org.eclipse.jetty.embedded.HelloServlet,jsp=null,order=-1,inst=false,async=true - STARTED +| | | | | +> class org.eclipse.jetty.embedded.HelloServlet +| | | | +> debug@5b09653==org.eclipse.jetty.embedded.DumpServlet,jsp=null,order=-1,inst=false,async=true - STARTED +| | | | | +> class org.eclipse.jetty.embedded.DumpServlet +| | | | +> org.eclipse.jetty.servlet.DefaultServlet-38bc8ab5@f1bd2681==org.eclipse.jetty.servlet.DefaultServlet,jsp=null,order=-1,inst=false,async=true - STARTED +| | | | +> class org.eclipse.jetty.servlet.DefaultServlet +| | | +> servletMappings ServletHandler@29ba4338{STARTED} size=4 +| | | +> [/hello/*]=>org.eclipse.jetty.embedded.HelloServlet-6b57696f +| | | +> [/dump/*]=>debug +| | | +> [*.dump]=>debug +| | | +> [/]=>org.eclipse.jetty.servlet.DefaultServlet-38bc8ab5 +| | += org.eclipse.jetty.server.session.DefaultSessionCache@6328d34a[evict=-1,removeUnloadable=false,saveOnCreate=false,saveOnInactiveEvict=false] - STARTED +| | | += org.eclipse.jetty.server.session.NullSessionDataStore@145eaa29[passivating=false,graceSec=3600] - STARTED +| | +~ DefaultSessionIdManager@15bb6bea{STARTED}[worker=node0] - STARTED +| +> No ClassLoader +| +> eventListeners o.e.j.s.ServletContextHandler@4ba2ca36{/,file:///tmp/,AVAILABLE} size=2 +| | +> org.eclipse.jetty.embedded.OneServletContext$InitListener@8b96fde +| | +> org.eclipse.jetty.embedded.OneServletContext$RequestListener@2d2e5f00 +| +> handler attributes o.e.j.s.ServletContextHandler@4ba2ca36{/,file:///tmp/,AVAILABLE} size=1 +| | +> org.eclipse.jetty.server.Executor=QueuedThreadPool[qtp1740189450]@67b92f0a{STARTED,8<=8<=200,i=5,r=4,q=0}[ReservedThreadExecutor@77e4c80f{s=0/4,p=0}] +| +> context attributes o.e.j.s.ServletContextHandler@4ba2ca36{/,file:///tmp/,AVAILABLE} size=2 +| | +> org.eclipse.jetty.util.DecoratedObjectFactory=org.eclipse.jetty.util.DecoratedObjectFactory[decorators=1] +| | +> X-Init=true +| +> initparams o.e.j.s.ServletContextHandler@4ba2ca36{/,file:///tmp/,AVAILABLE} size=0 ++= ErrorHandler@2ea6137{STARTED} - STARTED ++= DefaultSessionIdManager@15bb6bea{STARTED}[worker=node0] - STARTED +| += HouseKeeper@3439f68d{STARTED}[interval=660000, ownscheduler=true] - STARTED ++> jdk.internal.loader.ClassLoaders$AppClassLoader@2c13da15 + +> jdk.internal.loader.ClassLoaders$PlatformClassLoader@41ee392b +key: +- bean, += managed, +~ unmanaged, +? auto, +: iterable, +] array, +@ map, +> undefined +.... diff --git a/jetty-documentation/src/main/asciidoc/administration/startup/start-jar.adoc b/jetty-documentation/src/main/asciidoc/administration/startup/start-jar.adoc index ba4d96a34d3b..12b2651eeab0 100644 --- a/jetty-documentation/src/main/asciidoc/administration/startup/start-jar.adoc +++ b/jetty-documentation/src/main/asciidoc/administration/startup/start-jar.adoc @@ -65,7 +65,7 @@ When executed `start.jar` performs the following actions: 3. Uses default behavior of `java.io.File` (Relative to `System.getProperty` ("user.dir") and then as absolute file system path). * Loads any dependent modules (merges XXNK, library, and properties results with active command line). * Builds out server classpath. -* Determines run mode: +* Determines run mode as one of: ** Shows informational command line options and exit. ** Executes Jetty normally, waits for Jetty to stop. ** Executes a forked JVM to run Jetty in, waits for forked JVM to exit. @@ -89,9 +89,36 @@ Lists the resolved configuration that will start Jetty. * Server classpath * Server XML configuration files --dry-run:: -Prints the resolved command line that `start.jar` should use to start a forked instance of Jetty. +Print the command line that the start.jar generates, then exit. This may be used to generate command lines when the start.ini includes -X or -D arguments: +.... +$ java -jar start.jar --dry-run > jetty.sh +$ . jetty.sh +.... +--dry-run=:: +Print specific parts of the command line. The parts are a comma separated list of: + + * "java" - the JVM to run + * "opts" - the JVM options (eg -D and -X flags) + * "path" - the JVM class path or JPMS modules options + * "main" - the main class to run + * "args" - the arguments passed to the main class + +It is possible to decompose the start command: +.... +$ OPTS=$(java -jar start.jar --dry-run=opts,path) +$ MAIN=$(java -jar start.jar --dry-run=main) +$ ARGS=$(java -jar start.jar --dry-run=args) +$ java $OPTS -Dextra=opt $MAIN $ARGS extra=arg +.... +Alternatively to create an args file for java: +.... +$ java -jar start.jar --dry-run=opts,path,main,args > /tmp/args +$ java @/tmp/args +.... --exec:: -Starts a forked instance of Jetty. +Forces the start to use a forked instance of java to run Jetty. +Some modules include `--exec` in order to set java command line options. +Some start options, such as `--jpms` also imply `--exec` --exec-properties=:: Assign a fixed name to the file used to transfer properties to the sub process. This allows the generated properties file to be saved and reused. @@ -99,7 +126,7 @@ Without this option, a temporary file is used. --commands=:: Instructs `start.jar` to use each line of the specified file as arguments on the command line. -===== Debugg and Start Logging +===== Debug and Start Logging --debug:: Enables debugging output of the startup procedure. @@ -275,3 +302,25 @@ If you have a need for a shaded version of `start.jar` (such as for Gradle), you shaded .... + +==== Start.jar without exec or forking. + +Some Jetty modules include the `--exec` option so that java command line options can be set. +Also some `start.jar` options (eg. `--jpms`) include an implicit `--exec`. +To start jetty without forking a new JVM instance from the start JVM, the `--dry-run` option can be used to generate a command line: +.... +$ CMD=$(java -jar start.jar --dry-run) +$ $CMD +.... +It is possible to decompose the start command so that it can be modified: +.... +$ OPTS=$(java -jar start.jar --dry-run=opts,path) +$ MAIN=$(java -jar start.jar --dry-run=main) +$ ARGS=$(java -jar start.jar --dry-run=args) +$ java $OPTS -Dextra=opt $MAIN $ARGS extra=arg +.... +Alternatively to create an args file for java: +.... +$ java -jar start.jar --dry-run=opts,path,main,args > /tmp/args +$ java @/tmp/args +.... \ No newline at end of file diff --git a/jetty-documentation/src/main/asciidoc/development/handlers/writing-custom-handlers.adoc b/jetty-documentation/src/main/asciidoc/development/handlers/writing-custom-handlers.adoc index 090110434cf9..02c8a31b0ffe 100644 --- a/jetty-documentation/src/main/asciidoc/development/handlers/writing-custom-handlers.adoc +++ b/jetty-documentation/src/main/asciidoc/development/handlers/writing-custom-handlers.adoc @@ -170,6 +170,25 @@ This is typically used to pass a request to a link:{JDURL}/org/eclipse/jetty/ser * link:{JDURL}/org/eclipse/jetty/server/handler/HandlerList.html[`HandlerList`] - A list of handlers that are called in turn until the request state is set as handled. * link:{JDURL}/org/eclipse/jetty/server/handler/ContextHandlerCollection.html[`ContextHandlerCollection`] - A collection of Handlers, of which one is selected by best match for the context path. +[[injecting-handlers]] +==== Injecting Handlers + +The `Handler` needs to be added to the server classpath as described in xref:startup-classpath[]. +Then it can be added to the server, either by overriding some existing XML configuration files such as `jetty.xml` as shown below, or by defining a custom module as described in xref:custom-modules[]. + +[source, xml] +---- + + + + + + + + + +---- + [[more-about-handlers]] ==== More About Handlers diff --git a/jetty-http2/http2-client/src/test/java/org/eclipse/jetty/http2/client/ProxyTest.java b/jetty-http2/http2-client/src/test/java/org/eclipse/jetty/http2/client/ProxyTest.java index e8fcd0646652..82a2b950f37c 100644 --- a/jetty-http2/http2-client/src/test/java/org/eclipse/jetty/http2/client/ProxyTest.java +++ b/jetty-http2/http2-client/src/test/java/org/eclipse/jetty/http2/client/ProxyTest.java @@ -24,15 +24,14 @@ import java.util.Map; import java.util.concurrent.CountDownLatch; import java.util.concurrent.TimeUnit; -import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; -import org.eclipse.jetty.client.api.Request; import org.eclipse.jetty.http.HostPortHttpField; import org.eclipse.jetty.http.HttpFields; import org.eclipse.jetty.http.HttpScheme; +import org.eclipse.jetty.http.HttpStatus; import org.eclipse.jetty.http.HttpVersion; import org.eclipse.jetty.http.MetaData; import org.eclipse.jetty.http2.api.Session; @@ -53,6 +52,7 @@ import org.junit.jupiter.api.AfterEach; import org.junit.jupiter.api.Test; +import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertTrue; public class ProxyTest @@ -137,33 +137,60 @@ public void dispose() throws Exception } @Test - public void testServerBigDownloadSlowClient() throws Exception + public void testHTTPVersion() throws Exception { - final CountDownLatch serverLatch = new CountDownLatch(1); - final byte[] content = new byte[1024 * 1024]; startServer(new HttpServlet() { @Override - protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException + protected void service(HttpServletRequest request, HttpServletResponse response) { - response.getOutputStream().write(content); - serverLatch.countDown(); + assertEquals(HttpVersion.HTTP_1_1.asString(), request.getProtocol()); } }); Map params = new HashMap<>(); params.put("proxyTo", "http://localhost:" + serverConnector.getLocalPort()); - startProxy(new AsyncProxyServlet.Transparent() + startProxy(new AsyncProxyServlet.Transparent(), params); + startClient(); + + CountDownLatch clientLatch = new CountDownLatch(1); + Session session = newClient(new Session.Listener.Adapter()); + MetaData.Request metaData = newRequest("GET", "/", new HttpFields()); + HeadersFrame frame = new HeadersFrame(metaData, null, true); + session.newStream(frame, new Promise.Adapter<>(), new Stream.Listener.Adapter() + { + @Override + public void onHeaders(Stream stream, HeadersFrame frame) + { + assertTrue(frame.isEndStream()); + MetaData.Response response = (MetaData.Response)frame.getMetaData(); + assertEquals(HttpStatus.OK_200, response.getStatus()); + clientLatch.countDown(); + } + }); + + assertTrue(clientLatch.await(5, TimeUnit.SECONDS)); + } + + @Test + public void testServerBigDownloadSlowClient() throws Exception + { + CountDownLatch serverLatch = new CountDownLatch(1); + byte[] content = new byte[1024 * 1024]; + startServer(new HttpServlet() { @Override - protected void sendProxyRequest(HttpServletRequest clientRequest, HttpServletResponse proxyResponse, Request proxyRequest) + protected void service(HttpServletRequest request, HttpServletResponse response) throws IOException { - proxyRequest.version(HttpVersion.HTTP_1_1); - super.sendProxyRequest(clientRequest, proxyResponse, proxyRequest); + response.getOutputStream().write(content); + serverLatch.countDown(); } - }, params); + }); + Map params = new HashMap<>(); + params.put("proxyTo", "http://localhost:" + serverConnector.getLocalPort()); + startProxy(new AsyncProxyServlet.Transparent(), params); startClient(); - final CountDownLatch clientLatch = new CountDownLatch(1); + CountDownLatch clientLatch = new CountDownLatch(1); Session session = newClient(new Session.Listener.Adapter()); MetaData.Request metaData = newRequest("GET", "/", new HttpFields()); HeadersFrame frame = new HeadersFrame(metaData, null, true); diff --git a/jetty-proxy/src/main/java/org/eclipse/jetty/proxy/AbstractProxyServlet.java b/jetty-proxy/src/main/java/org/eclipse/jetty/proxy/AbstractProxyServlet.java index 7ea2264b9909..26998e4eae40 100644 --- a/jetty-proxy/src/main/java/org/eclipse/jetty/proxy/AbstractProxyServlet.java +++ b/jetty-proxy/src/main/java/org/eclipse/jetty/proxy/AbstractProxyServlet.java @@ -50,7 +50,6 @@ import org.eclipse.jetty.http.HttpHeader; import org.eclipse.jetty.http.HttpHeaderValue; import org.eclipse.jetty.http.HttpStatus; -import org.eclipse.jetty.http.HttpVersion; import org.eclipse.jetty.util.HttpCookieStore; import org.eclipse.jetty.util.ProcessorUtils; import org.eclipse.jetty.util.StringUtil; @@ -457,9 +456,10 @@ protected boolean expects100Continue(HttpServletRequest request) protected Request newProxyRequest(HttpServletRequest request, String rewrittenTarget) { + // Do not copy the HTTP version, since the client-to-proxy + // version may be different from the proxy-to-server version. return getHttpClient().newRequest(rewrittenTarget) .method(request.getMethod()) - .version(HttpVersion.fromString(request.getProtocol())) .attribute(CLIENT_REQUEST_ATTRIBUTE, request); } diff --git a/jetty-proxy/src/main/java/org/eclipse/jetty/proxy/AsyncMiddleManServlet.java b/jetty-proxy/src/main/java/org/eclipse/jetty/proxy/AsyncMiddleManServlet.java index 187414a1aa17..23ab804a1b3c 100644 --- a/jetty-proxy/src/main/java/org/eclipse/jetty/proxy/AsyncMiddleManServlet.java +++ b/jetty-proxy/src/main/java/org/eclipse/jetty/proxy/AsyncMiddleManServlet.java @@ -185,7 +185,7 @@ private void transform(ContentTransformer transformer, ByteBuffer input, boolean } catch (Throwable x) { - _log.info("Exception while transforming " + transformer, x); + _log.info("Exception while transforming {} ", transformer, x); throw x; } } diff --git a/jetty-proxy/src/test/java/org/eclipse/jetty/proxy/AsyncMiddleManServletTest.java b/jetty-proxy/src/test/java/org/eclipse/jetty/proxy/AsyncMiddleManServletTest.java index 7f342c8d8c37..11c1eba4134a 100644 --- a/jetty-proxy/src/test/java/org/eclipse/jetty/proxy/AsyncMiddleManServletTest.java +++ b/jetty-proxy/src/test/java/org/eclipse/jetty/proxy/AsyncMiddleManServletTest.java @@ -23,6 +23,9 @@ import java.io.InputStream; import java.io.InputStreamReader; import java.io.OutputStream; +import java.lang.management.ManagementFactory; +import java.lang.management.ThreadInfo; +import java.lang.management.ThreadMXBean; import java.net.URLDecoder; import java.net.URLEncoder; import java.nio.ByteBuffer; @@ -38,6 +41,7 @@ import java.util.Random; import java.util.concurrent.CountDownLatch; import java.util.concurrent.TimeUnit; +import java.util.concurrent.TimeoutException; import java.util.concurrent.atomic.AtomicBoolean; import java.util.zip.GZIPInputStream; import java.util.zip.GZIPOutputStream; @@ -100,9 +104,9 @@ public class AsyncMiddleManServletTest private HttpClient client; private Server proxy; private ServerConnector proxyConnector; + private AsyncMiddleManServlet proxyServlet; private Server server; private ServerConnector serverConnector; - private StacklessLogging stackless; private void startServer(HttpServlet servlet) throws Exception { @@ -140,13 +144,12 @@ private void startProxy(AsyncMiddleManServlet proxyServlet, Map proxy.addConnector(proxyConnector); ServletContextHandler proxyContext = new ServletContextHandler(proxy, "/", true, false); + this.proxyServlet = proxyServlet; ServletHolder proxyServletHolder = new ServletHolder(proxyServlet); proxyServletHolder.setInitParameters(initParams); proxyContext.addServlet(proxyServletHolder, "/*"); proxy.start(); - - stackless = new StacklessLogging(proxyServlet._log); } private void startClient() throws Exception @@ -165,7 +168,6 @@ public void dispose() throws Exception client.stop(); proxy.stop(); server.stop(); - stackless.close(); } @Test @@ -511,43 +513,46 @@ protected ContentTransformer newClientRequestContentTransformer(HttpServletReque }); startClient(); - byte[] bytes = new byte[1024]; - ContentResponse response = client.newRequest("localhost", serverConnector.getLocalPort()) - .content(new BytesContentProvider(bytes)) - .timeout(5, TimeUnit.SECONDS) - .send(); + try (StacklessLogging ignored = new StacklessLogging(proxyServlet._log)) + { + byte[] bytes = new byte[1024]; + ContentResponse response = client.newRequest("localhost", serverConnector.getLocalPort()) + .content(new BytesContentProvider(bytes)) + .timeout(5, TimeUnit.SECONDS) + .send(); - assertEquals(500, response.getStatus()); + assertEquals(500, response.getStatus()); + } } @Test public void testUpstreamTransformationThrowsAfterCommittingProxyRequest() throws Exception { - try (StacklessLogging ignored = new StacklessLogging(HttpChannel.class)) + startServer(new EchoHttpServlet()); + startProxy(new AsyncMiddleManServlet() { - startServer(new EchoHttpServlet()); - startProxy(new AsyncMiddleManServlet() + @Override + protected ContentTransformer newClientRequestContentTransformer(HttpServletRequest clientRequest, Request proxyRequest) { - @Override - protected ContentTransformer newClientRequestContentTransformer(HttpServletRequest clientRequest, Request proxyRequest) + return new ContentTransformer() { - return new ContentTransformer() - { - private int count; + private int count; - @Override - public void transform(ByteBuffer input, boolean finished, List output) - { - if (++count < 2) - output.add(input); - else - throw new NullPointerException("explicitly_thrown_by_test"); - } - }; - } - }); - startClient(); + @Override + public void transform(ByteBuffer input, boolean finished, List output) + { + if (++count < 2) + output.add(input); + else + throw new NullPointerException("explicitly_thrown_by_test"); + } + }; + } + }); + startClient(); + try (StacklessLogging ignored = new StacklessLogging(proxyServlet._log)) + { CountDownLatch latch = new CountDownLatch(1); DeferredContentProvider content = new DeferredContentProvider(); client.newRequest("localhost", serverConnector.getLocalPort()) @@ -628,11 +633,14 @@ public void transform(ByteBuffer input, boolean finished, List outpu }); startClient(); - ContentResponse response = client.newRequest("localhost", serverConnector.getLocalPort()) - .timeout(5, TimeUnit.SECONDS) - .send(); + try (StacklessLogging ignored = new StacklessLogging(proxyServlet._log)) + { + ContentResponse response = client.newRequest("localhost", serverConnector.getLocalPort()) + .timeout(5, TimeUnit.SECONDS) + .send(); - assertEquals(502, response.getStatus()); + assertEquals(502, response.getStatus()); + } } @Test @@ -1037,31 +1045,70 @@ public boolean transform(Source source, Sink sink) throws IOException }); startClient(); - ContentResponse response = client.newRequest("localhost", serverConnector.getLocalPort()) - .timeout(5, TimeUnit.SECONDS) - .send(); - - assertEquals(200, response.getStatus()); - @SuppressWarnings("unchecked") - Map obj = (Map)JSON.parse(response.getContentAsString()); - assertNotNull(obj); - assertEquals(2, obj.size()); - assertEquals(value0, obj.get(key0)); - assertEquals(value1, obj.get(key2)); - // Make sure the files do not exist. - try (DirectoryStream paths = Files.newDirectoryStream(targetTestsDir, inputPrefix + "*.*")) + try { - assertFalse(paths.iterator().hasNext()); + ContentResponse response = client.newRequest("localhost", serverConnector.getLocalPort()) + .timeout(15, TimeUnit.SECONDS) + .send(); + + assertEquals(200, response.getStatus()); + @SuppressWarnings("unchecked") + Map obj = (Map)JSON.parse(response.getContentAsString()); + assertNotNull(obj); + assertEquals(2, obj.size()); + assertEquals(value0, obj.get(key0)); + assertEquals(value1, obj.get(key2)); + + // File deletion is delayed on windows, testing for deletion is not going to work + if (!OS.WINDOWS.isCurrentOs()) + { + try (DirectoryStream paths = Files.newDirectoryStream(targetTestsDir, outputPrefix + "*.*")) + { + assertFalse(paths.iterator().hasNext()); + } + } + } + catch (TimeoutException e) + { + LOG.warn("Client Dump"); + QueuedThreadPool qtp = (QueuedThreadPool)client.getExecutor(); + qtp.setDetailedDump(true); + client.dumpStdErr(); + LOG.warn("Server Dump"); + qtp = (QueuedThreadPool)server.getThreadPool(); + qtp.setDetailedDump(true); + server.dumpStdErr(); + LOG.warn("Thread Dump"); + System.err.println(generateThreadDump()); + throw e; } + } - // File deletion is delayed on windows, testing for deletion is not going to work - if (!OS.WINDOWS.isCurrentOs()) + public static String generateThreadDump() + { + StringBuilder dump = new StringBuilder(); + ThreadMXBean threadMXBean = ManagementFactory.getThreadMXBean(); + for (ThreadInfo thread : threadMXBean.getThreadInfo(threadMXBean.getAllThreadIds(), 400)) { - try (DirectoryStream paths = Files.newDirectoryStream(targetTestsDir, outputPrefix + "*.*")) + dump.append('"').append(thread.getThreadName()).append("\" "); + dump.append(" #").append(thread.getThreadId()); + dump.append("\n java.lang.Thread.State: "); + Thread.State state = thread.getThreadState(); + dump.append(state.name()); + if (state == Thread.State.BLOCKED || state == Thread.State.WAITING || state == Thread.State.TIMED_WAITING) + { + dump.append(" (locked on "); + dump.append(thread.getLockInfo()); + dump.append(')'); + } + for (StackTraceElement stackTraceElement : thread.getStackTrace()) { - assertFalse(paths.iterator().hasNext()); + dump.append("\n\tat "); + dump.append(stackTraceElement); } + dump.append("\n\n"); } + return dump.toString(); } @Test @@ -1122,7 +1169,7 @@ public long getLength() return data.length + 1; } }) - .timeout(5 * idleTimeout, TimeUnit.MILLISECONDS) + .timeout(15 * idleTimeout, TimeUnit.MILLISECONDS) .send(); assertTrue(destroyLatch.await(5 * idleTimeout, TimeUnit.MILLISECONDS)); @@ -1182,7 +1229,7 @@ public void destroy() startClient(); ContentResponse response = client.newRequest("localhost", serverConnector.getLocalPort()) - .timeout(5, TimeUnit.SECONDS) + .timeout(15, TimeUnit.SECONDS) .send(); assertTrue(serviceLatch.await(5, TimeUnit.SECONDS)); diff --git a/jetty-server/src/main/java/org/eclipse/jetty/server/ResourceService.java b/jetty-server/src/main/java/org/eclipse/jetty/server/ResourceService.java index 94bf5462e421..2732986bb1b8 100644 --- a/jetty-server/src/main/java/org/eclipse/jetty/server/ResourceService.java +++ b/jetty-server/src/main/java/org/eclipse/jetty/server/ResourceService.java @@ -578,7 +578,7 @@ protected boolean passConditionalHeaders(HttpServletRequest request, HttpServlet { //Get jetty's Response impl String mdlm = content.getLastModifiedValue(); - if (mdlm != null && ifms.equals(mdlm)) + if (ifms.equals(mdlm)) { sendStatus(response, HttpServletResponse.SC_NOT_MODIFIED, content::getETagValue); return false; @@ -674,10 +674,10 @@ protected boolean sendData(HttpServletRequest request, content.getResource().writeTo(out, 0, content_length); } // else if we can't do a bypass write because of wrapping - else if (written || !(out instanceof HttpOutput)) + else if (written) { // write normally - putHeaders(response, content, written ? -1 : 0); + putHeaders(response, content, Response.NO_CONTENT_LENGTH); ByteBuffer buffer = content.getIndirectBuffer(); if (buffer != null) BufferUtil.writeTo(buffer, out); @@ -688,7 +688,7 @@ else if (written || !(out instanceof HttpOutput)) else { // write the headers - putHeaders(response, content, 0); + putHeaders(response, content, Response.USE_KNOWN_CONTENT_LENGTH); // write the content asynchronously if supported if (request.isAsyncSupported() && content.getContentLengthValue() > response.getBufferSize()) @@ -736,7 +736,7 @@ public String toString() // if there are no satisfiable ranges, send 416 response if (ranges == null || ranges.size() == 0) { - putHeaders(response, content, 0); + putHeaders(response, content, Response.USE_KNOWN_CONTENT_LENGTH); response.setHeader(HttpHeader.CONTENT_RANGE.asString(), InclusiveByteRange.to416HeaderRangeString(content_length)); sendStatus(response, HttpServletResponse.SC_REQUESTED_RANGE_NOT_SATISFIABLE, null); @@ -763,8 +763,8 @@ public String toString() // 216 response which does not require an overall // content-length header // - putHeaders(response, content, -1); - String mimetype = (content == null ? null : content.getContentTypeValue()); + putHeaders(response, content, Response.NO_CONTENT_LENGTH); + String mimetype = content.getContentTypeValue(); if (mimetype == null) LOG.warn("Unknown mimetype for " + request.getRequestURI()); MultiPartOutputStream multi = new MultiPartOutputStream(out); diff --git a/jetty-server/src/main/java/org/eclipse/jetty/server/Response.java b/jetty-server/src/main/java/org/eclipse/jetty/server/Response.java index 27c71750ad59..7d82d5318097 100644 --- a/jetty-server/src/main/java/org/eclipse/jetty/server/Response.java +++ b/jetty-server/src/main/java/org/eclipse/jetty/server/Response.java @@ -71,6 +71,8 @@ public class Response implements HttpServletResponse private static final Logger LOG = Log.getLogger(Response.class); private static final int __MIN_BUFFER_SIZE = 1; private static final HttpField __EXPIRES_01JAN1970 = new PreEncodedHttpField(HttpHeader.EXPIRES, DateGenerator.__01Jan1970); + public static final int NO_CONTENT_LENGTH = -1; + public static final int USE_KNOWN_CONTENT_LENGTH = -2; public enum OutputType { @@ -1289,12 +1291,12 @@ public void putHeaders(HttpContent content, long contentLength, boolean etag) if (lm != null) _fields.put(lm); - if (contentLength == 0) + if (contentLength == USE_KNOWN_CONTENT_LENGTH) { _fields.put(content.getContentLength()); _contentLength = content.getContentLengthValue(); } - else if (contentLength > 0) + else if (contentLength > NO_CONTENT_LENGTH) { _fields.putLongField(HttpHeader.CONTENT_LENGTH, contentLength); _contentLength = contentLength; @@ -1337,9 +1339,9 @@ public static void putHeaders(HttpServletResponse response, HttpContent content, if (lml >= 0) response.setDateHeader(HttpHeader.LAST_MODIFIED.asString(), lml); - if (contentLength == 0) + if (contentLength == USE_KNOWN_CONTENT_LENGTH) contentLength = content.getContentLengthValue(); - if (contentLength >= 0) + if (contentLength > NO_CONTENT_LENGTH) { if (contentLength < Integer.MAX_VALUE) response.setContentLength((int)contentLength); diff --git a/jetty-server/src/main/java/org/eclipse/jetty/server/session/SessionHandler.java b/jetty-server/src/main/java/org/eclipse/jetty/server/session/SessionHandler.java index 0d0f72c6e204..255b4b88eafc 100644 --- a/jetty-server/src/main/java/org/eclipse/jetty/server/session/SessionHandler.java +++ b/jetty-server/src/main/java/org/eclipse/jetty/server/session/SessionHandler.java @@ -767,7 +767,9 @@ public HttpSession newHttpSession(HttpServletRequest request) try { _sessionCache.add(id, session); - Request.getBaseRequest(request).enterSession(session); + Request baseRequest = Request.getBaseRequest(request); + baseRequest.setSession(session); + baseRequest.enterSession(session); _sessionsCreatedStats.increment(); if (request != null && request.isSecure()) diff --git a/jetty-servlet/src/main/java/org/eclipse/jetty/servlet/DefaultServlet.java b/jetty-servlet/src/main/java/org/eclipse/jetty/servlet/DefaultServlet.java index c76d78958a54..f242949cf74f 100644 --- a/jetty-servlet/src/main/java/org/eclipse/jetty/servlet/DefaultServlet.java +++ b/jetty-servlet/src/main/java/org/eclipse/jetty/servlet/DefaultServlet.java @@ -462,20 +462,28 @@ protected void doPost(HttpServletRequest request, HttpServletResponse response) doGet(request, response); } + @Override + protected void doHead(HttpServletRequest request, HttpServletResponse response) + throws ServletException, IOException + { + doGet(request, response); + } + /* (non-Javadoc) * @see javax.servlet.http.HttpServlet#doTrace(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse) */ @Override - protected void doTrace(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException + protected void doTrace(HttpServletRequest request, HttpServletResponse response) + throws ServletException, IOException { - resp.sendError(HttpServletResponse.SC_METHOD_NOT_ALLOWED); + response.sendError(HttpServletResponse.SC_METHOD_NOT_ALLOWED); } @Override - protected void doOptions(HttpServletRequest req, HttpServletResponse resp) + protected void doOptions(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { - resp.setHeader("Allow", "GET,HEAD,POST,OPTIONS"); + response.setHeader("Allow", "GET,HEAD,POST,OPTIONS"); } /* diff --git a/jetty-start/src/main/java/org/eclipse/jetty/start/Main.java b/jetty-start/src/main/java/org/eclipse/jetty/start/Main.java index c3c944afcb8c..a061bc74f968 100644 --- a/jetty-start/src/main/java/org/eclipse/jetty/start/Main.java +++ b/jetty-start/src/main/java/org/eclipse/jetty/start/Main.java @@ -206,7 +206,7 @@ public void invokeMain(ClassLoader classloader, StartArgs args) throws IllegalAc StartLog.debug("%s - %s", invokedClass, invokedClass.getPackage().getImplementationVersion()); - CommandLineBuilder cmd = args.getMainArgs(false); + CommandLineBuilder cmd = args.getMainArgs(StartArgs.ARG_PARTS); String[] argArray = cmd.getArgs().toArray(new String[0]); StartLog.debug("Command Line Args: %s", cmd.toString()); @@ -415,7 +415,7 @@ public void start(StartArgs args) throws IOException, InterruptedException // Show Command Line to execute Jetty if (args.isDryRun()) { - CommandLineBuilder cmd = args.getMainArgs(true); + CommandLineBuilder cmd = args.getMainArgs(args.getDryRunParts()); System.out.println(cmd.toString(StartLog.isDebugEnabled() ? " \\\n" : " ")); } @@ -454,7 +454,7 @@ else if (args.isCreateFiles() || !args.getStartModules().isEmpty()) // execute Jetty in another JVM if (args.isExec()) { - CommandLineBuilder cmd = args.getMainArgs(true); + CommandLineBuilder cmd = args.getMainArgs(StartArgs.ALL_PARTS); cmd.debug(); ProcessBuilder pbuilder = new ProcessBuilder(cmd.getArgs()); StartLog.endStartLog(); diff --git a/jetty-start/src/main/java/org/eclipse/jetty/start/StartArgs.java b/jetty-start/src/main/java/org/eclipse/jetty/start/StartArgs.java index c59eed581c25..7161387a2883 100644 --- a/jetty-start/src/main/java/org/eclipse/jetty/start/StartArgs.java +++ b/jetty-start/src/main/java/org/eclipse/jetty/start/StartArgs.java @@ -57,6 +57,14 @@ public class StartArgs { public static final String VERSION; + public static final Set ALL_PARTS = Collections.unmodifiableSet(new HashSet<>(Arrays.asList( + "java", + "opts", + "path", + "main", + "args"))); + public static final Set ARG_PARTS = Collections.unmodifiableSet(new HashSet<>(Arrays.asList( + "args"))); static { @@ -219,6 +227,7 @@ public class StartArgs private boolean listConfig = false; private boolean version = false; private boolean dryRun = false; + private final Set dryRunParts = new HashSet<>(); private boolean jpms = false; private boolean createStartd = false; private boolean updateIni = false; @@ -675,8 +684,11 @@ public List getJvmArgs() return jvmArgs; } - public CommandLineBuilder getMainArgs(boolean addJavaInit) throws IOException + public CommandLineBuilder getMainArgs(Set parts) throws IOException { + if (parts.isEmpty()) + parts = ALL_PARTS; + CommandLineBuilder cmd = new CommandLineBuilder(); // Special Stop/Shutdown properties @@ -684,10 +696,11 @@ public CommandLineBuilder getMainArgs(boolean addJavaInit) throws IOException ensureSystemPropertySet("STOP.KEY"); ensureSystemPropertySet("STOP.WAIT"); - if (addJavaInit) - { + if (parts.contains("java")) cmd.addRawArg(CommandLineBuilder.findJavaBin()); + if (parts.contains("opts")) + { cmd.addRawArg("-Djava.io.tmpdir=" + System.getProperty("java.io.tmpdir")); cmd.addRawArg("-Djetty.home=" + baseHome.getHome()); cmd.addRawArg("-Djetty.base=" + baseHome.getBase()); @@ -702,6 +715,7 @@ public CommandLineBuilder getMainArgs(boolean addJavaInit) throws IOException Prop p = processSystemProperty(key, value, null); cmd.addRawArg("-D" + p.key + "=" + getProperties().expand(p.value)); + } else { @@ -715,7 +729,10 @@ public CommandLineBuilder getMainArgs(boolean addJavaInit) throws IOException String value = System.getProperty(propKey); cmd.addEqualsArg("-D" + propKey, value); } + } + if (parts.contains("path")) + { if (isJPMS()) { Map> dirsAndFiles = StreamSupport.stream(classpath.spliterator(), false) @@ -764,52 +781,58 @@ public CommandLineBuilder getMainArgs(boolean addJavaInit) throws IOException cmd.addRawArg("--add-reads"); cmd.addRawArg(entry.getKey() + "=" + String.join(",", entry.getValue())); } - - cmd.addRawArg("--module"); - cmd.addRawArg(getMainClassname()); } else { cmd.addRawArg("-cp"); cmd.addRawArg(classpath.toString()); - cmd.addRawArg(getMainClassname()); } } + if (parts.contains("main")) + { + if (isJPMS()) + cmd.addRawArg("--module"); + cmd.addRawArg(getMainClassname()); + } + // pass properties as args or as a file - if (dryRun && execProperties == null) + if (parts.contains("args")) { - for (Prop p : properties) + if (dryRun && execProperties == null) { - cmd.addRawArg(CommandLineBuilder.quote(p.key) + "=" + CommandLineBuilder.quote(p.value)); + for (Prop p : properties) + { + cmd.addRawArg(CommandLineBuilder.quote(p.key) + "=" + CommandLineBuilder.quote(p.value)); + } } - } - else if (properties.size() > 0) - { - Path propPath; - if (execProperties == null) + else if (properties.size() > 0) { - propPath = Files.createTempFile("start_", ".properties"); - propPath.toFile().deleteOnExit(); + Path propPath; + if (execProperties == null) + { + propPath = Files.createTempFile("start_", ".properties"); + propPath.toFile().deleteOnExit(); + } + else + propPath = new File(execProperties).toPath(); + + try (OutputStream out = Files.newOutputStream(propPath)) + { + properties.store(out, "start.jar properties"); + } + cmd.addRawArg(propPath.toAbsolutePath().toString()); } - else - propPath = new File(execProperties).toPath(); - try (OutputStream out = Files.newOutputStream(propPath)) + for (Path xml : xmls) { - properties.store(out, "start.jar properties"); + cmd.addRawArg(xml.toAbsolutePath().toString()); } - cmd.addRawArg(propPath.toAbsolutePath().toString()); - } - for (Path xml : xmls) - { - cmd.addRawArg(xml.toAbsolutePath().toString()); - } - - for (Path propertyFile : propertyFiles) - { - cmd.addRawArg(propertyFile.toAbsolutePath().toString()); + for (Path propertyFile : propertyFiles) + { + cmd.addRawArg(propertyFile.toAbsolutePath().toString()); + } } return cmd; @@ -935,6 +958,11 @@ public boolean isDryRun() return dryRun; } + public Set getDryRunParts() + { + return dryRunParts; + } + public boolean isExec() { return exec; @@ -1152,6 +1180,21 @@ public void parse(final String rawarg, String source) return; } + if (arg.startsWith("--dry-run=")) + { + int colon = arg.indexOf('='); + for (String part : arg.substring(colon + 1).split(",")) + { + if (!ALL_PARTS.contains(part)) + throw new UsageException(UsageException.ERR_BAD_ARG, "Unrecognized --dry-run=\"%s\" in %s", part, source); + + dryRunParts.add(part); + } + dryRun = true; + run = false; + return; + } + // Enable forked execution of Jetty server if ("--exec".equals(arg)) { diff --git a/jetty-start/src/main/resources/org/eclipse/jetty/start/usage.txt b/jetty-start/src/main/resources/org/eclipse/jetty/start/usage.txt index f0ec8ce742b3..4bd9fa87be52 100644 --- a/jetty-start/src/main/resources/org/eclipse/jetty/start/usage.txt +++ b/jetty-start/src/main/resources/org/eclipse/jetty/start/usage.txt @@ -28,7 +28,30 @@ Command Line Options: --dry-run Print the command line that the start.jar generates, then exit. This may be used to generate command lines - when the start.ini includes -X or -D arguments. + when the start.ini includes -X or -D arguments: + + java -jar start.jar --dry-run > jetty.sh + . jetty.sh + + --dry-run=parts Print specific parts of the command line. The parts + are a comma separated list of + o "java" - the JVM to run + o "opts" - the JVM options (eg -D and -X flags) + o "path" - the JVM class path or JPMS modules options + o "main" - the main class to run + o "args" - the arguments passed to the main class + + It is possible to decompose the start command: + + OPTS=$(java -jar start.jar --dry-run=opts,path) + MAIN=$(java -jar start.jar --dry-run=main) + ARGS=$(java -jar start.jar --dry-run=args) + java $OPTS -Dextra=opt $MAIN $ARGS extra=arg + + Alternatively to create an args file for java: + + java -jar start.jar --dry-run=opts,path,main,args > /tmp/args + java @/tmp/args --exec Run the generated command line (see --dry-run) in a sub process. This can be used when start.ini @@ -59,7 +82,6 @@ Debug and Start Logging: issues where the jetty specific logger has not yet kicked in due to startup configuration errors. - Module Management: ------------------ diff --git a/jetty-start/src/test/java/org/eclipse/jetty/start/MainTest.java b/jetty-start/src/test/java/org/eclipse/jetty/start/MainTest.java index 1eda5681817e..3c58faabcb03 100644 --- a/jetty-start/src/test/java/org/eclipse/jetty/start/MainTest.java +++ b/jetty-start/src/test/java/org/eclipse/jetty/start/MainTest.java @@ -193,7 +193,7 @@ public void testJvmArgExpansion() throws Exception assertThat("jetty.home", baseHome.getHome(), is(homePath.toString())); assertThat("jetty.base", baseHome.getBase(), is(homePath.toString())); - CommandLineBuilder commandLineBuilder = args.getMainArgs(true); + CommandLineBuilder commandLineBuilder = args.getMainArgs(StartArgs.ALL_PARTS); String commandLine = commandLineBuilder.toString("\n"); String expectedExpansion = String.format("-Xloggc:%s/logs/gc-%s.log", baseHome.getBase(), System.getProperty("java.version") diff --git a/jetty-util/src/main/java/org/eclipse/jetty/util/ssl/SniX509ExtendedKeyManager.java b/jetty-util/src/main/java/org/eclipse/jetty/util/ssl/SniX509ExtendedKeyManager.java index 598917fe9726..566bea23a612 100644 --- a/jetty-util/src/main/java/org/eclipse/jetty/util/ssl/SniX509ExtendedKeyManager.java +++ b/jetty-util/src/main/java/org/eclipse/jetty/util/ssl/SniX509ExtendedKeyManager.java @@ -25,7 +25,10 @@ import java.util.Arrays; import java.util.Collection; import java.util.Collections; +import java.util.LinkedHashMap; +import java.util.Map; import java.util.Objects; +import java.util.function.UnaryOperator; import java.util.stream.Collectors; import javax.net.ssl.SNIMatcher; import javax.net.ssl.SSLEngine; @@ -49,6 +52,7 @@ public class SniX509ExtendedKeyManager extends X509ExtendedKeyManager private final X509ExtendedKeyManager _delegate; private final SslContextFactory.Server _sslContextFactory; + private UnaryOperator _aliasMapper = UnaryOperator.identity(); /** * @deprecated not supported, you must have a {@link SslContextFactory.Server} for this to work. @@ -65,6 +69,38 @@ public SniX509ExtendedKeyManager(X509ExtendedKeyManager keyManager, SslContextFa _sslContextFactory = Objects.requireNonNull(sslContextFactory, "SslContextFactory.Server must be provided"); } + /** + * @return the function that transforms the alias + * @see #setAliasMapper(UnaryOperator) + */ + public UnaryOperator getAliasMapper() + { + return _aliasMapper; + } + + /** + *

Sets a function that transforms the alias into a possibly different alias, + * invoked when the SNI logic must choose the alias to pick the right certificate.

+ *

This function is required when using the + * {@link SslContextFactory.Server#setKeyManagerFactoryAlgorithm(String) PKIX KeyManagerFactory algorithm} + * which suffers from bug https://bugs.openjdk.java.net/browse/JDK-8246262, + * where aliases are returned by the OpenJDK implementation to the application + * in the form {@code N.0.alias} where {@code N} is an always increasing number. + * Such mangled aliases won't match the aliases in the keystore, so that for + * example SNI matching will always fail.

+ *

Other implementations such as BouncyCastle have been reported to mangle + * the alias in a different way, namely {@code 0.alias.N}.

+ *

This function allows to "unmangle" the alias from the implementation + * specific mangling back to just {@code alias} so that SNI matching will work + * again.

+ * + * @param aliasMapper the function that transforms the alias + */ + public void setAliasMapper(UnaryOperator aliasMapper) + { + _aliasMapper = Objects.requireNonNull(aliasMapper); + } + @Override public String chooseClientAlias(String[] keyType, Principal[] issuers, Socket socket) { @@ -80,10 +116,15 @@ public String chooseEngineClientAlias(String[] keyType, Principal[] issuers, SSL protected String chooseServerAlias(String keyType, Principal[] issuers, Collection matchers, SSLSession session) { // Look for the aliases that are suitable for the keyType and issuers. - String[] aliases = _delegate.getServerAliases(keyType, issuers); - if (aliases == null || aliases.length == 0) + String[] mangledAliases = _delegate.getServerAliases(keyType, issuers); + if (mangledAliases == null || mangledAliases.length == 0) return null; + // Apply the alias mapping, keeping the alias order. + Map aliasMap = new LinkedHashMap<>(); + Arrays.stream(mangledAliases) + .forEach(alias -> aliasMap.put(getAliasMapper().apply(alias), alias)); + // Find our SNIMatcher. There should only be one and it always matches (always returns true // from AliasSNIMatcher.matches), but it will capture the SNI Host if one was presented. String host = matchers == null ? null : matchers.stream() @@ -96,35 +137,40 @@ protected String chooseServerAlias(String keyType, Principal[] issuers, Collecti try { // Filter the certificates by alias. - Collection certificates = Arrays.stream(aliases) + Collection certificates = aliasMap.keySet().stream() .map(_sslContextFactory::getX509) .filter(Objects::nonNull) .collect(Collectors.toList()); - // delegate the decision to accept to the sniSelector + // Delegate the decision to accept to the sniSelector. SniSelector sniSelector = _sslContextFactory.getSNISelector(); if (sniSelector == null) sniSelector = _sslContextFactory; String alias = sniSelector.sniSelect(keyType, issuers, session, host, certificates); - // Check selected alias - if (alias != null && alias != SniSelector.DELEGATE) - { - // Make sure we got back an alias from the acceptable aliases. - X509 x509 = _sslContextFactory.getX509(alias); - if (!Arrays.asList(aliases).contains(alias) || x509 == null) - { - if (LOG.isDebugEnabled()) - LOG.debug("Invalid X509 match for SNI {}: {}", host, alias); - return null; - } + // Check the selected alias. + if (alias == null || alias == SniSelector.DELEGATE) + return alias; + // Make sure we got back an alias from the acceptable aliases. + X509 x509 = _sslContextFactory.getX509(alias); + if (!aliasMap.containsKey(alias) || x509 == null) + { if (LOG.isDebugEnabled()) - LOG.debug("Matched SNI {} with X509 {} from {}", host, x509, Arrays.asList(aliases)); - if (session != null) - session.putValue(SNI_X509, x509); + LOG.debug("Invalid X509 match for SNI {}: {}", host, alias); + return null; } - return alias; + + if (session != null) + session.putValue(SNI_X509, x509); + + // Convert the selected alias back to the original + // value before the alias mapping performed above. + String mangledAlias = aliasMap.get(alias); + + if (LOG.isDebugEnabled()) + LOG.debug("Matched SNI {} with alias {}, certificate {} from aliases {}", host, mangledAlias, x509, aliasMap.keySet()); + return mangledAlias; } catch (Throwable x) { @@ -141,10 +187,11 @@ public String chooseServerAlias(String keyType, Principal[] issuers, Socket sock String alias = (socket == null) ? chooseServerAlias(keyType, issuers, Collections.emptyList(), null) : chooseServerAlias(keyType, issuers, sslSocket.getSSLParameters().getSNIMatchers(), sslSocket.getHandshakeSession()); - if (alias == SniSelector.DELEGATE) + boolean delegate = alias == SniSelector.DELEGATE; + if (delegate) alias = _delegate.chooseServerAlias(keyType, issuers, socket); if (LOG.isDebugEnabled()) - LOG.debug("Chose alias {}/{} on {}", alias, keyType, socket); + LOG.debug("Chose {} alias {}/{} on {}", delegate ? "delegate" : "explicit", alias, keyType, socket); return alias; } @@ -154,10 +201,11 @@ public String chooseEngineServerAlias(String keyType, Principal[] issuers, SSLEn String alias = (engine == null) ? chooseServerAlias(keyType, issuers, Collections.emptyList(), null) : chooseServerAlias(keyType, issuers, engine.getSSLParameters().getSNIMatchers(), engine.getHandshakeSession()); - if (alias == SniSelector.DELEGATE) + boolean delegate = alias == SniSelector.DELEGATE; + if (delegate) alias = _delegate.chooseEngineServerAlias(keyType, issuers, engine); if (LOG.isDebugEnabled()) - LOG.debug("Chose alias {}/{} on {}", alias, keyType, engine); + LOG.debug("Chose {} alias {}/{} on {}", delegate ? "delegate" : "explicit", alias, keyType, engine); return alias; } diff --git a/jetty-util/src/test/java/org/eclipse/jetty/util/ssl/SslContextFactoryTest.java b/jetty-util/src/test/java/org/eclipse/jetty/util/ssl/SslContextFactoryTest.java index edce0f218be9..d5f8da57c5f5 100644 --- a/jetty-util/src/test/java/org/eclipse/jetty/util/ssl/SslContextFactoryTest.java +++ b/jetty-util/src/test/java/org/eclipse/jetty/util/ssl/SslContextFactoryTest.java @@ -20,14 +20,28 @@ import java.io.IOException; import java.io.InputStream; +import java.io.OutputStream; +import java.net.InetSocketAddress; +import java.nio.charset.StandardCharsets; import java.security.KeyStore; +import java.security.cert.Certificate; +import java.security.cert.X509Certificate; import java.util.Arrays; +import java.util.Collections; import java.util.List; +import java.util.regex.Matcher; +import java.util.regex.Pattern; import java.util.stream.Collectors; import java.util.stream.Stream; +import javax.net.ssl.SNIHostName; import javax.net.ssl.SSLContext; import javax.net.ssl.SSLEngine; +import javax.net.ssl.SSLParameters; +import javax.net.ssl.SSLServerSocket; +import javax.net.ssl.SSLSocket; +import javax.net.ssl.X509ExtendedKeyManager; +import org.eclipse.jetty.util.IO; import org.eclipse.jetty.util.component.AbstractLifeCycle; import org.eclipse.jetty.util.log.StacklessLogging; import org.eclipse.jetty.util.resource.Resource; @@ -43,6 +57,8 @@ import static org.hamcrest.Matchers.is; import static org.hamcrest.Matchers.matchesRegex; import static org.hamcrest.Matchers.not; +import static org.hamcrest.Matchers.startsWith; +import static org.junit.jupiter.api.Assertions.assertArrayEquals; import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertFalse; import static org.junit.jupiter.api.Assertions.assertNotNull; @@ -362,4 +378,81 @@ public void testServerSslContextFactory() throws Exception assertNull(cf.getEndpointIdentificationAlgorithm()); } + + @Test + public void testSNIWithPKIX() throws Exception + { + SslContextFactory.Server serverTLS = new SslContextFactory.Server() + { + @Override + protected X509ExtendedKeyManager newSniX509ExtendedKeyManager(X509ExtendedKeyManager keyManager) + { + SniX509ExtendedKeyManager result = new SniX509ExtendedKeyManager(keyManager, this); + result.setAliasMapper(alias -> + { + // Workaround for https://bugs.openjdk.java.net/browse/JDK-8246262. + Matcher matcher = Pattern.compile(".*\\..*\\.(.*)").matcher(alias); + if (matcher.matches()) + return matcher.group(1); + return alias; + }); + return result; + } + }; + // This test requires a SNI keystore so that the X509ExtendedKeyManager is wrapped. + serverTLS.setKeyStoreResource(Resource.newSystemResource("keystore_sni.p12")); + serverTLS.setKeyStorePassword("storepwd"); + serverTLS.setKeyManagerPassword("keypwd"); + serverTLS.setKeyManagerFactoryAlgorithm("PKIX"); + // Don't pick a default certificate if SNI does not match. + serverTLS.setSniRequired(true); + serverTLS.start(); + + SslContextFactory.Client clientTLS = new SslContextFactory.Client(true); + clientTLS.start(); + + try (SSLServerSocket serverSocket = serverTLS.newSslServerSocket(null, 0, 128); + SSLSocket clientSocket = clientTLS.newSslSocket()) + { + SSLParameters sslParameters = clientSocket.getSSLParameters(); + String hostName = "jetty.eclipse.org"; + sslParameters.setServerNames(Collections.singletonList(new SNIHostName(hostName))); + clientSocket.setSSLParameters(sslParameters); + clientSocket.connect(new InetSocketAddress("localhost", serverSocket.getLocalPort()), 5000); + try (SSLSocket sslSocket = (SSLSocket)serverSocket.accept()) + { + byte[] data = "HELLO".getBytes(StandardCharsets.UTF_8); + new Thread(() -> + { + try + { + // Start the TLS handshake and verify that + // the client got the right server certificate. + clientSocket.startHandshake(); + Certificate[] certificates = clientSocket.getSession().getPeerCertificates(); + assertThat(certificates.length, greaterThan(0)); + X509Certificate certificate = (X509Certificate)certificates[0]; + assertThat(certificate.getSubjectX500Principal().getName(), startsWith("CN=" + hostName)); + // Send some data to verify communication is ok. + OutputStream output = clientSocket.getOutputStream(); + output.write(data); + output.flush(); + clientSocket.close(); + } + catch (Throwable x) + { + x.printStackTrace(); + } + }).start(); + // Verify that we received the data the client sent. + sslSocket.setSoTimeout(5000); + InputStream input = sslSocket.getInputStream(); + byte[] bytes = IO.readBytes(input); + assertArrayEquals(data, bytes); + } + } + + clientTLS.stop(); + serverTLS.stop(); + } } diff --git a/jetty-util/src/test/resources/jetty-logging.properties b/jetty-util/src/test/resources/jetty-logging.properties index 7367559fac99..33c6ec7e8a03 100644 --- a/jetty-util/src/test/resources/jetty-logging.properties +++ b/jetty-util/src/test/resources/jetty-logging.properties @@ -1,4 +1,3 @@ -# Setup default logging implementation for during testing org.eclipse.jetty.util.log.class=org.eclipse.jetty.util.log.StdErrLog #org.eclipse.jetty.util.LEVEL=DEBUG #org.eclipse.jetty.util.PathWatcher.LEVEL=DEBUG diff --git a/jetty-webapp/src/test/java/org/eclipse/jetty/webapp/HugeResourceTest.java b/jetty-webapp/src/test/java/org/eclipse/jetty/webapp/HugeResourceTest.java index 4c75b95bd171..d530cd8a4f6d 100644 --- a/jetty-webapp/src/test/java/org/eclipse/jetty/webapp/HugeResourceTest.java +++ b/jetty-webapp/src/test/java/org/eclipse/jetty/webapp/HugeResourceTest.java @@ -244,6 +244,31 @@ public void testDownload(String filename, long expectedSize) throws Exception } } + @ParameterizedTest + @MethodSource("staticFiles") + public void testHead(String filename, long expectedSize) throws Exception + { + URI destUri = server.getURI().resolve("/" + filename); + InputStreamResponseListener responseListener = new InputStreamResponseListener(); + + Request request = client.newRequest(destUri) + .method(HttpMethod.HEAD); + request.send(responseListener); + Response response = responseListener.get(5, TimeUnit.SECONDS); + + try (InputStream in = responseListener.getInputStream()) + { + assertThat(in.read(), is(-1)); + } + + assertThat("HTTP Response Code", response.getStatus(), is(200)); + // dumpResponse(response); + + String contentLength = response.getHeaders().get(HttpHeader.CONTENT_LENGTH); + long contentLengthLong = Long.parseLong(contentLength); + assertThat("Http Response Header: \"Content-Length: " + contentLength + "\"", contentLengthLong, is(expectedSize)); + } + @ParameterizedTest @MethodSource("staticFiles") public void testUpload(String filename, long expectedSize) throws Exception diff --git a/jetty-websocket/jetty-websocket-tests/src/test/java/org/eclipse/jetty/websocket/tests/SingleOnMessageTest.java b/jetty-websocket/jetty-websocket-tests/src/test/java/org/eclipse/jetty/websocket/tests/SingleOnMessageTest.java new file mode 100644 index 000000000000..03acf813ed52 --- /dev/null +++ b/jetty-websocket/jetty-websocket-tests/src/test/java/org/eclipse/jetty/websocket/tests/SingleOnMessageTest.java @@ -0,0 +1,177 @@ +// +// ======================================================================== +// Copyright (c) 1995-2020 Mort Bay Consulting Pty Ltd and others. +// ------------------------------------------------------------------------ +// All rights reserved. This program and the accompanying materials +// are made available under the terms of the Eclipse Public License v1.0 +// and Apache License v2.0 which accompanies this distribution. +// +// The Eclipse Public License is available at +// http://www.eclipse.org/legal/epl-v10.html +// +// The Apache License v2.0 is available at +// http://www.opensource.org/licenses/apache2.0.php +// +// You may elect to redistribute this code under either of these licenses. +// ======================================================================== +// + +package org.eclipse.jetty.websocket.tests; + +import java.net.URI; +import java.nio.ByteBuffer; +import java.util.concurrent.CountDownLatch; +import java.util.concurrent.TimeUnit; + +import org.eclipse.jetty.server.Server; +import org.eclipse.jetty.server.ServerConnector; +import org.eclipse.jetty.servlet.ServletContextHandler; +import org.eclipse.jetty.util.BlockingArrayQueue; +import org.eclipse.jetty.util.BufferUtil; +import org.eclipse.jetty.websocket.api.RemoteEndpoint; +import org.eclipse.jetty.websocket.api.Session; +import org.eclipse.jetty.websocket.api.StatusCode; +import org.eclipse.jetty.websocket.api.annotations.OnWebSocketClose; +import org.eclipse.jetty.websocket.api.annotations.OnWebSocketConnect; +import org.eclipse.jetty.websocket.api.annotations.OnWebSocketMessage; +import org.eclipse.jetty.websocket.api.annotations.WebSocket; +import org.eclipse.jetty.websocket.api.util.WSURI; +import org.eclipse.jetty.websocket.client.WebSocketClient; +import org.eclipse.jetty.websocket.server.NativeWebSocketServletContainerInitializer; +import org.eclipse.jetty.websocket.server.WebSocketUpgradeFilter; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; + +import static org.hamcrest.MatcherAssert.assertThat; +import static org.hamcrest.Matchers.is; +import static org.junit.jupiter.api.Assertions.assertTrue; + +public class SingleOnMessageTest +{ + private final Server server = new Server(); + private final WebSocketClient client = new WebSocketClient(); + private final EventSocket serverSocket = new EventSocket(); + private URI serverUri; + + @BeforeEach + public void start() throws Exception + { + ServerConnector connector = new ServerConnector(server); + server.addConnector(connector); + + ServletContextHandler contextHandler = new ServletContextHandler(ServletContextHandler.SESSIONS); + contextHandler.setContextPath("/"); + NativeWebSocketServletContainerInitializer.configure(contextHandler, + (context, container) -> container.addMapping("/", (req, resp) -> serverSocket)); + WebSocketUpgradeFilter.configure(contextHandler); + + server.setHandler(contextHandler); + server.start(); + serverUri = WSURI.toWebsocket(server.getURI()); + + client.start(); + } + + @AfterEach + public void stop() throws Exception + { + client.stop(); + server.stop(); + } + + @Test + public void testTextHandler() throws Exception + { + TextOnlyHandler handler = new TextOnlyHandler(); + client.connect(handler, serverUri); + assertTrue(handler.openLatch.await(5, TimeUnit.SECONDS)); + assertTrue(serverSocket.openLatch.await(5, TimeUnit.SECONDS)); + + // The server sends a sequence of Binary and Text messages + RemoteEndpoint remote = serverSocket.session.getRemote(); + remote.sendBytes(BufferUtil.toBuffer("this should get rejected")); + remote.sendString("WebSocket_Data0"); + remote.sendString("WebSocket_Data1"); + serverSocket.session.close(StatusCode.NORMAL, "test complete"); + + // The client receives the messages and has discarded the binary message. + assertThat(handler.messages.poll(5, TimeUnit.SECONDS), is("WebSocket_Data0")); + assertThat(handler.messages.poll(5, TimeUnit.SECONDS), is("WebSocket_Data1")); + assertTrue(handler.closeLatch.await(5, TimeUnit.SECONDS)); + assertThat(handler.closeCode, is(StatusCode.NORMAL)); + assertThat(handler.closeReason, is("test complete")); + } + + @Test + public void testBinaryHandler() throws Exception + { + BinaryOnlyHandler handler = new BinaryOnlyHandler(); + client.connect(handler, serverUri); + assertTrue(handler.openLatch.await(5, TimeUnit.SECONDS)); + assertTrue(serverSocket.openLatch.await(5, TimeUnit.SECONDS)); + + // The server sends a sequence of Binary and Text messages + RemoteEndpoint remote = serverSocket.session.getRemote(); + remote.sendString("this should get rejected"); + remote.sendBytes(BufferUtil.toBuffer("WebSocket_Data0")); + remote.sendBytes(BufferUtil.toBuffer("WebSocket_Data1")); + serverSocket.session.close(StatusCode.NORMAL, "test complete"); + + // The client receives the messages and has discarded the binary message. + assertThat(handler.messages.poll(5, TimeUnit.SECONDS), is(BufferUtil.toBuffer("WebSocket_Data0"))); + assertThat(handler.messages.poll(5, TimeUnit.SECONDS), is(BufferUtil.toBuffer("WebSocket_Data1"))); + assertTrue(handler.closeLatch.await(5, TimeUnit.SECONDS)); + assertThat(handler.closeCode, is(StatusCode.NORMAL)); + assertThat(handler.closeReason, is("test complete")); + } + + @WebSocket + public static class TextOnlyHandler extends AbstractHandler + { + final BlockingArrayQueue messages = new BlockingArrayQueue<>(); + + @OnWebSocketMessage + public void onMessage(String message) + { + messages.add(message); + } + } + + @WebSocket + public static class BinaryOnlyHandler extends AbstractHandler + { + final BlockingArrayQueue messages = new BlockingArrayQueue<>(); + + @OnWebSocketMessage + public void onMessage(byte[] array, int offset, int length) + { + messages.add(BufferUtil.toBuffer(array, offset, length)); + } + } + + @WebSocket + public static class AbstractHandler + { + final CountDownLatch openLatch = new CountDownLatch(1); + final CountDownLatch closeLatch = new CountDownLatch(1); + Session session; + int closeCode; + String closeReason; + + @OnWebSocketClose + public void onClose(int statusCode, String reason) + { + this.closeCode = statusCode; + this.closeReason = reason; + this.closeLatch.countDown(); + } + + @OnWebSocketConnect + public void onConnect(Session session) + { + this.session = session; + this.openLatch.countDown(); + } + } +} diff --git a/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/AbstractEventDriver.java b/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/AbstractEventDriver.java index 2c54ace5c183..d69fe68044fc 100644 --- a/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/AbstractEventDriver.java +++ b/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/AbstractEventDriver.java @@ -20,6 +20,7 @@ import java.io.IOException; import java.nio.ByteBuffer; +import java.util.Objects; import org.eclipse.jetty.util.BufferUtil; import org.eclipse.jetty.util.Utf8Appendable.NotUtf8Exception; @@ -42,7 +43,7 @@ */ public abstract class AbstractEventDriver extends AbstractLifeCycle implements IncomingFrames, EventDriver { - private static final Logger LOG = Log.getLogger(AbstractEventDriver.class); + private final Logger logger; protected final Logger targetLog; protected WebSocketPolicy policy; protected final Object websocket; @@ -51,8 +52,9 @@ public abstract class AbstractEventDriver extends AbstractLifeCycle implements I public AbstractEventDriver(WebSocketPolicy policy, Object websocket) { + this.logger = Log.getLogger(this.getClass()); this.policy = policy; - this.websocket = websocket; + this.websocket = Objects.requireNonNull(websocket, "WebSocket endpoint may not be null"); this.targetLog = Log.getLogger(websocket.getClass()); } @@ -87,9 +89,9 @@ public WebSocketSession getSession() @Override public void incomingFrame(Frame frame) { - if (LOG.isDebugEnabled()) + if (logger.isDebugEnabled()) { - LOG.debug("incomingFrame({})", frame); + logger.debug("incomingFrame({})", frame); } try @@ -112,9 +114,9 @@ public void incomingFrame(Frame frame) } case OpCode.PING: { - if (LOG.isDebugEnabled()) + if (logger.isDebugEnabled()) { - LOG.debug("PING: {}", BufferUtil.toDetailString(frame.getPayload())); + logger.debug("PING: {}", BufferUtil.toDetailString(frame.getPayload())); } ByteBuffer pongBuf; if (frame.hasPayload()) @@ -133,9 +135,9 @@ public void incomingFrame(Frame frame) } case OpCode.PONG: { - if (LOG.isDebugEnabled()) + if (logger.isDebugEnabled()) { - LOG.debug("PONG: {}", BufferUtil.toDetailString(frame.getPayload())); + logger.debug("PONG: {}", BufferUtil.toDetailString(frame.getPayload())); } onPong(frame.getPayload()); break; @@ -157,8 +159,8 @@ public void incomingFrame(Frame frame) } default: { - if (LOG.isDebugEnabled()) - LOG.debug("Unhandled OpCode: {}", opcode); + if (logger.isDebugEnabled()) + logger.debug("Unhandled OpCode: {}", opcode); } } } @@ -202,10 +204,9 @@ public BatchMode getBatchMode() @Override public void openSession(WebSocketSession session) { - if (LOG.isDebugEnabled()) + if (logger.isDebugEnabled()) { - LOG.debug("openSession({})", session); - LOG.debug("objectFactory={}", session.getContainerScope().getObjectFactory()); + logger.debug("openSession({}) objectFactory={}", session, session.getContainerScope().getObjectFactory()); } this.session = session; this.session.getContainerScope().getObjectFactory().decorate(this.websocket); diff --git a/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/JettyAnnotatedEventDriver.java b/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/JettyAnnotatedEventDriver.java index cb993d213d0b..c48d0d9de245 100644 --- a/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/JettyAnnotatedEventDriver.java +++ b/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/JettyAnnotatedEventDriver.java @@ -22,7 +22,9 @@ import java.io.InputStream; import java.io.Reader; import java.nio.ByteBuffer; +import java.util.Objects; +import org.eclipse.jetty.util.BufferUtil; import org.eclipse.jetty.util.log.Log; import org.eclipse.jetty.util.log.Logger; import org.eclipse.jetty.websocket.api.BatchMode; @@ -36,6 +38,7 @@ import org.eclipse.jetty.websocket.common.message.NullMessage; import org.eclipse.jetty.websocket.common.message.SimpleBinaryMessage; import org.eclipse.jetty.websocket.common.message.SimpleTextMessage; +import org.eclipse.jetty.websocket.common.util.TextUtil; /** * Handler for Annotated User WebSocket objects. @@ -45,12 +48,12 @@ public class JettyAnnotatedEventDriver extends AbstractEventDriver private static final Logger LOG = Log.getLogger(JettyAnnotatedEventDriver.class); private final JettyAnnotatedMetadata events; private boolean hasCloseBeenCalled = false; - private BatchMode batchMode; + private final BatchMode batchMode; public JettyAnnotatedEventDriver(WebSocketPolicy policy, Object websocket, JettyAnnotatedMetadata events) { super(policy, websocket); - this.events = events; + this.events = Objects.requireNonNull(events, "JettyAnnotatedMetadata may not be null"); WebSocket anno = websocket.getClass().getAnnotation(WebSocket.class); // Setup the policy @@ -71,6 +74,11 @@ public JettyAnnotatedEventDriver(WebSocketPolicy policy, Object websocket, Jetty this.policy.setIdleTimeout(anno.maxIdleTime()); } this.batchMode = anno.batchMode(); + + if (LOG.isDebugEnabled()) + { + LOG.debug("ctor / object={}, policy={}, batchMode={}, events={}", websocket, policy, batchMode, events); + } } @Override @@ -82,20 +90,20 @@ public BatchMode getBatchMode() @Override public void onBinaryFrame(ByteBuffer buffer, boolean fin) throws IOException { - if (events.onBinary == null) + if (LOG.isDebugEnabled()) { - // not interested in binary events - if (activeMessage == null) - { - activeMessage = NullMessage.INSTANCE; - } - - return; + LOG.debug("onBinaryFrame({}, {}) - events.onBinary={}, activeMessage={}", + BufferUtil.toDetailString(buffer), fin, events.onBinary, activeMessage); } if (activeMessage == null) { - if (events.onBinary.isStreaming()) + if (events.onBinary == null) + { + // not interested in binary events + activeMessage = NullMessage.INSTANCE; + } + else if (events.onBinary.isStreaming()) { final MessageInputStream inputStream = new MessageInputStream(session); activeMessage = inputStream; @@ -126,6 +134,11 @@ public void onBinaryFrame(ByteBuffer buffer, boolean fin) throws IOException @Override public void onBinaryMessage(byte[] data) { + if (LOG.isDebugEnabled()) + { + LOG.debug("onBinaryMessage([{}]) - events.onBinary={}", data.length, events.onBinary); + } + if (events.onBinary != null) { events.onBinary.call(websocket, session, data, 0, data.length); @@ -141,6 +154,12 @@ public void onClose(CloseInfo close) return; } hasCloseBeenCalled = true; + + if (LOG.isDebugEnabled()) + { + LOG.debug("onClose({}) - events.onClose={}", close, events.onClose); + } + if (events.onClose != null) { events.onClose.call(websocket, session, close.getStatusCode(), close.getReason()); @@ -150,6 +169,11 @@ public void onClose(CloseInfo close) @Override public void onConnect() { + if (LOG.isDebugEnabled()) + { + LOG.debug("onConnect() - events.onConnect={}", events.onConnect); + } + if (events.onConnect != null) { events.onConnect.call(websocket, session); @@ -159,6 +183,11 @@ public void onConnect() @Override public void onError(Throwable cause) { + if (LOG.isDebugEnabled()) + { + LOG.debug("onError({}) - events.onError={}", cause.getClass().getName(), events.onError); + } + if (events.onError != null) { events.onError.call(websocket, session, cause); @@ -172,6 +201,11 @@ public void onError(Throwable cause) @Override public void onFrame(Frame frame) { + if (LOG.isDebugEnabled()) + { + LOG.debug("onFrame({}) - events.onFrame={}", frame, events.onFrame); + } + if (events.onFrame != null) { events.onFrame.call(websocket, session, frame); @@ -181,6 +215,13 @@ public void onFrame(Frame frame) @Override public void onInputStream(InputStream stream) { + Objects.requireNonNull(stream, "InputStream may not be null"); + + if (LOG.isDebugEnabled()) + { + LOG.debug("onInputStream({}) - events.onBinary={}", stream.getClass().getName(), events.onBinary); + } + if (events.onBinary != null) { events.onBinary.call(websocket, session, stream); @@ -190,6 +231,13 @@ public void onInputStream(InputStream stream) @Override public void onReader(Reader reader) { + Objects.requireNonNull(reader, "Reader may not be null"); + + if (LOG.isDebugEnabled()) + { + LOG.debug("onReader({}) - events.onText={}", reader.getClass().getName(), events.onText); + } + if (events.onText != null) { events.onText.call(websocket, session, reader); @@ -199,19 +247,20 @@ public void onReader(Reader reader) @Override public void onTextFrame(ByteBuffer buffer, boolean fin) throws IOException { - if (events.onText == null) + if (LOG.isDebugEnabled()) { - // not interested in text events - if (activeMessage == null) - { - activeMessage = NullMessage.INSTANCE; - } - return; + LOG.debug("onTextFrame({}, {}) - events.onText={}, activeMessage={}", + BufferUtil.toDetailString(buffer), fin, events.onText, activeMessage); } if (activeMessage == null) { - if (events.onText.isStreaming()) + if (events.onText == null) + { + // not interested in text events + activeMessage = NullMessage.INSTANCE; + } + else if (events.onText.isStreaming()) { MessageInputStream inputStream = new MessageInputStream(session); activeMessage = new MessageReader(inputStream); @@ -243,6 +292,12 @@ public void onTextFrame(ByteBuffer buffer, boolean fin) throws IOException @Override public void onTextMessage(String message) { + if (LOG.isDebugEnabled()) + { + LOG.debug("onTextMessage([{}] \"{}\") - events.onText={}", + message.length(), TextUtil.maxStringLength(60, message), events.onText); + } + if (events.onText != null) { events.onText.call(websocket, session, message); diff --git a/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/JettyAnnotatedMetadata.java b/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/JettyAnnotatedMetadata.java index 536faeaaf2a5..c56f9efb89fb 100644 --- a/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/JettyAnnotatedMetadata.java +++ b/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/JettyAnnotatedMetadata.java @@ -24,27 +24,27 @@ public class JettyAnnotatedMetadata { /** - * @OnWebSocketConnect () + * {@code @OnWebSocketConnect ()} */ public CallableMethod onConnect; /** - * @OnWebSocketMessage (byte[], or ByteBuffer, or InputStream) + * {@code @OnWebSocketMessage (byte[], or ByteBuffer, or InputStream)} */ public OptionalSessionCallableMethod onBinary; /** - * @OnWebSocketMessage (String, or Reader) + * {@code @OnWebSocketMessage (String, or Reader)} */ public OptionalSessionCallableMethod onText; /** - * @OnWebSocketFrame (Frame) + * {@code @OnWebSocketFrame (Frame)} */ public OptionalSessionCallableMethod onFrame; /** - * @OnWebSocketError (Throwable) + * {@code @OnWebSocketError (Throwable)} */ public OptionalSessionCallableMethod onError; /** - * @OnWebSocketClose (Frame) + * {@code @OnWebSocketClose (Frame)} */ public OptionalSessionCallableMethod onClose; @@ -52,7 +52,8 @@ public class JettyAnnotatedMetadata public String toString() { StringBuilder s = new StringBuilder(); - s.append("JettyPojoMetadata["); + s.append(this.getClass().getSimpleName()); + s.append("["); s.append("onConnect=").append(onConnect); s.append(",onBinary=").append(onBinary); s.append(",onText=").append(onText); diff --git a/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/JettyListenerEventDriver.java b/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/JettyListenerEventDriver.java index 9af52f99937a..dc9ed1059c31 100644 --- a/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/JettyListenerEventDriver.java +++ b/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/JettyListenerEventDriver.java @@ -22,7 +22,9 @@ import java.io.InputStream; import java.io.Reader; import java.nio.ByteBuffer; +import java.util.Objects; +import org.eclipse.jetty.util.BufferUtil; import org.eclipse.jetty.util.Utf8StringBuilder; import org.eclipse.jetty.util.log.Log; import org.eclipse.jetty.util.log.Logger; @@ -38,6 +40,7 @@ import org.eclipse.jetty.websocket.common.frames.ReadOnlyDelegatedFrame; import org.eclipse.jetty.websocket.common.message.SimpleBinaryMessage; import org.eclipse.jetty.websocket.common.message.SimpleTextMessage; +import org.eclipse.jetty.websocket.common.util.TextUtil; /** * Handler for {@link WebSocketListener} based User WebSocket implementations. @@ -58,12 +61,26 @@ private enum PartialMode public JettyListenerEventDriver(WebSocketPolicy policy, WebSocketConnectionListener listener) { super(policy, listener); - this.listener = listener; + this.listener = Objects.requireNonNull(listener, "Listener may not be null"); + if (LOG.isDebugEnabled()) + { + LOG.debug("ctor / listener={}, policy={}", listener.getClass().getName(), policy); + } } @Override public void onBinaryFrame(ByteBuffer buffer, boolean fin) throws IOException { + if (LOG.isDebugEnabled()) + { + LOG.debug("onBinaryFrame({}, {}) - webSocketListener={}, webSocketPartialListener={}, listener={}, activeMessage={}", + BufferUtil.toDetailString(buffer), fin, + (listener instanceof WebSocketListener), + (listener instanceof WebSocketPartialListener), + listener.getClass().getName(), + activeMessage); + } + if (listener instanceof WebSocketListener) { if (activeMessage == null) @@ -98,6 +115,14 @@ public void onBinaryFrame(ByteBuffer buffer, boolean fin) throws IOException @Override public void onBinaryMessage(byte[] data) { + if (LOG.isDebugEnabled()) + { + LOG.debug("onBinaryMessage([{}]) - webSocketListener={}, listener={}", + data.length, + (listener instanceof WebSocketListener), + this.listener.getClass().getName()); + } + if (listener instanceof WebSocketListener) { ((WebSocketListener)listener).onWebSocketBinary(data, 0, data.length); @@ -116,6 +141,11 @@ public void onClose(CloseInfo close) int statusCode = close.getStatusCode(); String reason = close.getReason(); + + if (LOG.isDebugEnabled()) + { + LOG.debug("onClose({},{}) - listener={}", statusCode, reason, this.listener.getClass().getName()); + } listener.onWebSocketClose(statusCode, reason); } @@ -123,19 +153,34 @@ public void onClose(CloseInfo close) public void onConnect() { if (LOG.isDebugEnabled()) - LOG.debug("onConnect({})", session); + { + LOG.debug("onConnect({}) - listener={}", session, this.listener.getClass().getName()); + } listener.onWebSocketConnect(session); } @Override public void onError(Throwable cause) { + if (LOG.isDebugEnabled()) + { + LOG.debug("onError({}) - listener={}", cause.getClass().getName(), this.listener.getClass().getName()); + } listener.onWebSocketError(cause); } @Override public void onFrame(Frame frame) { + if (LOG.isDebugEnabled()) + { + LOG.debug("onFrame({}) - frameListener={}, pingPongListener={}, listener={}", + frame, + (listener instanceof WebSocketFrameListener), + (listener instanceof WebSocketPingPongListener), + this.listener.getClass().getName()); + } + if (listener instanceof WebSocketFrameListener) { ((WebSocketFrameListener)listener).onWebSocketFrame(new ReadOnlyDelegatedFrame(frame)); @@ -169,6 +214,17 @@ public void onReader(Reader reader) @Override public void onTextFrame(ByteBuffer buffer, boolean fin) throws IOException { + if (LOG.isDebugEnabled()) + { + LOG.debug("onTextFrame({}, {}) - webSocketListener={}, webSocketPartialListener={}, listener={}, activeMessage={}", + BufferUtil.toDetailString(buffer), + fin, + (listener instanceof WebSocketListener), + (listener instanceof WebSocketPartialListener), + listener.getClass().getName(), + activeMessage); + } + if (listener instanceof WebSocketListener) { if (activeMessage == null) @@ -226,6 +282,15 @@ public void onTextFrame(ByteBuffer buffer, boolean fin) throws IOException @Override public void onTextMessage(String message) { + if (LOG.isDebugEnabled()) + { + LOG.debug("onTextMessage([{}] \"{}\") - webSocketListener={}, listener={}", + message.length(), + TextUtil.maxStringLength(60, message), + (listener instanceof WebSocketListener), + listener.getClass().getName()); + } + if (listener instanceof WebSocketListener) { ((WebSocketListener)listener).onWebSocketText(message); @@ -234,6 +299,16 @@ public void onTextMessage(String message) public void onContinuationFrame(ByteBuffer buffer, boolean fin) throws IOException { + if (LOG.isDebugEnabled()) + { + LOG.debug("onContinuationFrame({}, {}) - webSocketListener={}, webSocketPartialListener={}, listener={}, activeMessage={}", + BufferUtil.toDetailString(buffer), fin, + (listener instanceof WebSocketListener), + (listener instanceof WebSocketPartialListener), + listener.getClass().getName(), + activeMessage); + } + if (listener instanceof WebSocketPartialListener) { switch (partialMode) diff --git a/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/annotated/CallableMethod.java b/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/annotated/CallableMethod.java index 0f10c71e9bd7..145ea510e964 100644 --- a/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/annotated/CallableMethod.java +++ b/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/annotated/CallableMethod.java @@ -139,6 +139,9 @@ public Class getPojo() @Override public String toString() { - return String.format("%s[%s]", this.getClass().getSimpleName(), method.toGenericString()); + return String.format("%s[pojo=%s,method=%s]", + this.getClass().getSimpleName(), + pojo.getName(), + method.toGenericString()); } } diff --git a/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/annotated/OptionalSessionCallableMethod.java b/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/annotated/OptionalSessionCallableMethod.java index aca97a2eb01c..115a6d124172 100644 --- a/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/annotated/OptionalSessionCallableMethod.java +++ b/jetty-websocket/websocket-common/src/main/java/org/eclipse/jetty/websocket/common/events/annotated/OptionalSessionCallableMethod.java @@ -86,6 +86,11 @@ public boolean isStreaming() @Override public String toString() { - return String.format("%s[%s]", this.getClass().getSimpleName(), method.toGenericString()); + return String.format("%s[pojo=%s,method=%s,wantsSession=%b,streaming=%s]", + this.getClass().getSimpleName(), + pojo.getName(), + method.toGenericString(), + wantsSession, + streaming); } } diff --git a/tests/test-sessions/test-sessions-common/src/test/java/org/eclipse/jetty/server/session/CreationTest.java b/tests/test-sessions/test-sessions-common/src/test/java/org/eclipse/jetty/server/session/CreationTest.java index 02b87fdfcb85..b7cd0f84648a 100644 --- a/tests/test-sessions/test-sessions-common/src/test/java/org/eclipse/jetty/server/session/CreationTest.java +++ b/tests/test-sessions/test-sessions-common/src/test/java/org/eclipse/jetty/server/session/CreationTest.java @@ -28,13 +28,17 @@ import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; +import javax.servlet.http.HttpSessionEvent; +import javax.servlet.http.HttpSessionListener; import org.eclipse.jetty.client.HttpClient; import org.eclipse.jetty.client.api.ContentResponse; import org.eclipse.jetty.client.api.Request; import org.eclipse.jetty.http.HttpHeader; +import org.eclipse.jetty.servlet.ListenerHolder; import org.eclipse.jetty.servlet.ServletContextHandler; import org.eclipse.jetty.servlet.ServletHolder; +import org.eclipse.jetty.servlet.Source; import org.eclipse.jetty.util.StringUtil; import org.eclipse.jetty.util.log.Log; import org.eclipse.jetty.util.log.StacklessLogging; @@ -56,7 +60,62 @@ */ public class CreationTest { + static ThreadLocal currentRequest = new ThreadLocal<>(); + @Test + public void testRequestGetSessionInsideListener() throws Exception + { + String contextPath = ""; + String servletMapping = "/server"; + + DefaultSessionCacheFactory cacheFactory = new DefaultSessionCacheFactory(); + cacheFactory.setEvictionPolicy(SessionCache.EVICT_ON_SESSION_EXIT); + SessionDataStoreFactory storeFactory = new TestSessionDataStoreFactory(); + + TestServer server1 = new TestServer(0, -1, -1, cacheFactory, storeFactory); + TestServlet servlet = new TestServlet(); + ServletHolder holder = new ServletHolder(servlet); + ServletContextHandler contextHandler = server1.addContext(contextPath); + + ListenerHolder h = contextHandler.getServletHandler().newListenerHolder(Source.EMBEDDED); + h.setListener(new MySessionListener()); + contextHandler.getServletHandler().addListener(h); + + TestHttpChannelCompleteListener scopeListener = new TestHttpChannelCompleteListener(); + server1.getServerConnector().addBean(scopeListener); + contextHandler.addServlet(holder, servletMapping); + servlet.setStore(contextHandler.getSessionHandler().getSessionCache().getSessionDataStore()); + server1.start(); + int port1 = server1.getPort(); + try (StacklessLogging stackless = new StacklessLogging(Log.getLogger("org.eclipse.jetty.server.session"))) + { + HttpClient client = new HttpClient(); + client.start(); + + //make a session + String url = "http://localhost:" + port1 + contextPath + servletMapping + "?action=create&check=false"; + + CountDownLatch synchronizer = new CountDownLatch(1); + scopeListener.setExitSynchronizer(synchronizer); + + //make a request to set up a session on the server + ContentResponse response = client.GET(url); + assertEquals(HttpServletResponse.SC_OK, response.getStatus()); + + String sessionCookie = response.getHeaders().get("Set-Cookie"); + assertTrue(sessionCookie != null); + + //ensure request has finished being handled + synchronizer.await(5, TimeUnit.SECONDS); + } + finally + { + server1.stop(); + } + + } + + /** * Test creating a session when the cache is set to * evict after the request exits. @@ -387,6 +446,21 @@ public void testSessionCreateForwardAndInvalidate() throws Exception } } + public static class MySessionListener implements HttpSessionListener + { + @Override + public void sessionCreated(HttpSessionEvent se) + { + currentRequest.get().getSession(true); + } + + @Override + public void sessionDestroyed(HttpSessionEvent se) + { + } + + } + public static class TestServlet extends HttpServlet { private static final long serialVersionUID = 1L; @@ -436,6 +510,7 @@ else if (action != null && "test".equals(action)) } else if (action != null && action.startsWith("create")) { + currentRequest.set(request); HttpSession session = request.getSession(true); _id = session.getId(); session.setAttribute("value", new Integer(1));