Package org.eclipse.jetty.server.handler
Class StatisticsHandler
- java.lang.Object
-
- org.eclipse.jetty.util.component.AbstractLifeCycle
-
- org.eclipse.jetty.util.component.ContainerLifeCycle
-
- org.eclipse.jetty.server.handler.AbstractHandler
-
- org.eclipse.jetty.server.handler.AbstractHandlerContainer
-
- org.eclipse.jetty.server.handler.HandlerWrapper
-
- org.eclipse.jetty.server.handler.StatisticsHandler
-
- All Implemented Interfaces:
Handler
,HandlerContainer
,Container
,Destroyable
,Dumpable
,Dumpable.DumpableContainer
,Graceful
,LifeCycle
@ManagedObject("Request Statistics Gathering") public class StatisticsHandler extends HandlerWrapper implements Graceful
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class org.eclipse.jetty.server.handler.AbstractHandler
AbstractHandler.ErrorDispatchHandler
-
Nested classes/interfaces inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
AbstractLifeCycle.AbstractLifeCycleListener
-
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Container
Container.InheritedListener, Container.Listener
-
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Dumpable
Dumpable.DumpableContainer
-
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Graceful
Graceful.Shutdown
-
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.component.LifeCycle
LifeCycle.Listener
-
-
Field Summary
-
Fields inherited from class org.eclipse.jetty.server.handler.HandlerWrapper
_handler
-
-
Constructor Summary
Constructors Constructor Description StatisticsHandler()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected void
doStart()
Starts the managed lifecycle beans in the order they were added.protected void
doStop()
Stops the managed lifecycle beans in the reverse order they were added.int
getAsyncDispatches()
int
getAsyncRequests()
int
getAsyncRequestsWaiting()
int
getAsyncRequestsWaitingMax()
int
getDispatched()
int
getDispatchedActive()
int
getDispatchedActiveMax()
long
getDispatchedTimeMax()
double
getDispatchedTimeMean()
double
getDispatchedTimeStdDev()
long
getDispatchedTimeTotal()
int
getErrors()
int
getExpires()
boolean
getGracefulShutdownWaitsForRequests()
int
getRequests()
int
getRequestsActive()
int
getRequestsActiveMax()
long
getRequestTimeMax()
double
getRequestTimeMean()
double
getRequestTimeStdDev()
long
getRequestTimeTotal()
int
getResponses1xx()
int
getResponses2xx()
int
getResponses3xx()
int
getResponses4xx()
int
getResponses5xx()
long
getResponsesBytesTotal()
int
getResponsesThrown()
long
getStatsOnMs()
void
handle(java.lang.String path, Request baseRequest, javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response)
Handle a request.boolean
isShutdown()
void
setGracefulShutdownWaitsForRequests(boolean gracefulShutdownWaitsForRequests)
Set whether the graceful shutdown should wait for all requests to complete including async requests which are not currently dispatched, or whether it should only wait for all the actively dispatched requests to complete.java.util.concurrent.Future<java.lang.Void>
shutdown()
void
statsReset()
Resets the current request statistics.java.lang.String
toStatsHTML()
java.lang.String
toString()
protected void
updateResponse(Request request, boolean thrownError)
-
Methods inherited from class org.eclipse.jetty.server.handler.HandlerWrapper
destroy, expandChildren, getHandler, getHandlers, insertHandler, setHandler
-
Methods inherited from class org.eclipse.jetty.server.handler.AbstractHandlerContainer
doShutdown, expandHandler, findContainerOf, getChildHandlerByClass, getChildHandlers, getChildHandlersByClass, setServer
-
Methods inherited from class org.eclipse.jetty.server.handler.AbstractHandler
doError, getServer
-
Methods inherited from class org.eclipse.jetty.util.component.ContainerLifeCycle
addBean, addBean, addEventListener, addManaged, contains, dump, dump, dump, dump, dump, dumpBeans, dumpObject, dumpObjects, dumpStdErr, dumpThis, getBean, getBeans, getBeans, getContainedBeans, getContainedBeans, isAuto, isManaged, isUnmanaged, manage, removeBean, removeBeans, removeEventListener, setBeans, setStopTimeout, start, stop, unmanage, updateBean, updateBean, updateBeans
-
Methods inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
addLifeCycleListener, getState, getState, getStopTimeout, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, removeLifeCycleListener, start, stop
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.eclipse.jetty.util.component.Dumpable.DumpableContainer
isDumpable
-
Methods inherited from interface org.eclipse.jetty.util.component.LifeCycle
addLifeCycleListener, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, removeLifeCycleListener, start, stop
-
-
-
-
Method Detail
-
statsReset
@ManagedOperation(value="resets statistics", impact="ACTION") public void statsReset()
Resets the current request statistics.
-
handle
public void handle(java.lang.String path, Request baseRequest, javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response) throws java.io.IOException, javax.servlet.ServletException
Description copied from interface:Handler
Handle a request.- Specified by:
handle
in interfaceHandler
- Overrides:
handle
in classHandlerWrapper
- Parameters:
path
- The target of the request - either a URI or a name.baseRequest
- The original unwrapped request object.request
- The request either as theRequest
object or a wrapper of that request. The
method can be used access the Request object if required.HttpConnection.getCurrentConnection()
.getHttpChannel()
.getRequest()
response
- The response as theResponse
object or a wrapper of that request. The
method can be used access the Response object if required.HttpConnection.getCurrentConnection()
.getHttpChannel()
.getResponse()
- Throws:
java.io.IOException
- if unable to handle the request or response processingjavax.servlet.ServletException
- if unable to handle the request or response due to underlying servlet issue
-
updateResponse
protected void updateResponse(Request request, boolean thrownError)
-
doStart
protected void doStart() throws java.lang.Exception
Description copied from class:ContainerLifeCycle
Starts the managed lifecycle beans in the order they were added.- Overrides:
doStart
in classAbstractHandler
- Throws:
java.lang.Exception
-
doStop
protected void doStop() throws java.lang.Exception
Description copied from class:ContainerLifeCycle
Stops the managed lifecycle beans in the reverse order they were added.- Overrides:
doStop
in classAbstractHandler
- Throws:
java.lang.Exception
-
setGracefulShutdownWaitsForRequests
public void setGracefulShutdownWaitsForRequests(boolean gracefulShutdownWaitsForRequests)
Set whether the graceful shutdown should wait for all requests to complete including async requests which are not currently dispatched, or whether it should only wait for all the actively dispatched requests to complete.- Parameters:
gracefulShutdownWaitsForRequests
- true to wait for async requests on graceful shutdown.
-
getGracefulShutdownWaitsForRequests
@ManagedAttribute("if graceful shutdown will wait for all requests") public boolean getGracefulShutdownWaitsForRequests()
- Returns:
- whether the graceful shutdown will wait for all requests to complete including async requests which are not currently dispatched, or whether it will only wait for all the actively dispatched requests to complete.
- See Also:
getAsyncDispatches()
-
getRequests
@ManagedAttribute("number of requests") public int getRequests()
- Returns:
- the number of requests handled by this handler
since
statsReset()
was last called, excluding active requests - See Also:
getAsyncDispatches()
-
getRequestsActive
@ManagedAttribute("number of requests currently active") public int getRequestsActive()
- Returns:
- the number of requests currently active.
since
statsReset()
was last called.
-
getRequestsActiveMax
@ManagedAttribute("maximum number of active requests") public int getRequestsActiveMax()
- Returns:
- the maximum number of active requests
since
statsReset()
was last called.
-
getRequestTimeMax
@ManagedAttribute("maximum time spend handling requests (in ms)") public long getRequestTimeMax()
- Returns:
- the maximum time (in milliseconds) of request handling
since
statsReset()
was last called.
-
getRequestTimeTotal
@ManagedAttribute("total time spend in all request handling (in ms)") public long getRequestTimeTotal()
- Returns:
- the total time (in milliseconds) of requests handling
since
statsReset()
was last called.
-
getRequestTimeMean
@ManagedAttribute("mean time spent handling requests (in ms)") public double getRequestTimeMean()
- Returns:
- the mean time (in milliseconds) of request handling
since
statsReset()
was last called. - See Also:
getRequestTimeTotal()
,getRequests()
-
getRequestTimeStdDev
@ManagedAttribute("standard deviation for request handling (in ms)") public double getRequestTimeStdDev()
- Returns:
- the standard deviation of time (in milliseconds) of request handling
since
statsReset()
was last called. - See Also:
getRequestTimeTotal()
,getRequests()
-
getDispatched
@ManagedAttribute("number of dispatches") public int getDispatched()
- Returns:
- the number of dispatches seen by this handler
since
statsReset()
was last called, excluding active dispatches
-
getDispatchedActive
@ManagedAttribute("number of dispatches currently active") public int getDispatchedActive()
- Returns:
- the number of dispatches currently in this handler
since
statsReset()
was last called, including resumed requests
-
getDispatchedActiveMax
@ManagedAttribute("maximum number of active dispatches being handled") public int getDispatchedActiveMax()
- Returns:
- the max number of dispatches currently in this handler
since
statsReset()
was last called, including resumed requests
-
getDispatchedTimeMax
@ManagedAttribute("maximum time spend in dispatch handling") public long getDispatchedTimeMax()
- Returns:
- the maximum time (in milliseconds) of request dispatch
since
statsReset()
was last called.
-
getDispatchedTimeTotal
@ManagedAttribute("total time spent in dispatch handling (in ms)") public long getDispatchedTimeTotal()
- Returns:
- the total time (in milliseconds) of requests handling
since
statsReset()
was last called.
-
getDispatchedTimeMean
@ManagedAttribute("mean time spent in dispatch handling (in ms)") public double getDispatchedTimeMean()
- Returns:
- the mean time (in milliseconds) of request handling
since
statsReset()
was last called. - See Also:
getRequestTimeTotal()
,getRequests()
-
getDispatchedTimeStdDev
@ManagedAttribute("standard deviation for dispatch handling (in ms)") public double getDispatchedTimeStdDev()
- Returns:
- the standard deviation of time (in milliseconds) of request handling
since
statsReset()
was last called. - See Also:
getRequestTimeTotal()
,getRequests()
-
getAsyncRequests
@ManagedAttribute("total number of async requests") public int getAsyncRequests()
- Returns:
- the number of requests handled by this handler
since
statsReset()
was last called, including resumed requests - See Also:
getAsyncDispatches()
-
getAsyncRequestsWaiting
@ManagedAttribute("currently waiting async requests") public int getAsyncRequestsWaiting()
- Returns:
- the number of requests currently suspended.
since
statsReset()
was last called.
-
getAsyncRequestsWaitingMax
@ManagedAttribute("maximum number of waiting async requests") public int getAsyncRequestsWaitingMax()
- Returns:
- the maximum number of current suspended requests
since
statsReset()
was last called.
-
getAsyncDispatches
@ManagedAttribute("number of requested that have been asynchronously dispatched") public int getAsyncDispatches()
- Returns:
- the number of requests that have been asynchronously dispatched
-
getExpires
@ManagedAttribute("number of async requests requests that have expired") public int getExpires()
- Returns:
- the number of requests that expired while suspended.
- See Also:
getAsyncDispatches()
-
getErrors
@ManagedAttribute("number of async errors that occurred") public int getErrors()
- Returns:
- the number of async errors that occurred.
- See Also:
getAsyncDispatches()
-
getResponses1xx
@ManagedAttribute("number of requests with 1xx response status") public int getResponses1xx()
- Returns:
- the number of responses with a 1xx status returned by this context
since
statsReset()
was last called.
-
getResponses2xx
@ManagedAttribute("number of requests with 2xx response status") public int getResponses2xx()
- Returns:
- the number of responses with a 2xx status returned by this context
since
statsReset()
was last called.
-
getResponses3xx
@ManagedAttribute("number of requests with 3xx response status") public int getResponses3xx()
- Returns:
- the number of responses with a 3xx status returned by this context
since
statsReset()
was last called.
-
getResponses4xx
@ManagedAttribute("number of requests with 4xx response status") public int getResponses4xx()
- Returns:
- the number of responses with a 4xx status returned by this context
since
statsReset()
was last called.
-
getResponses5xx
@ManagedAttribute("number of requests with 5xx response status") public int getResponses5xx()
- Returns:
- the number of responses with a 5xx status returned by this context
since
statsReset()
was last called.
-
getResponsesThrown
@ManagedAttribute("number of requests that threw an exception during handling") public int getResponsesThrown()
- Returns:
- the number of requests that threw an exception during handling
since
statsReset()
was last called. These may have resulted in some error responses which were unrecorded by theStatisticsHandler
.
-
getStatsOnMs
@ManagedAttribute("time in milliseconds stats have been collected for") public long getStatsOnMs()
- Returns:
- the milliseconds since the statistics were started with
statsReset()
.
-
getResponsesBytesTotal
@ManagedAttribute("total number of bytes across all responses") public long getResponsesBytesTotal()
- Returns:
- the total bytes of content sent in responses
-
toStatsHTML
public java.lang.String toStatsHTML()
-
shutdown
public java.util.concurrent.Future<java.lang.Void> shutdown()
-
isShutdown
public boolean isShutdown()
- Specified by:
isShutdown
in interfaceGraceful
-
toString
public java.lang.String toString()
- Overrides:
toString
in classAbstractLifeCycle
-
-