Merge remote-tracking branch 'origin/jetty-9.4.x'
This commit is contained in:
commit
e93fa6c141
|
@ -28,11 +28,11 @@
|
|||
[[balancer-servlet-usage]]
|
||||
==== Usage
|
||||
|
||||
The Balancer servlet allows for simple, sticky round robin load balancing leveraging the ProxyServlet that is distributed with Jetty.
|
||||
The Balancer servlet allows for simple, sticky round robin load balancing leveraging the `ProxyServlet` that is distributed with Jetty.
|
||||
|
||||
In addition to the parameters for ProxyServlet, the following are available for the balancer servlet:
|
||||
In addition to the parameters for `ProxyServlet`, the following are available for the balancer servlet:
|
||||
|
||||
stickySessions::
|
||||
true if sessions should be sticky for subsequent requests
|
||||
True if sessions should be sticky for subsequent requests
|
||||
balancerMember.<name>.proxyTo::
|
||||
One of more of these are required and will be the locations that are used to proxy traffic to.
|
||||
|
|
|
@ -29,9 +29,8 @@
|
|||
==== Usage
|
||||
|
||||
The CGI servlet class extends the abstract HttpServlet class.
|
||||
When the init parameter is called, the cgi bin directory is set with the cgibinResourceBase.
|
||||
When the init parameter is called, the cgi bin directory is set with the `cgibinResourceBase`.
|
||||
Otherwise, it defaults to the resource base of the context.
|
||||
See CGI javadoc.
|
||||
|
||||
The cgi bin uses three parameters:
|
||||
|
||||
|
|
|
@ -40,46 +40,46 @@ This is extremely useful in CometD web applications where it is now possible to
|
|||
[[cross-origin-setup]]
|
||||
==== Setup
|
||||
|
||||
You will need to put the jetty-servlets.jar file onto your classpath.
|
||||
If you are creating a webapp, ensure that this jar is included in your webapp's WEB-INF/lib.
|
||||
Or, if you are running jetty embedded you will need to ensure that jetty-servlets.jar is on the execution classpath.
|
||||
You can download the jetty-servlets.jar from the Maven Central Repository at http://central.maven.org/maven2/org/eclipse/jetty/jetty-servlets/.
|
||||
You will need to put the `jetty-servlets.jar` file onto your classpath.
|
||||
If you are creating a webapp, ensure that this jar is included in your webapp's `WEB-INF/lib`.
|
||||
Or, if you are running Jetty embedded you will need to ensure that `jetty-servlets.jar` is on the execution classpath.
|
||||
You can download the `jetty-servlets.jar` from the Maven Central Repository at http://central.maven.org/maven2/org/eclipse/jetty/jetty-servlets/.
|
||||
It is also available as part of the Jetty distribution in the `$JETTY_HOME/lib` directory.
|
||||
|
||||
[[cross-origin-config]]
|
||||
==== Configuration
|
||||
|
||||
This is a regular servlet filter that must be configured in web.xml.
|
||||
This is a regular servlet filter that must be configured in `web.xml`.
|
||||
|
||||
It supports the following configuration parameters:
|
||||
|
||||
allowedOrigins::
|
||||
a comma separated list of origins that are allowed to access the resources.
|
||||
A comma separated list of origins that are allowed to access the resources.
|
||||
Default value is: * (all origins)
|
||||
allowedMethods::
|
||||
a comma separated list of HTTP methods that are allowed to be used when accessing the resources.
|
||||
A comma separated list of HTTP methods that are allowed to be used when accessing the resources.
|
||||
Default value is: GET,POST,HEAD
|
||||
allowedHeaders::
|
||||
a comma separated list of HTTP headers that are allowed to be specified when accessing the resources.
|
||||
A comma separated list of HTTP headers that are allowed to be specified when accessing the resources.
|
||||
Default value is: X-Requested-With,Content-Type,Accept,Origin
|
||||
allowCredentials::
|
||||
a boolean indicating if the resource allows requests with credentials.
|
||||
A boolean indicating if the resource allows requests with credentials.
|
||||
Default value is: true
|
||||
preflightMaxAge::
|
||||
the number of seconds that preflight requests can be cached by the client.
|
||||
The number of seconds that preflight requests can be cached by the client.
|
||||
Default value is 1800 seconds (30 minutes)
|
||||
chainPreflight::
|
||||
if true preflight requests are chained to their target resource for normal handling (as an OPTION request).
|
||||
If true preflight requests are chained to their target resource for normal handling (as an OPTION request).
|
||||
Otherwise the filter will response to the preflight.
|
||||
Default is true.
|
||||
exposedHeaders::
|
||||
a comma separated list of HTTP headers that are allowed to be exposed on the client.
|
||||
A comma separated list of HTTP headers that are allowed to be exposed on the client.
|
||||
Default value is the empty list.
|
||||
|
||||
A typical configuration could be:
|
||||
|
||||
[source, xml, subs="{sub-order}"]
|
||||
----
|
||||
|
||||
<web-app>
|
||||
|
||||
<filter>
|
||||
|
@ -92,6 +92,4 @@ A typical configuration could be:
|
|||
</filter-mapping>
|
||||
|
||||
</web-app>
|
||||
|
||||
|
||||
----
|
||||
|
|
|
@ -29,12 +29,11 @@
|
|||
==== Usage
|
||||
|
||||
A simple handler that is useful to debug incoming traffic.
|
||||
It will log entry and exit points of http requests as well as the response code.
|
||||
It will log entry and exit points of HTTP requests as well as the response code.
|
||||
|
||||
==== Usage in standard distribution
|
||||
|
||||
Simply include jetty-debug.xml in your *.ini configs.
|
||||
For example in start.ini.
|
||||
The debug handler can be added to Jetty by activating the debug module.
|
||||
|
||||
==== Embedded usage
|
||||
|
||||
|
@ -49,10 +48,9 @@ debugHandler.setHandler(server.getHandler());
|
|||
|
||||
server.setHandler(debugHandler);
|
||||
server.start();
|
||||
|
||||
----
|
||||
|
||||
==== Some example output
|
||||
==== Example output
|
||||
|
||||
[source,bash]
|
||||
----
|
||||
|
@ -66,5 +64,4 @@ server.start();
|
|||
15:14:07.248:qtp551889550-59:http://0:0:0:0:0:0:0:1:8080/favicon.ico REQUEST 0:0:0:0:0:0:0:1 GET __utma=111872281.10102721.1321534299.1369833564.1370447492.35; __utmz=111872281.1321534299.1.1.utmcsr=(direct)|utmccn=(direct)|utmcmd=(none); _opt_vi_RPY720HZ=75E12E63-0CD0-4D6F-8383-C90D5C8397C7; visited=yes; Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:22.0) Gecko/20100101 Firefox/22.0
|
||||
15:14:07.251:qtp551889550-59:http://0:0:0:0:0:0:0:1:8080/favicon.ico RESPONSE 404 text/html;charset=ISO-8859-1
|
||||
15:14:09.330:qtp551889550-57 CLOSED HttpConnection@e910ee4{INTERESTED},g=HttpGenerator{s=START},p=HttpParser{s=START,0 of -1}
|
||||
|
||||
----
|
||||
|
|
|
@ -29,18 +29,17 @@
|
|||
==== Usage
|
||||
|
||||
A simple handler that is useful to terminate handler chains with a clean fashion.
|
||||
As in the example below, if a resource to be served is not matched within the resource handler, the DefaultHandler will take care of producing a 404 page.
|
||||
As in the example below, if a resource to be served is not matched within the resource handler the `DefaultHandler` will take care of producing a 404 page.
|
||||
This class is a useful template to either extend and embrace or simply provide a similar implementation for customizing to your needs.
|
||||
There is also an link:#error-handler[Error Handler] that services errors related to the servlet api specification so it is best to not get the two confused.
|
||||
There is also an link:#error-handler[Error Handler] that services errors related to the servlet api specification, so it is best to not get the two confused.
|
||||
|
||||
_____
|
||||
[NOTE]
|
||||
The DefaultHandler will also handle serving out the flav.ico file should a request make it through all of the other handlers without being resolved.
|
||||
The `DefaultHandler` will also handle serving out the `flav.ico` file should a request make it through all of the other handlers without being resolved.
|
||||
_____
|
||||
|
||||
[source, java, subs="{sub-order}"]
|
||||
----
|
||||
|
||||
Server server = new Server(8080);
|
||||
HandlerList handlers = new HandlerList();
|
||||
ResourceHandler resourceHandler = new ResourceHandler();
|
||||
|
@ -49,6 +48,4 @@ _____
|
|||
{ resourceHandler, new DefaultHandler() });
|
||||
server.setHandler(handlers);
|
||||
server.start();
|
||||
|
||||
|
||||
----
|
||||
|
|
|
@ -28,15 +28,15 @@
|
|||
[[default-servlet-usage]]
|
||||
==== Usage
|
||||
|
||||
The DefaultServlet implements the ResourceFactory interface and extends the HttpServlet abstract class.
|
||||
It is usually mapped to / and provides handling for static content, OPTION and TRACE methods for the context.
|
||||
The MOVE method is allowed if PUT and DELETE are allowed.
|
||||
See DefaultServlet link:{JDURL}/org/eclipse/jetty/servlet/DefaultServlet.html[javadoc].
|
||||
The `DefaultServlet` implements the `ResourceFactory` interface and extends the `HttpServlet` abstract class.
|
||||
It is usually mapped to "/" and provides handling for static content, `OPTION` and `TRACE` methods for the context.
|
||||
The `MOVE` method is allowed if `PUT` and `DELETE` are allowed.
|
||||
See the `DefaultServlet` link:{JDURL}/org/eclipse/jetty/servlet/DefaultServlet.html[javadoc].
|
||||
|
||||
[[default-servlet-init]]
|
||||
==== Init Parameters
|
||||
|
||||
Jetty supports the following initParameters:
|
||||
Jetty supports the following `initParameters`:
|
||||
|
||||
acceptRanges::
|
||||
If true, range requests and responses are supported.
|
||||
|
|
|
@ -45,18 +45,17 @@ To uniquely identify authenticated users, you should implement the The extractUs
|
|||
|
||||
To use the DoS Filter, these JAR files must be available in WEB-INF/lib:
|
||||
|
||||
* $JETTY_HOME/lib/ext/jetty-util.jar
|
||||
* $JETTY_HOME/lib/ext/jetty-servlets.jar
|
||||
* $JETTY_HOME/lib/jetty-util.jar
|
||||
* $JETTY_HOME/lib/jetty-servlets.jar
|
||||
|
||||
===== Sample Configuration
|
||||
|
||||
Place the configuration in a webapp's web.xml or jetty-web.xml.
|
||||
Place the configuration in a webapp's `web.xml` or `jetty-web.xml`.
|
||||
The default configuration allows 25 requests per connection at a time, servicing more important requests first, and queuing up the rest.
|
||||
This example allow 30 requests at a time:
|
||||
|
||||
[source, xml, subs="{sub-order}"]
|
||||
----
|
||||
|
||||
<filter>
|
||||
<filter-name>DoSFilter</filter-name>
|
||||
<filter-class>org.eclipse.jetty.servlets.DoSFilter</filter-class>
|
||||
|
@ -65,14 +64,12 @@ This example allow 30 requests at a time:
|
|||
<param-value>30</param-value>
|
||||
</init-param>
|
||||
</filter>
|
||||
|
||||
|
||||
----
|
||||
|
||||
[[dos-filter-init]]
|
||||
===== Configuring DoS Filter Parameters
|
||||
|
||||
The following init parameters control the behavior of the filter:
|
||||
The following `init` parameters control the behavior of the filter:
|
||||
|
||||
maxRequestsPerSec::
|
||||
Maximum number of requests from a connection per second.
|
||||
|
@ -81,7 +78,6 @@ maxRequestsPerSec::
|
|||
|
||||
delayMs::
|
||||
Delay imposed on all requests over the rate limit, before they are considered at all:
|
||||
+
|
||||
* 100 (ms) = Default
|
||||
* -1 = Reject request
|
||||
* 0 = No delay
|
||||
|
@ -98,8 +94,7 @@ throttleMs::
|
|||
maxRequestMs::
|
||||
Length of time, in ms, to allow the request to run. Default is 30000L.
|
||||
maxIdleTrackerMs::
|
||||
Length of time, in ms, to keep track of request rates for a connection, before deciding that the user has gone away, and
|
||||
discarding it.
|
||||
Length of time, in ms, to keep track of request rates for a connection, before deciding that the user has gone away, and discarding it.
|
||||
Default is 30000L.
|
||||
insertHeaders::
|
||||
If true, insert the DoSFilter headers into the response.
|
||||
|
@ -108,10 +103,10 @@ trackSessions::
|
|||
If true, usage rate is tracked by session if a session exists.
|
||||
Defaults to true.
|
||||
remotePort::
|
||||
If true and session tracking is not used, then rate is tracked by IP+port (effectively connection).
|
||||
If true and session tracking is not used, then rate is tracked by IP and port (effectively connection).
|
||||
Defaults to false.
|
||||
ipWhitelist::
|
||||
A comma-separated list of IP addresses that will not be rate limited.
|
||||
managedAttr::
|
||||
If set to true, then this servlet is set as a ServletContext attribute with the filter name as the attribute name.
|
||||
This allows a context external mechanism (for example, JMX via ContextHandler.MANAGED_ATTRIBUTES) to manage the configuration of the filter.
|
||||
This allows a context external mechanism (for example, JMX via `ContextHandler.MANAGED_ATTRIBUTES`) to manage the configuration of the filter.
|
||||
|
|
|
@ -30,4 +30,4 @@
|
|||
|
||||
A handler that is used to report errors from servlet contexts and webapp contexts to report error conditions.
|
||||
Primarily handles setting the various servlet spec specific response headers for error conditions.
|
||||
Can be customized by extending, for more information on this see xref:custom-error-pages[].
|
||||
Can be customized by extending; for more information on this see xref:custom-error-pages[].
|
||||
|
|
|
@ -29,18 +29,18 @@
|
|||
[[gzip-filter-usage]]
|
||||
==== Usage
|
||||
|
||||
The Jetty GzipHandler is a compression handler that you can apply to any dynamic resource (servlet).
|
||||
The Jetty `GzipHandler` is a compression handler that you can apply to any dynamic resource (servlet).
|
||||
It fixes many of the bugs in commonly available compression filters: it works with asynchronous servlets; it handles all ways to set content length.
|
||||
We have tested it with Jetty continuations and suspending requests.
|
||||
It has been tested with Jetty continuations and suspending requests.
|
||||
Some user-agents might be excluded from compression to avoid common browser bugs (yes, this means IE!).
|
||||
|
||||
The GzipHandler is added to the entire server by the etc/jetty-gzip.xml file from the gzip.mod module.
|
||||
The `GzipHandler` is added to the entire server by the `etc/jetty-gzip.xml` file from the `gzip.mod` module.
|
||||
It may also be added to individual contexts in a context xml file.
|
||||
|
||||
[[gzip-filter-rules]]
|
||||
==== Gzip Rules
|
||||
|
||||
GZIP Handler will gzip or deflate the content of a response if:
|
||||
`GzipHandler` will gzip or deflate the content of a response if:
|
||||
|
||||
* It is mapped to a matching path
|
||||
* The request method is configured to support gzip
|
||||
|
@ -53,31 +53,33 @@ GZIP Handler will gzip or deflate the content of a response if:
|
|||
|
||||
If both gzip and deflate are specified in the accept-encoding header, then gzip will be used.
|
||||
|
||||
Compressing the content can greatly improve the network bandwidth usage, but at a cost of memory and CPU cycles.
|
||||
Compressing the content can greatly improve the network bandwidth usage, but at the cost of memory and CPU cycles.
|
||||
The link:#default-servlet[DefaultServlet] is capable of serving pre-compressed static content, which saves memory and CPU.
|
||||
By default, the GzipHandler will check to see if pre-compressed content exists, and pass the request through to be handled by the DefaultServlet.
|
||||
By default, the `GzipHandler` will check to see if pre-compressed content exists, and pass the request through to be handled by the `DefaultServlet`.
|
||||
|
||||
[[gzip-filter-init]]
|
||||
==== Gzip Configuration
|
||||
|
||||
minGzipSize::
|
||||
Content will only be compressed if content length is either unknown or greater than minGzipSize.
|
||||
Content will only be compressed if content length is either unknown or greater than `minGzipSize`.
|
||||
checkGzExists::
|
||||
True by default. If set to false, the handler will not check for pre-compressed content.
|
||||
True by default.
|
||||
If set to false, the handler will not check for pre-compressed content.
|
||||
compressionLevel::
|
||||
The compression level used for deflate compression. (0-9).
|
||||
includedMethods::
|
||||
List of HTTP methods to compress. If not set, only GET requests are compressed.
|
||||
List of HTTP methods to compress.
|
||||
If not set, only `GET` requests are compressed.
|
||||
includedMimeTypes::
|
||||
List of mime types to compress.
|
||||
List of MIME types to compress.
|
||||
excludedMimeTypes::
|
||||
List of mime types not to compress.
|
||||
List of MIME types not to compress.
|
||||
excludedAgentPatterns::
|
||||
A list of regex patterns for User-Agent names from which requests should not be compressed.
|
||||
excludedPaths::
|
||||
List of paths to exclude from compression.
|
||||
Does a String.startsWith(String) comparison to check if the path matches.
|
||||
If it does match -> no compression.
|
||||
Performs a `String.startsWith(String)` comparison to check if the path matches.
|
||||
If it does match then there is no compression.
|
||||
To match subpaths use excludePathPatterns instead.
|
||||
includedPaths::
|
||||
List of paths to consider for compression.
|
||||
|
|
|
@ -39,7 +39,7 @@ Typically, the black/white lists will be used in one of three modes:
|
|||
* Allowing a general range of IPs/URLs by specifying several general white list entries, that are then further refined by several specific black list exceptions.
|
||||
|
||||
An empty white list is treated as match all.
|
||||
If there is at least one entry in the white list, then a request must match a white list entry.
|
||||
If there is at least one entry in the white list, then a request *must* match a white list entry.
|
||||
Black list entries are always applied, so that even if an entry matches the white list, a black list entry will override it.
|
||||
|
||||
Internet addresses may be specified as absolute address or as a combination of four octet wildcard specifications (a.b.c.d) that are defined as follows.
|
||||
|
|
|
@ -30,25 +30,24 @@
|
|||
[[moved-context-handler-usage]]
|
||||
==== Usage
|
||||
|
||||
You can use the MovedContextHandler to relocate or redirect a context that has changed context path and/or virtual hosts.
|
||||
You can use the `MovedContextHandler` to relocate or redirect a context that has changed context path and/or virtual hosts.
|
||||
|
||||
You can configure it to _permanently_ redirect the old URL to the new URL, in which case Jetty sends a Http Status code of 301 to the browser with the new URL.
|
||||
Alternatively, you can make it non-permanent, in which case Jetty sends a 302 Http Status code along with the new URL.
|
||||
|
||||
In addition, as with any other context, you can configure a list of virtual hosts, meaning that this context responds only to requests to one of the listed host names.
|
||||
|
||||
Suppose you have a context deployed at /foo, but that now you want to deploy at the root context / instead.
|
||||
Suppose you have a context deployed at `/foo`, but that now you want to deploy at the root context `/` instead.
|
||||
|
||||
* First you reconfigure and redeploy the context on Jetty.
|
||||
* Next you need a way to redirect all the browsers who have bookmarked /foo to the new path.
|
||||
You create a new context xml file in $JETTY_HOME/contexts and configure the MovedContextHandler to do the redirection from /foo to /.
|
||||
* Next you need a way to redirect all the browsers who have bookmarked `/foo` to the new path.
|
||||
You create a new xref:configuring-contexts[context xml] file in `{$jetty/.base}/webapps` and configure the `MovedContextHandler` to do the redirection from `/foo` to `/`.
|
||||
|
||||
Here's an example.
|
||||
This is a permanent redirection, which also preserves pathinfo and query strings on the redirect:
|
||||
Below is an example.
|
||||
This is a permanent redirection, which also preserves `pathinfo` and query strings on the redirect:
|
||||
|
||||
[source, xml, subs="{sub-order}"]
|
||||
----
|
||||
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!DOCTYPE Configure PUBLIC "-//Jetty//Configure//EN" "http://www.eclipse.org/jetty/configure_9_0.dtd">
|
||||
|
||||
|
@ -69,6 +68,4 @@ This is a permanent redirection, which also preserves pathinfo and query strings
|
|||
</Array>
|
||||
</Set>
|
||||
</Configure>
|
||||
|
||||
|
||||
----
|
||||
|
|
|
@ -28,9 +28,10 @@
|
|||
[[proxy-servlet-usage]]
|
||||
==== Usage
|
||||
|
||||
An asynchronous servlet that forwards requests to another server either as a standard web reverse proxy (as defined by RFC2616) or as a transparent reverse proxy. Internally it uses the async jetty-client.
|
||||
An asynchronous servlet that forwards requests to another server either as a standard web reverse proxy (as defined by RFC2616) or as a transparent reverse proxy.
|
||||
Internally it uses the async jetty-client.
|
||||
|
||||
To facilitate JMX monitoring, the HttpClient instance is set as context attribute, prefixed with the servlet's name and exposed by the mechanism provided by ContextHandler.MANAGED_ATTRIBUTES.
|
||||
To facilitate JMX monitoring, the `HttpClient` instance is set as context attribute, prefixed with the servlet's name and exposed by the mechanism provided by `ContextHandler.MANAGED_ATTRIBUTES`.
|
||||
|
||||
[[proxy-servlet-init]]
|
||||
==== Init Parameters
|
||||
|
@ -47,35 +48,30 @@ blackList::
|
|||
comma-separated list of forbidden proxy hosts
|
||||
|
||||
|
||||
In addition, there are a number of init parameters that can be used to configure the HttpClient instance used internally for the proxy.
|
||||
In addition, there are a number of init parameters that can be used to configure the `HttpClient` instance used internally for the proxy.
|
||||
|
||||
maxThreads::
|
||||
Default Value: 256
|
||||
+
|
||||
The max number of threads of HttpClient's Executor
|
||||
|
||||
maxConnections::
|
||||
Default Value: 32768
|
||||
+
|
||||
The max number of connections per destination.
|
||||
RFC 2616 suggests that 2 connections should be opened per each destination, but browsers commonly open 6 or more. If this HttpClient is used for load testing, it is common to have only one destination (the server to load test), and it is recommended to set this value to a high value (at least as much as the threads present in the executor).
|
||||
RFC 2616 suggests that 2 connections should be opened per each destination, but browsers commonly open 6 or more.
|
||||
If this `HttpClient` is used for load testing, it is common to have only one destination (the server to load test), and it is recommended to set this value to a high value (at least as much as the threads present in the executor).
|
||||
|
||||
idleTimeout::
|
||||
Default Value: 30000
|
||||
+
|
||||
The idle timeout in milliseconds that a connection can be idle, that is without traffic of bytes in either direction.
|
||||
|
||||
timeout::
|
||||
Default Value: 60000
|
||||
+
|
||||
The total timeout in milliseconds for the request/response conversation.
|
||||
|
||||
requestBufferSize::
|
||||
Default Value: 4096
|
||||
+
|
||||
The size of the request buffer the request is written into.
|
||||
|
||||
responseBufferSize::
|
||||
Default Value: 4096
|
||||
+
|
||||
The size of the response buffer the response is written into.
|
||||
|
|
|
@ -29,7 +29,7 @@
|
|||
==== Usage
|
||||
|
||||
Jetty supports Continuations, which allow non-blocking handling of HTTP requests, so that threads can be allocated in a managed way to provide application specific Quality of Service (QoS).
|
||||
The QoSFilter is a utility servlet filter that implements some QoS features.
|
||||
The `QoSFilter` is a utility servlet filter that implements some QoS features.
|
||||
|
||||
[[qos-understanding]]
|
||||
==== Understanding the Problem
|
||||
|
@ -42,12 +42,11 @@ Consider a thread pool with 20 connections, being used by a web application that
|
|||
Such a pool can service on average 200*20*1000/50 = 400 requests per second.
|
||||
|
||||
However, if the request rate rises above 400 per second, or if the database slows down (due to a large query) or becomes momentarily unavailable, the thread pool can very quickly accumulate many waiting requests.
|
||||
If, for example, the website is slashdotted or experiences some other temporary burst of traffic and the request rate rises from 400 to 500 requests per second, then 100 requests per second join those waiting for a JDBC connection.
|
||||
Typically, a web server's thread pool contains only a few hundred threads, so a burst or slow DB need only persist for a few seconds to consume the entire web server's thread pool.
|
||||
This is called thread starvation.
|
||||
If, for example, the website is "slashdotted" or experiences some other temporary burst of traffic and the request rate rises from 400 to 500 requests per second, then 100 requests per second join those waiting for a JDBC connection.
|
||||
Typically, a web server's thread pool contains only a few hundred threads, so a burst or slow DB need only persist for a few seconds to consume the entire web server's thread pool; this is called thread starvation.
|
||||
The key issue with thread starvation is that it effects the entire web application, and potentially the entire web server.
|
||||
Even if the requests using the database are only a small proportion of the total requests on the web server, all requests are blocked because all the available threads are waiting on the JDBC connection pool.
|
||||
This represents non graceful degradation under load and provides a very poor quality of service.
|
||||
This represents non-graceful degradation under load and provides a very poor quality of service.
|
||||
|
||||
===== Prioritizing Resources
|
||||
|
||||
|
@ -55,7 +54,7 @@ Consider a web application that is under extreme load.
|
|||
This load might be due to a popularity spike (slashdot), usage burst (Christmas or close of business), or even a denial of service attack.
|
||||
During such periods of load, it is often desirable not to treat all requests as equals, and to give priority to high value customers or administrative users.
|
||||
|
||||
The typical behaviour of a web server under extreme load is to use all its threads to service requests and to build up a backlog of unserviced requests.
|
||||
The typical behavior of a web server under extreme load is to use all its threads to service requests and to build up a backlog of unserviced requests.
|
||||
If the backlog grows deep enough, then requests start to timeout and users experience failures as well as delays.
|
||||
|
||||
Ideally, the web application should be able to examine the requests in the backlog, and give priority to high value customers and administrative users.
|
||||
|
@ -72,20 +71,19 @@ You can assign priorities to each suspended request, so that high priority reque
|
|||
|
||||
===== Required JARs
|
||||
|
||||
To use the QoS Filter, these JAR files must be available in WEB-INF/lib:
|
||||
To use the QoS Filter, these JAR files must be available in `WEB-INF/lib`:
|
||||
|
||||
* $JETTY_HOME/lib/ext/jetty-util.jar
|
||||
* $JETTY_HOME/lib/ext/jetty-servlets.jar–contains QoSFilter
|
||||
* $JETTY_HOME/lib/jetty-util.jar
|
||||
* $JETTY_HOME/lib/jetty-servlets.jar – contains QoSFilter
|
||||
|
||||
===== Sample Configuration
|
||||
|
||||
Place the configuration in a webapp's web.xml or jetty-web.xml.
|
||||
The default configuration processes ten requests at a time, servicing more important requests first, and queuing up the rest.
|
||||
Place the configuration in a webapp's `web.xml` or `jetty-web.xml`.
|
||||
The default configuration processes ten requests at a time, servicing more important requests first and queuing up the rest.
|
||||
This example processes fifty requests at a time:
|
||||
|
||||
[source, xml, subs="{sub-order}"]
|
||||
----
|
||||
|
||||
<filter>
|
||||
<filter-name>QoSFilter</filter-name>
|
||||
<filter-class>org.eclipse.jetty.servlets.QoSFilter</filter-class>
|
||||
|
@ -94,35 +92,33 @@ This example processes fifty requests at a time:
|
|||
<param-value>50</param-value>
|
||||
</init-param>
|
||||
</filter>
|
||||
|
||||
|
||||
----
|
||||
|
||||
[[qos-filter-init]]
|
||||
===== Configuring QoS Filter Parameters
|
||||
|
||||
A semaphore polices the "maxRequests" limit.
|
||||
A semaphore polices the `maxRequests` limit.
|
||||
The filter waits a short time while attempting to acquire the semaphore.
|
||||
The "waitMs" init parameter controls the wait, avoiding the expense of a suspend if the semaphore is shortly available.
|
||||
If the semaphore cannot be obtained, Jetty suspends the request for the default suspend period of the container or the value set as the "suspendMs" init parameter.
|
||||
The `waitMs` init parameter controls the wait, avoiding the expense of a suspend if the semaphore is shortly available.
|
||||
If the semaphore cannot be obtained, Jetty suspends the request for the default suspend period of the container or the value set as the `suspendMs` init parameter.
|
||||
|
||||
The QoS filter uses the following init parameters:
|
||||
|
||||
maxRequests::
|
||||
the maximum number of requests to be serviced at a time. The default is 10.
|
||||
The maximum number of requests to be serviced at a time. The default is 10.
|
||||
maxPriority::
|
||||
the maximum valid priority that can be assigned to a request.
|
||||
The maximum valid priority that can be assigned to a request.
|
||||
A request with a high priority value is more important than a request with a low priority value. The default is 10.
|
||||
waitMS::
|
||||
waitMS–length of time, in milliseconds, to wait while trying to accept a new request.
|
||||
The length of time, in milliseconds, to wait while trying to accept a new request.
|
||||
Used when the maxRequests limit is reached.
|
||||
Default is 50 ms.
|
||||
suspendMS::
|
||||
length of time, in milliseconds, that the request will be suspended if it is not accepted immediately.
|
||||
Length of time, in milliseconds, that the request will be suspended if it is not accepted immediately.
|
||||
If not set, the container's default suspend period applies. Default is -1 ms.
|
||||
managedAttr::
|
||||
If set to true, then this servlet is set as a ServletContext attribute with the filter name as the attribute name.
|
||||
This allows a context external mechanism (for example, JMX via ContextHandler.MANAGED_ATTRIBUTES) to manage the configuration of the filter.
|
||||
If set to true, then this servlet is set as a `ServletContext` attribute with the filter name as the attribute name.
|
||||
This allows a context external mechanism (for example, JMX via `ContextHandler.MANAGED_ATTRIBUTES`) to manage the configuration of the filter.
|
||||
|
||||
===== Mapping to URLs
|
||||
|
||||
|
@ -131,13 +127,10 @@ In this example, a URL pattern applies the QoSFilter to every request within the
|
|||
|
||||
[source, xml, subs="{sub-order}"]
|
||||
----
|
||||
|
||||
<filter-mapping>
|
||||
<filter-name>QoSFilter</filter-name>
|
||||
<url-pattern>/*</url-pattern>
|
||||
</filter-mapping>
|
||||
|
||||
|
||||
----
|
||||
|
||||
===== Setting the Request Priority
|
||||
|
@ -149,13 +142,12 @@ The default request priorities assigned by the QoSFilter are:
|
|||
* 1 -- For any request with a non-new valid session
|
||||
* 0 -- For all other requests
|
||||
|
||||
To customize the priority, subclass QoSFilter and then override the getPriority(ServletRequest request) method to return an appropriate priority for the request.
|
||||
To customize the priority, subclass QoSFilter and then override the `getPriority(ServletRequest request)` method to return an appropriate priority for the request.
|
||||
You can then use this subclass as your QoS filter.
|
||||
Here's a trivial example:
|
||||
Here's an example:
|
||||
|
||||
[source, java, subs="{sub-order}"]
|
||||
----
|
||||
|
||||
public class ParsePriorityQoSFilter extends QoSFilter
|
||||
{
|
||||
protected int getPriority(ServletRequest request)
|
||||
|
@ -166,6 +158,4 @@ public class ParsePriorityQoSFilter extends QoSFilter
|
|||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
----
|
||||
|
|
|
@ -17,7 +17,8 @@
|
|||
[[rewrite-handler]]
|
||||
=== Rewrite Handler
|
||||
|
||||
The RewriteHandler matches a request against a set of rules, and modifies the request accordingly for any rules that match. The most common use is to rewrite request URIs, but it is capable of much more: rules can also be configured to redirect the response, set a cookie or response code on the response, modify the header, etc.
|
||||
The `RewriteHandler` matches a request against a set of rules, and modifies the request accordingly for any rules that match.
|
||||
The most common use is to rewrite request URIs, but it is capable of much more: rules can also be configured to redirect the response, set a cookie or response code on the response, modify the header, etc.
|
||||
|
||||
[[rewrite-handler-metadata]]
|
||||
==== Info
|
||||
|
@ -31,9 +32,7 @@ The standard Jetty distribution bundle contains the `jetty-rewrite` link:#startu
|
|||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
|
||||
$ java -jar start.jar --add-to-startd=rewrite
|
||||
|
||||
$ java -jar start.jar --add-to-start=rewrite
|
||||
....
|
||||
|
||||
_____
|
||||
|
@ -43,14 +42,14 @@ _____
|
|||
|
||||
==== Usage
|
||||
|
||||
The rewrite module enables the following jetty xml config file on the execution path:
|
||||
The rewrite module enables the following Jetty xml config file on the execution path:
|
||||
|
||||
[source, xml, subs="{sub-order}"]
|
||||
----
|
||||
include::{SRCDIR}/jetty-rewrite/src/main/config/etc/jetty-rewrite.xml[]
|
||||
----
|
||||
|
||||
As the commented out code shows, you configure the RewriteHandler by adding various rules.
|
||||
As the commented out code shows, you configure the `RewriteHandler` by adding various rules.
|
||||
|
||||
There is an example of link:#rewrite-rules[rules] configuration in the standard distribution in the `demo-base/etc/demo-rewrite-rules.xml` file:
|
||||
|
||||
|
@ -65,7 +64,6 @@ This is an example for embedded Jetty, which does something similar to the confi
|
|||
|
||||
[source, java, subs="{sub-order}"]
|
||||
----
|
||||
|
||||
Server server = new Server();
|
||||
|
||||
RewriteHandler rewrite = new RewriteHandler();
|
||||
|
@ -89,8 +87,6 @@ This is an example for embedded Jetty, which does something similar to the confi
|
|||
rewrite.addRule(reverse);
|
||||
|
||||
server.setHandler(rewrite);
|
||||
|
||||
|
||||
----
|
||||
|
||||
[[rewrite-rules]]
|
||||
|
@ -121,18 +117,18 @@ link:{JXURL}/org/eclipse/jetty/rewrite/handler/RedirectRegexRule.html[RedirectRe
|
|||
Redirect the response.
|
||||
link:{JXURL}/org/eclipse/jetty/rewrite/handler/RewriteRegexRule.html[RewriteRegexRule]::
|
||||
Rewrite the URI by matching with a regular expression.
|
||||
(The replacement string may use Template:$n to replace the nth capture group.)
|
||||
(The replacement string may use `Template:$n` to replace the nth capture group.)
|
||||
|
||||
===== HeaderRule
|
||||
|
||||
Match against request headers. Match either on a header name + specific value, or on the presence of a header (with any value).
|
||||
Match against request headers. Match either on a header name and specific value, or on the presence of a header (with any value).
|
||||
|
||||
link:{JXURL}/org/eclipse/jetty/rewrite/handler/ForwardedSchemeHeaderRule.html[ForwardedSchemaHeaderRule]::
|
||||
Set the scheme on the request (defaulting to https).
|
||||
Set the scheme on the request (defaulting to HTTPS).
|
||||
|
||||
===== Others
|
||||
|
||||
Oddball rules that defy classification.
|
||||
Extra rules that defy standard classification.
|
||||
|
||||
link:{JXURL}/org/eclipse/jetty/rewrite/handler/MsieSslRule.html[MsieSslRule]::
|
||||
Disables the keep alive for SSL from IE5 or IE6.
|
||||
|
@ -141,7 +137,8 @@ link:{JXURL}/org/eclipse/jetty/rewrite/handler/LegacyRule.html[LegacyRule]::
|
|||
|
||||
===== RuleContainer
|
||||
|
||||
Groups rules together. The contained rules will only be processed if the conditions for the RuleContainer evaluate to true.
|
||||
Groups rules together.
|
||||
The contained rules will only be processed if the conditions for the `RuleContainer` evaluate to true.
|
||||
|
||||
link:{JXURL}/org/eclipse/jetty/rewrite/handler/VirtualHostRuleContainer.html[VirtualHostRuleContainer]::
|
||||
Groups rules that apply only to a specific virtual host or a set of virtual hosts
|
||||
|
|
|
@ -29,29 +29,26 @@
|
|||
==== Usage
|
||||
|
||||
A handler that shuts the server down on a valid request.
|
||||
Used to do "soft" restarts from Java.
|
||||
If _exitJvm is set to true a hard System.exit() call is being made.
|
||||
This is used to perform "soft" restarts from Java.
|
||||
If `_exitJvm` is set to true a hard `System.exit()` call is being made.
|
||||
|
||||
This is an example of how you can setup this handler directly with the Server, it can be added as a part of handler chain or collection as well.
|
||||
This is an example of how you can setup this handler directly with the Server.
|
||||
It can also be added as a part of handler chain or collection.
|
||||
|
||||
[source, java, subs="{sub-order}"]
|
||||
----
|
||||
|
||||
Server server = new Server(8080);
|
||||
HandlerList handlers = new HandlerList();
|
||||
handlers.setHandlers(new Handler[]
|
||||
{ someOtherHandler, new ShutdownHandler(server,"secret password") });
|
||||
server.setHandler(handlers);
|
||||
server.start();
|
||||
|
||||
|
||||
----
|
||||
|
||||
And this is an example that you can use to call the shutdown handler from within java.
|
||||
This is an example that you can use to call the shutdown handler from within java.
|
||||
|
||||
[source, java, subs="{sub-order}"]
|
||||
----
|
||||
|
||||
public static void attemptShutdown(int port, String shutdownCookie) {
|
||||
try {
|
||||
URL url = new URL("http://localhost:" + port + "/shutdown?token=" + shutdownCookie);
|
||||
|
@ -66,6 +63,4 @@ And this is an example that you can use to call the shutdown handler from within
|
|||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
----
|
||||
|
|
|
@ -31,14 +31,13 @@
|
|||
|
||||
Jetty currently has two levels of request statistic collection:
|
||||
|
||||
* Subclasses of AbstractConnector class optionally can collect statistics about connections as well as number of requests.
|
||||
* The StatisticsHandler class may be used to collect request statistics.
|
||||
* Subclasses of `AbstractConnector` class optionally can collect statistics about connections as well as number of requests.
|
||||
* The `StatisticsHandler` class may be used to collect request statistics.
|
||||
|
||||
In addition to that, subclasses of AbstractSessionHandler class optionally can collect session statistics.
|
||||
In addition to these, subclasses of the `AbstractSessionHandler` class optionally can collect session statistics.
|
||||
|
||||
AbstractConnector and AbstractSessionHandler statistics are turned off by default and must either be configured manually for each instance or
|
||||
turned on via JMX interface.
|
||||
The Statistics Handler is not included in default Jetty configuration, and needs to be configured manually.
|
||||
`AbstractConnector` and `AbstractSessionHandler` statistics are turned off by default and must either be configured manually for each instance or turned on via JMX interface.
|
||||
The `StatisticsHandler` is not included in default Jetty configuration, and needs to be configured manually.
|
||||
|
||||
_____
|
||||
[NOTE]
|
||||
|
@ -50,14 +49,13 @@ _____
|
|||
|
||||
Detailed statistics on connection duration and number of requests are only collated when a connection is closed.
|
||||
The current and maximum number of connections are the only "live" statistics.
|
||||
To learn how to turn on connector statistics please see Jetty Statistics tutorial, although this is not recommended and it is best to use a JMX agent to select statistics only when needed.
|
||||
//To learn how to turn on connector statistics please see the Jetty Statistics tutorial, although this is not recommended and it is best to use a JMX agent to select statistics only when needed.
|
||||
|
||||
The following example shows how to turn on connector statistics in jetty xml.
|
||||
The following example shows how to turn on connector statistics in Jetty xml.
|
||||
This example comes from within `jetty-http.xml`.
|
||||
|
||||
[source, xml, subs="{sub-order}"]
|
||||
----
|
||||
|
||||
<Call name="addConnector">
|
||||
<Arg>
|
||||
<New class="org.eclipse.jetty.server.ServerConnector">
|
||||
|
@ -83,38 +81,31 @@ This example comes from within `jetty-http.xml`.
|
|||
</New>
|
||||
</Arg>
|
||||
</Call>
|
||||
|
||||
|
||||
----
|
||||
|
||||
[[request-statistics]]
|
||||
==== Request Statistics
|
||||
|
||||
To collect request statistics a StatisticsHandler must be configured as one of the handlers of the server.
|
||||
To collect request statistics a `StatisticsHandler` must be configured as one of the handlers of the server.
|
||||
Typically this can be done as the top level handler, but you may choose to configure a statistics handler for just one context by creating a context configuration file.
|
||||
Please note that `jetty-stats.xml` has to appear in the command line after the main Jetty configuration file as shown below.
|
||||
It should be able to be uncommented in the start.ini file.
|
||||
You can enable the `StatisticsHandler` by activating the `stats` modules on the command line.
|
||||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
$ java -jar start.jar OPTIONS=default etc/jetty.xml etc/jetty-stats.xml
|
||||
|
||||
$ java -jar {$jetty.home}/start.jar --add-to-start=stats
|
||||
....
|
||||
|
||||
Alternately, if you are making multiple changes to the Jetty configuration, you could include statistics handler configuration into your own jetty xml configuration.
|
||||
Alternately, if you are making multiple changes to the Jetty configuration, you could include statistics handler configuration into your own Jetty xml configuration.
|
||||
The following fragment shows how to configure a top level statistics handler:
|
||||
|
||||
[source, xml, subs="{sub-order}"]
|
||||
----
|
||||
|
||||
<Get id="oldhandler" name="handler" />
|
||||
<Set name="handler">
|
||||
<New id="StatsHandler" class="org.eclipse.jetty.server.handler.StatisticsHandler">
|
||||
<Set name="handler"><Ref refid="oldhandler" /></Set>
|
||||
</New>
|
||||
</Set>
|
||||
|
||||
|
||||
----
|
||||
|
||||
[[session-statistics]]
|
||||
|
|
|
@ -17,6 +17,6 @@
|
|||
[[runner]]
|
||||
== Jetty Runner
|
||||
|
||||
This chapter explains how to use the jetty-runner to run your webapps without needing an installation of jetty.
|
||||
This chapter explains how to use the `jetty-runner` to run your webapps without needing an installation of Jetty.
|
||||
|
||||
include::jetty-runner.adoc[]
|
|
@ -17,28 +17,27 @@
|
|||
[[jetty-runner]]
|
||||
=== Use Jetty without an installed distribution
|
||||
|
||||
The idea of the jetty-runner is extremely simple – run a webapp directly from the command line using a single jar and as much default configuration as possible.
|
||||
Of course, if your webapp is not so straightforward, the jetty-runner has command line options which allow
|
||||
you to customize the execution environment.
|
||||
The idea of the `jetty-runner` is extremely simple – run a webapp directly from the command line using a single jar file and as much default configuration as possible.
|
||||
Of course, if your webapp is not so straightforward, the `jetty-runner` has command line options which allow you to customize the execution environment.
|
||||
|
||||
[[jetty-runner-preparation]]
|
||||
==== Preparation
|
||||
|
||||
You will need the jetty-runner jar:
|
||||
You will need the `jetty-runner` jar:
|
||||
|
||||
1. http://central.maven.org/maven2/org/eclipse/jetty/jetty-runner/[Get] the jetty-runner jar, from http://search.maven.org/#browse[maven central]
|
||||
1. http://central.maven.org/maven2/org/eclipse/jetty/jetty-runner/[Get] the `jetty-runner` jar available at http://search.maven.org/#browse[maven central].
|
||||
|
||||
==== Deploying a simple context
|
||||
|
||||
Let's assume we have a very simple webapp, that does not need any resources from its environment, nor any configuration apart from the defaults.
|
||||
Starting it is as simple as doing the following:
|
||||
Let's assume we have a very simple webapp that does not need any resources from its environment, nor any configuration apart from the defaults.
|
||||
Starting it is as simple as performing the following:
|
||||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
> java -jar jetty-runner.jar simple.war
|
||||
....
|
||||
|
||||
This will start jetty on port 8080, and deploy the webapp to "/".
|
||||
This will start Jetty on port 8080, and deploy the webapp to `/`.
|
||||
|
||||
Your webapp does not have to be packed into a war, you can deploy a webapp that is a directory instead in the same way:
|
||||
|
||||
|
@ -47,7 +46,7 @@ Your webapp does not have to be packed into a war, you can deploy a webapp that
|
|||
> java -jar jetty-runner.jar simple
|
||||
....
|
||||
|
||||
In fact, the webapp does not have to be a war or even a directory, it can simply be a jetty link:#using-context-provider[context xml] file that describes your webapp:
|
||||
In fact, the webapp does not have to be a war or even a directory, it can simply be a Jetty link:#using-context-provider[context xml] file that describes your webapp:
|
||||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
|
@ -62,7 +61,7 @@ ____
|
|||
==== Deploying multiple contexts
|
||||
|
||||
If you have more than one webapp that must be deployed, simply provide them all on the command line.
|
||||
You can control the context paths for them using the "--path" parameter.
|
||||
You can control the context paths for them using the `--path` parameter.
|
||||
Here's an example of deploying 2 wars (although either or both of them could be unpacked directories instead):
|
||||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
|
@ -70,25 +69,25 @@ Here's an example of deploying 2 wars (although either or both of them could be
|
|||
> java -jar jetty-runner.jar --path /one my1.war --path /two my2.war
|
||||
....
|
||||
|
||||
If you have context xml files that describe your webapps, you can fully configure your webapps in them, and hence you don't need to use the command line switches.
|
||||
If you have context xml files that describe your webapps, you can fully configure your webapps in them and hence you don't need to use the command line switches.
|
||||
Just provide the list of context files like so:
|
||||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
> java -jar jetty-runner.jar my-first-context.xml my-second-context.xml my-third-context.xml
|
||||
|
||||
....
|
||||
|
||||
____
|
||||
[NOTE]
|
||||
The command line switches override configuration file settings. So, for example, you could set the context path for the webapp inside the context xml file, and use the --path switch to override it on the command line.
|
||||
Switched used on the command line override configuration file settings.
|
||||
So, for example, you could set the context path for the webapp inside the context xml file, and use the `--path` switch to override it on the command line.
|
||||
____
|
||||
|
||||
|
||||
===== Changing the default port
|
||||
|
||||
By default the jetty-runner will listen on port 8080.
|
||||
You can easily change this on the command line using the "--port" command.
|
||||
By default the `jetty-runner` will listen on port 8080.
|
||||
You can easily change this on the command line using the `--port` command.
|
||||
Here's an example that runs our simple.war on port 9090:
|
||||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
|
@ -98,22 +97,17 @@ Here's an example that runs our simple.war on port 9090:
|
|||
|
||||
===== Using jetty.xml files
|
||||
|
||||
Instead of, or in addition to using command line switches, you can use one or more jetty.xml files to configure the environment for your webapps.
|
||||
Here's an example where we apply two different jetty.xml files:
|
||||
Instead of, or in addition to, using command line switches, you can use one or more `jetty.xml` files to configure the environment for your webapps.
|
||||
Here's an example where we apply two different `jetty.xml` files:
|
||||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
> java -jar jetty-runner.jar --config jetty.xml --config jetty-https.xml simple.war
|
||||
....
|
||||
|
||||
____
|
||||
[NOTE]
|
||||
Switches on the command line take precedence over those defined in configuration files, so you can use the command line as overrides.
|
||||
____
|
||||
|
||||
===== Full configuration reference
|
||||
|
||||
You can see the fill set of configuration options using the --help switch:
|
||||
You can see the fill set of configuration options using the `--help` switch:
|
||||
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
|
@ -141,63 +135,57 @@ Server opts:
|
|||
[--config file]*n - each tuple specifies the name of a jetty xml config file to apply (in the order defined)
|
||||
Context opts:
|
||||
[[--path /path] context]*n - WAR file, web app dir or context xml file, optionally with a context path
|
||||
|
||||
----
|
||||
|
||||
Printing the version:::
|
||||
Print out the version of jetty and then exit immediately.
|
||||
Print out the version of Jetty and then exit immediately.
|
||||
+
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
> java -jar jetty-runner.jar --version
|
||||
|
||||
....
|
||||
|
||||
Configuring a request log:::
|
||||
Cause jetty to write a request log with the given name.
|
||||
If the file is prefixed with yyyy_mm_dd then the file will be automatically rolled over.
|
||||
Note that for finer grained configuration of the link:{JDURL}/org/eclipse/jetty/server/NCSARequestLog.html[request log], you will need to use a jetty xml file instead.
|
||||
Cause Jetty to write a request log with the given name.
|
||||
If the file is prefixed with `yyyy_mm_dd` then the file will be automatically rolled over.
|
||||
Note that for finer grained configuration of the link:{JDURL}/org/eclipse/jetty/server/NCSARequestLog.html[request log], you will need to use a Jetty xml file instead.
|
||||
+
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
> java -jar jetty-runner.jar --log yyyy_mm_dd-requests.log my.war
|
||||
|
||||
....
|
||||
|
||||
Configuring the output log:::
|
||||
Redirect the output of jetty logging to the named file.
|
||||
If the file is prefixed with yyyy_mm_dd then the file will be automatically rolled over.
|
||||
If the file is prefixed with `yyyy_mm_dd` then the file will be automatically rolled over.
|
||||
+
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
> java -jar jetty-runner.jar --out yyyy_mm_dd-output.log my.war
|
||||
|
||||
....
|
||||
|
||||
Configuring the interface for http:::
|
||||
Like jetty standalone, the default is for the connectors to listen on all interfaces on a machine.
|
||||
You can control that by specifying the name or ip address of the particular interface you wish to use with the --host argument:
|
||||
Like Jetty standalone, the default is for the connectors to listen on all interfaces on a machine.
|
||||
You can control that by specifying the name or ip address of the particular interface you wish to use with the `--host` argument:
|
||||
+
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
> java -jar jetty-runner.jar --host 192.168.22.19 my.war
|
||||
|
||||
....
|
||||
|
||||
Configuring the port for http:::
|
||||
The default port number is 8080.
|
||||
To link:#how-to-configure-connectors[configure a https connector], use a jetty xml config file instead.
|
||||
To link:#how-to-configure-connectors[configure a https connector], use a Jetty xml config file instead.
|
||||
+
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
> java -jar jetty-runner.jar --port 9090 my.war
|
||||
|
||||
....
|
||||
|
||||
Configuring stop:::
|
||||
You can configure a port number for jetty to listen on for a stop command, so you are able to stop it from a different terminal.
|
||||
This requires the use of a "secret" key, to prevent malicious or accidental termination.
|
||||
Use the --stop-port and --stop-key parameters as arguments to the jetty-runner:
|
||||
Use the `--stop-port` and `--stop-key` parameters as arguments to the `jetty-runner`:
|
||||
+
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
|
@ -205,64 +193,60 @@ Configuring stop:::
|
|||
|
||||
....
|
||||
+
|
||||
Then, to stop jetty from a different terminal, you need to supply the same port and key information.
|
||||
For this you'll either need a local installation of jetty, the link:#jetty-maven-plugin[jetty-maven-plugin], the link:#jetty-ant[jetty-ant plugin], or write a custom class.
|
||||
Here's how to use a jetty installation to perform a stop:
|
||||
Then, to stop Jetty from a different terminal, you need to supply the same port and key information.
|
||||
For this you'll either need a local installation of Jetty, the link:#jetty-maven-plugin[jetty-maven-plugin], the link:#jetty-ant[jetty-ant plugin], or a custom class.
|
||||
Here's how to use a Jetty installation to perform a stop:
|
||||
+
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
> java -jar start.jar --stop-port 8181 --stop-key abc123 --stop
|
||||
|
||||
....
|
||||
|
||||
Configuring the container classpath:::
|
||||
With a local installation of jetty, you add jars and classes to the container's classpath by putting them in the $JETTY_HOME/lib directory.
|
||||
With the jetty-runner, you can use the --lib, --jar and --classes arguments instead to achieve the same thing.
|
||||
With a local installation of Jetty, you add jars and classes to the container's classpath by putting them in the `{$jetty.base}/lib` directory.
|
||||
With the `jetty-runner`, you can use the `--lib`, `--jar` and `--classes` arguments instead to achieve the same thing.
|
||||
+
|
||||
--lib adds the location of a directory which contains jars to add to the container classpath.
|
||||
You can add 1 or more. Here's an example of configuring 2 directories:
|
||||
`--lib` adds the location of a directory which contains jars to add to the container classpath.
|
||||
You can add 1 or more.
|
||||
Here's an example of configuring 2 directories:
|
||||
+
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
> java -jar jetty-runner.jar --lib /usr/local/external/lib --lib $HOME/external-other/lib my.war
|
||||
|
||||
....
|
||||
+
|
||||
--jar adds a single jar file to the container classpath.
|
||||
`--jar` adds a single jar file to the container classpath.
|
||||
You can add 1 or more.
|
||||
Here's an example of configuring 3 extra jars:
|
||||
+
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
> java -jar jetty-runner.jar --jar /opt/stuff/jars/jar1.jar --jar $HOME/jars/jar2.jar --jar /usr/local/proj/jars/jar3.jar my.war
|
||||
|
||||
....
|
||||
+
|
||||
--classes add the location of a directory containing classes to add to the container classpath.
|
||||
`--classes` add the location of a directory containing classes to add to the container classpath.
|
||||
You can add 1 or more.
|
||||
Here's an example of configuring a single extra classes dir:
|
||||
+
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
> java -jar jetty-runner.jar --classes /opt/stuff/classes my.war
|
||||
|
||||
....
|
||||
|
||||
Gathering statistics:::
|
||||
If statistics gathering is enabled, then they are viewable by surfing
|
||||
to the context /stats. You may optionally protect access to that
|
||||
context with a password. Here's an example of enabling statistics,
|
||||
with no password protection:
|
||||
If statistics gathering is enabled, then they are viewable by surfing to the context `/stats`.
|
||||
You may optionally protect access to that context with a password.
|
||||
Here's an example of enabling statistics, with no password protection:
|
||||
+
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
> java -jar jetty-runner.jar --stats unsecure my.war
|
||||
|
||||
....
|
||||
+
|
||||
If we wished to protect access to the /stats context, we would provide the location of a jetty realm configuration file containing authentication and authorization information.
|
||||
For example, we could use the following example realm file from the jetty distribution:
|
||||
If we wished to protect access to the `/stats` context, we would provide the location of a Jetty realm configuration file containing authentication and authorization information.
|
||||
For example, we could use the following example realm file from the Jetty distribution:
|
||||
+
|
||||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
jetty: MD5:164c88b302622e17050af52c89945d44,user
|
||||
admin: CRYPT:adpexzg3FUZAk,server-administrator,content-administrator,admin
|
||||
|
@ -271,7 +255,6 @@ plain: plain,user
|
|||
user: password,user
|
||||
# This entry is for digest auth. The credential is a MD5 hash of username:realmname:password
|
||||
digest: MD5:6e120743ad67abfbc385bc2bb754e297,user
|
||||
|
||||
....
|
||||
+
|
||||
Assuming we've copied it into the local directory, we would apply it like so
|
||||
|
@ -279,10 +262,9 @@ Assuming we've copied it into the local directory, we would apply it like so
|
|||
[source, screen, subs="{sub-order}"]
|
||||
....
|
||||
> java -jar jetty-runner.jar --stats realm.properties my.war
|
||||
|
||||
....
|
||||
+
|
||||
After surfing to http://localhost:8080/ a few times, we can surf to the stats servlet on http://localhost:8080/stats to see the output:
|
||||
After navigating to http://localhost:8080/ a few times, we can point to the stats servlet on http://localhost:8080/stats to see the output:
|
||||
+
|
||||
....
|
||||
Statistics:
|
||||
|
@ -339,4 +321,3 @@ Memory:
|
|||
Heap memory usage: 49194840 bytes
|
||||
Non-heap memory usage: 12611696 bytes
|
||||
....
|
||||
|
||||
|
|
|
@ -70,7 +70,7 @@ public class RequestLogTest
|
|||
@Test
|
||||
public void testNotHandled() throws Exception
|
||||
{
|
||||
_connector.getResponses("GET /foo HTTP/1.0\n\n");
|
||||
_connector.getResponse("GET /foo HTTP/1.0\n\n");
|
||||
String log = _log.exchange(null,5,TimeUnit.SECONDS);
|
||||
assertThat(log,containsString("GET /foo HTTP/1.0\" 404 "));
|
||||
}
|
||||
|
@ -78,17 +78,17 @@ public class RequestLogTest
|
|||
@Test
|
||||
public void testRequestLine() throws Exception
|
||||
{
|
||||
_connector.getResponses("GET /foo?data=1 HTTP/1.0\nhost: host:80\n\n");
|
||||
_connector.getResponse("GET /foo?data=1 HTTP/1.0\nhost: host:80\n\n");
|
||||
String log = _log.exchange(null,5,TimeUnit.SECONDS);
|
||||
// TODO should be without host (https://bugs.eclipse.org/bugs/show_bug.cgi?id=480276)
|
||||
// assertThat(log,containsString("GET /foo?data=1 HTTP/1.0\" 200 "));
|
||||
assertThat(log,containsString("GET //host:80/foo?data=1 HTTP/1.0\" 200 "));
|
||||
|
||||
_connector.getResponses("GET //bad/foo?data=1 HTTP/1.0\n\n");
|
||||
_connector.getResponse("GET //bad/foo?data=1 HTTP/1.0\n\n");
|
||||
log = _log.exchange(null,5,TimeUnit.SECONDS);
|
||||
assertThat(log,containsString("GET //bad/foo?data=1 HTTP/1.0\" 200 "));
|
||||
|
||||
_connector.getResponses("GET http://host:80/foo?data=1 HTTP/1.0\n\n");
|
||||
_connector.getResponse("GET http://host:80/foo?data=1 HTTP/1.0\n\n");
|
||||
log = _log.exchange(null,5,TimeUnit.SECONDS);
|
||||
assertThat(log,containsString("GET http://host:80/foo?data=1 HTTP/1.0\" 200 "));
|
||||
}
|
||||
|
@ -96,7 +96,7 @@ public class RequestLogTest
|
|||
@Test
|
||||
public void testSmallData() throws Exception
|
||||
{
|
||||
_connector.getResponses("GET /foo?data=42 HTTP/1.0\n\n");
|
||||
_connector.getResponse("GET /foo?data=42 HTTP/1.0\n\n");
|
||||
String log = _log.exchange(null,5,TimeUnit.SECONDS);
|
||||
assertThat(log,containsString("GET /foo?"));
|
||||
assertThat(log,containsString(" 200 42 "));
|
||||
|
@ -105,7 +105,7 @@ public class RequestLogTest
|
|||
@Test
|
||||
public void testBigData() throws Exception
|
||||
{
|
||||
_connector.getResponses("GET /foo?data=102400 HTTP/1.0\n\n");
|
||||
_connector.getResponse("GET /foo?data=102400 HTTP/1.0\n\n");
|
||||
String log = _log.exchange(null,5,TimeUnit.SECONDS);
|
||||
assertThat(log,containsString("GET /foo?"));
|
||||
assertThat(log,containsString(" 200 102400 "));
|
||||
|
@ -114,7 +114,7 @@ public class RequestLogTest
|
|||
@Test
|
||||
public void testStatus() throws Exception
|
||||
{
|
||||
_connector.getResponses("GET /foo?status=206 HTTP/1.0\n\n");
|
||||
_connector.getResponse("GET /foo?status=206 HTTP/1.0\n\n");
|
||||
String log = _log.exchange(null,5,TimeUnit.SECONDS);
|
||||
assertThat(log,containsString("GET /foo?"));
|
||||
assertThat(log,containsString(" 206 0 "));
|
||||
|
@ -123,7 +123,7 @@ public class RequestLogTest
|
|||
@Test
|
||||
public void testStatusData() throws Exception
|
||||
{
|
||||
_connector.getResponses("GET /foo?status=206&data=42 HTTP/1.0\n\n");
|
||||
_connector.getResponse("GET /foo?status=206&data=42 HTTP/1.0\n\n");
|
||||
String log = _log.exchange(null,5,TimeUnit.SECONDS);
|
||||
assertThat(log,containsString("GET /foo?"));
|
||||
assertThat(log,containsString(" 206 42 "));
|
||||
|
@ -132,7 +132,7 @@ public class RequestLogTest
|
|||
@Test
|
||||
public void testBadRequest() throws Exception
|
||||
{
|
||||
_connector.getResponses("XXXXXXXXXXXX\n\n");
|
||||
_connector.getResponse("XXXXXXXXXXXX\n\n");
|
||||
String log = _log.exchange(null,5,TimeUnit.SECONDS);
|
||||
assertThat(log,containsString("\"- - -\""));
|
||||
assertThat(log,containsString(" 400 0 "));
|
||||
|
@ -141,7 +141,7 @@ public class RequestLogTest
|
|||
@Test
|
||||
public void testBadCharacter() throws Exception
|
||||
{
|
||||
_connector.getResponses("METHOD /f\00o HTTP/1.0\n\n");
|
||||
_connector.getResponse("METHOD /f\00o HTTP/1.0\n\n");
|
||||
String log = _log.exchange(null,5,TimeUnit.SECONDS);
|
||||
assertThat(log,containsString("\"- - -\""));
|
||||
assertThat(log,containsString(" 400 0 "));
|
||||
|
@ -150,7 +150,7 @@ public class RequestLogTest
|
|||
@Test
|
||||
public void testBadVersion() throws Exception
|
||||
{
|
||||
_connector.getResponses("METHOD /foo HTTP/9\n\n");
|
||||
_connector.getResponse("METHOD /foo HTTP/9\n\n");
|
||||
String log = _log.exchange(null,5,TimeUnit.SECONDS);
|
||||
assertThat(log,containsString("\"- - -\""));
|
||||
assertThat(log,containsString(" 400 0 "));
|
||||
|
@ -162,7 +162,7 @@ public class RequestLogTest
|
|||
char[] chars = new char[10000];
|
||||
Arrays.fill(chars,'o');
|
||||
String ooo = new String(chars);
|
||||
_connector.getResponses("METHOD /f"+ooo+" HTTP/1.0\n\n");
|
||||
_connector.getResponse("METHOD /f"+ooo+" HTTP/1.0\n\n");
|
||||
String log = _log.exchange(null,5,TimeUnit.SECONDS);
|
||||
assertThat(log,containsString("\"- - -\""));
|
||||
assertThat(log,containsString(" 414 0 "));
|
||||
|
@ -174,7 +174,7 @@ public class RequestLogTest
|
|||
char[] chars = new char[10000];
|
||||
Arrays.fill(chars,'o');
|
||||
String ooo = new String(chars);
|
||||
_connector.getResponses("METHOD /foo HTTP/1.0\name: f+"+ooo+"\n\n");
|
||||
_connector.getResponse("METHOD /foo HTTP/1.0\name: f+"+ooo+"\n\n");
|
||||
String log = _log.exchange(null,5,TimeUnit.SECONDS);
|
||||
assertThat(log,containsString("\"METHOD /foo HTTP/1.0\""));
|
||||
assertThat(log,containsString(" 431 0 "));
|
||||
|
@ -183,7 +183,7 @@ public class RequestLogTest
|
|||
@Test
|
||||
public void testBadRequestNoHost() throws Exception
|
||||
{
|
||||
_connector.getResponses("GET /foo HTTP/1.1\n\n");
|
||||
_connector.getResponse("GET /foo HTTP/1.1\n\n");
|
||||
String log = _log.exchange(null,5,TimeUnit.SECONDS);
|
||||
assertThat(log,containsString("GET /foo "));
|
||||
assertThat(log,containsString(" 400 0 "));
|
||||
|
@ -192,7 +192,7 @@ public class RequestLogTest
|
|||
@Test
|
||||
public void testUseragentWithout() throws Exception
|
||||
{
|
||||
_connector.getResponses("GET http://[:1]/foo HTTP/1.1\nReferer: http://other.site\n\n");
|
||||
_connector.getResponse("GET http://[:1]/foo HTTP/1.1\nReferer: http://other.site\n\n");
|
||||
String log = _log.exchange(null,5,TimeUnit.SECONDS);
|
||||
assertThat(log,containsString("GET http://[:1]/foo "));
|
||||
assertThat(log,containsString(" 400 0 \"http://other.site\" \"-\" - "));
|
||||
|
@ -201,7 +201,7 @@ public class RequestLogTest
|
|||
@Test
|
||||
public void testUseragentWith() throws Exception
|
||||
{
|
||||
_connector.getResponses("GET http://[:1]/foo HTTP/1.1\nReferer: http://other.site\nUser-Agent: Mozilla/5.0 (test)\n\n");
|
||||
_connector.getResponse("GET http://[:1]/foo HTTP/1.1\nReferer: http://other.site\nUser-Agent: Mozilla/5.0 (test)\n\n");
|
||||
String log = _log.exchange(null,5,TimeUnit.SECONDS);
|
||||
assertThat(log,containsString("GET http://[:1]/foo "));
|
||||
assertThat(log,containsString(" 400 0 \"http://other.site\" \"Mozilla/5.0 (test)\" - "));
|
||||
|
|
Loading…
Reference in New Issue