Merge pull request #4856 from lorban/jetty-9.4.x-4847-socket-configuration-properties
introduce socket configuration properties in Jetty XML files
This commit is contained in:
commit
ad72d29f2a
|
@ -34,6 +34,10 @@
|
|||
<Set name="idleTimeout"><Property name="jetty.http.idleTimeout" deprecated="http.timeout" default="30000"/></Set>
|
||||
<Set name="acceptorPriorityDelta"><Property name="jetty.http.acceptorPriorityDelta" deprecated="http.acceptorPriorityDelta" default="0"/></Set>
|
||||
<Set name="acceptQueueSize"><Property name="jetty.http.acceptQueueSize" deprecated="http.acceptQueueSize" default="0"/></Set>
|
||||
<Set name="reuseAddress"><Property name="jetty.http.reuseAddress" default="true"/></Set>
|
||||
<Set name="acceptedTcpNoDelay"><Property name="jetty.http.acceptedTcpNoDelay" default="true"/></Set>
|
||||
<Set name="acceptedReceiveBufferSize"><Property name="jetty.http.acceptedReceiveBufferSize" default="-1"/></Set>
|
||||
<Set name="acceptedSendBufferSize"><Property name="jetty.http.acceptedSendBufferSize" default="-1"/></Set>
|
||||
<Get name="SelectorManager">
|
||||
<Set name="connectTimeout"><Property name="jetty.http.connectTimeout" default="15000"/></Set>
|
||||
</Get>
|
||||
|
|
|
@ -26,6 +26,10 @@
|
|||
<Set name="idleTimeout"><Property name="jetty.ssl.idleTimeout" deprecated="ssl.timeout" default="30000"/></Set>
|
||||
<Set name="acceptorPriorityDelta"><Property name="jetty.ssl.acceptorPriorityDelta" deprecated="ssl.acceptorPriorityDelta" default="0"/></Set>
|
||||
<Set name="acceptQueueSize"><Property name="jetty.ssl.acceptQueueSize" deprecated="ssl.acceptQueueSize" default="0"/></Set>
|
||||
<Set name="reuseAddress"><Property name="jetty.ssl.reuseAddress" default="true"/></Set>
|
||||
<Set name="acceptedTcpNoDelay"><Property name="jetty.ssl.acceptedTcpNoDelay" default="true"/></Set>
|
||||
<Set name="acceptedReceiveBufferSize"><Property name="jetty.ssl.acceptedReceiveBufferSize" default="-1"/></Set>
|
||||
<Set name="acceptedSendBufferSize"><Property name="jetty.ssl.acceptedSendBufferSize" default="-1"/></Set>
|
||||
<Get name="SelectorManager">
|
||||
<Set name="connectTimeout"><Property name="jetty.ssl.connectTimeout" default="15000"/></Set>
|
||||
</Get>
|
||||
|
|
|
@ -39,6 +39,21 @@ etc/jetty-http.xml
|
|||
## Thread priority delta to give to acceptor threads
|
||||
# jetty.http.acceptorPriorityDelta=0
|
||||
|
||||
## The requested maximum length of the queue of incoming connections.
|
||||
# jetty.http.acceptQueueSize=0
|
||||
|
||||
## Enable/disable the SO_REUSEADDR socket option.
|
||||
# jetty.http.reuseAddress=true
|
||||
|
||||
## Enable/disable TCP_NODELAY on accepted sockets.
|
||||
# jetty.http.acceptedTcpNoDelay=true
|
||||
|
||||
## The SO_RCVBUF option to set on accepted sockets. A value of -1 indicates that it is left to its default value.
|
||||
# jetty.http.acceptedReceiveBufferSize=-1
|
||||
|
||||
## The SO_SNDBUF option to set on accepted sockets. A value of -1 indicates that it is left to its default value.
|
||||
# jetty.http.acceptedSendBufferSize=-1
|
||||
|
||||
## Connect Timeout in milliseconds
|
||||
# jetty.http.connectTimeout=15000
|
||||
|
||||
|
|
|
@ -43,6 +43,21 @@ basehome:modules/ssl/keystore|etc/keystore
|
|||
## Thread priority delta to give to acceptor threads
|
||||
# jetty.ssl.acceptorPriorityDelta=0
|
||||
|
||||
## The requested maximum length of the queue of incoming connections.
|
||||
# jetty.ssl.acceptQueueSize=0
|
||||
|
||||
## Enable/disable the SO_REUSEADDR socket option.
|
||||
# jetty.ssl.reuseAddress=true
|
||||
|
||||
## Enable/disable TCP_NODELAY on accepted sockets.
|
||||
# jetty.ssl.acceptedTcpNoDelay=true
|
||||
|
||||
## The SO_RCVBUF option to set on accepted sockets. A value of -1 indicates that it is left to its default value.
|
||||
# jetty.ssl.acceptedReceiveBufferSize=-1
|
||||
|
||||
## The SO_SNDBUF option to set on accepted sockets. A value of -1 indicates that it is left to its default value.
|
||||
# jetty.ssl.acceptedSendBufferSize=-1
|
||||
|
||||
## Connect Timeout in milliseconds
|
||||
# jetty.ssl.connectTimeout=15000
|
||||
|
||||
|
|
|
@ -83,6 +83,9 @@ public class ServerConnector extends AbstractNetworkConnector
|
|||
private volatile int _localPort = -1;
|
||||
private volatile int _acceptQueueSize = 0;
|
||||
private volatile boolean _reuseAddress = true;
|
||||
private volatile boolean _acceptedTcpNoDelay = true;
|
||||
private volatile int _acceptedReceiveBufferSize = -1;
|
||||
private volatile int _acceptedSendBufferSize = -1;
|
||||
|
||||
/**
|
||||
* <p>Construct a ServerConnector with a private instance of {@link HttpConnectionFactory} as the only factory.</p>
|
||||
|
@ -399,7 +402,11 @@ public class ServerConnector extends AbstractNetworkConnector
|
|||
{
|
||||
try
|
||||
{
|
||||
socket.setTcpNoDelay(true);
|
||||
socket.setTcpNoDelay(_acceptedTcpNoDelay);
|
||||
if (_acceptedReceiveBufferSize > -1)
|
||||
socket.setReceiveBufferSize(_acceptedReceiveBufferSize);
|
||||
if (_acceptedSendBufferSize > -1)
|
||||
socket.setSendBufferSize(_acceptedSendBufferSize);
|
||||
}
|
||||
catch (SocketException e)
|
||||
{
|
||||
|
@ -479,6 +486,7 @@ public class ServerConnector extends AbstractNetworkConnector
|
|||
* @return whether the server socket reuses addresses
|
||||
* @see ServerSocket#getReuseAddress()
|
||||
*/
|
||||
@ManagedAttribute("Server Socket SO_REUSEADDR")
|
||||
public boolean getReuseAddress()
|
||||
{
|
||||
return _reuseAddress;
|
||||
|
@ -493,6 +501,67 @@ public class ServerConnector extends AbstractNetworkConnector
|
|||
_reuseAddress = reuseAddress;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return whether the accepted socket gets {@link java.net.SocketOptions#TCP_NODELAY TCP_NODELAY} enabled.
|
||||
* @see Socket#getTcpNoDelay()
|
||||
*/
|
||||
@ManagedAttribute("Accepted Socket TCP_NODELAY")
|
||||
public boolean getAcceptedTcpNoDelay()
|
||||
{
|
||||
return _acceptedTcpNoDelay;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param tcpNoDelay whether {@link java.net.SocketOptions#TCP_NODELAY TCP_NODELAY} gets enabled on the the accepted socket.
|
||||
* @see Socket#setTcpNoDelay(boolean)
|
||||
*/
|
||||
public void setAcceptedTcpNoDelay(boolean tcpNoDelay)
|
||||
{
|
||||
this._acceptedTcpNoDelay = tcpNoDelay;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return the {@link java.net.SocketOptions#SO_RCVBUF SO_RCVBUF} size to set onto the accepted socket.
|
||||
* A value of -1 indicates that it is left to its default value.
|
||||
* @see Socket#getReceiveBufferSize()
|
||||
*/
|
||||
@ManagedAttribute("Accepted Socket SO_RCVBUF")
|
||||
public int getAcceptedReceiveBufferSize()
|
||||
{
|
||||
return _acceptedReceiveBufferSize;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param receiveBufferSize the {@link java.net.SocketOptions#SO_RCVBUF SO_RCVBUF} size to set onto the accepted socket.
|
||||
* A value of -1 indicates that it is left to its default value.
|
||||
* @see Socket#setReceiveBufferSize(int)
|
||||
*/
|
||||
public void setAcceptedReceiveBufferSize(int receiveBufferSize)
|
||||
{
|
||||
this._acceptedReceiveBufferSize = receiveBufferSize;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return the {@link java.net.SocketOptions#SO_SNDBUF SO_SNDBUF} size to set onto the accepted socket.
|
||||
* A value of -1 indicates that it is left to its default value.
|
||||
* @see Socket#getSendBufferSize()
|
||||
*/
|
||||
@ManagedAttribute("Accepted Socket SO_SNDBUF")
|
||||
public int getAcceptedSendBufferSize()
|
||||
{
|
||||
return _acceptedSendBufferSize;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param sendBufferSize the {@link java.net.SocketOptions#SO_SNDBUF SO_SNDBUF} size to set onto the accepted socket.
|
||||
* A value of -1 indicates that it is left to its default value.
|
||||
* @see Socket#setSendBufferSize(int)
|
||||
*/
|
||||
public void setAcceptedSendBufferSize(int sendBufferSize)
|
||||
{
|
||||
this._acceptedSendBufferSize = sendBufferSize;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setAccepting(boolean accepting)
|
||||
{
|
||||
|
|
Loading…
Reference in New Issue