From 6f098dd69c02196b00c9b5ea25e50cf2c6b1eeba Mon Sep 17 00:00:00 2001 From: Greg Wilkins Date: Mon, 10 Dec 2012 12:58:14 +1100 Subject: [PATCH] jetty-9 use DateCache timer to set Date header once per second --- .../eclipse/jetty/embedded/LikeJettyXml.java | 2 +- .../eclipse/jetty/embedded/SpdyServer.java | 2 +- jetty-deploy/src/test/resources/jetty.xml | 2 - .../org/eclipse/jetty/http/HttpField.java | 8 ++- .../org/eclipse/jetty/http/HttpFields.java | 3 +- .../jetty-osgi-boot/jettyhome/etc/jetty.xml | 2 - .../src/test/config/etc/jetty.xml | 2 - .../src/main/config/etc/jetty-proxy.xml | 2 - .../jetty-rewrite.xml | 2 - .../java/org/eclipse/jetty/runner/Runner.java | 1 - jetty-server/src/main/config/etc/jetty.xml | 2 - .../jetty/server/AbstractConnector.java | 2 +- .../org/eclipse/jetty/server/Connector.java | 4 +- .../org/eclipse/jetty/server/HttpChannel.java | 8 +-- .../jetty/server/HttpConfiguration.java | 27 +++++++++ .../eclipse/jetty/server/HttpConnection.java | 2 +- .../java/org/eclipse/jetty/server/Server.java | 57 ++++++++++--------- .../server/NetworkTrafficListenerTest.java | 4 +- .../servlet/DefaultServletRangesTest.java | 5 +- .../jetty/servlet/DefaultServletTest.java | 3 +- .../eclipse/jetty/servlet/DispatcherTest.java | 3 +- .../eclipse/jetty/servlet/InvokerTest.java | 3 +- .../org/eclipse/jetty/spring/jetty.xml | 2 - .../org/eclipse/jetty/util/DateCache.java | 22 ++++--- .../src/test/resources/DefaultHandler.xml | 2 - .../src/test/resources/RFC2616Base.xml | 2 - .../java/org/eclipse/jetty/TestServer.java | 4 +- .../jetty/TestTransparentProxyServer.java | 4 +- 28 files changed, 104 insertions(+), 78 deletions(-) diff --git a/examples/embedded/src/main/java/org/eclipse/jetty/embedded/LikeJettyXml.java b/examples/embedded/src/main/java/org/eclipse/jetty/embedded/LikeJettyXml.java index b0543dd1567..d3641fba4a8 100644 --- a/examples/embedded/src/main/java/org/eclipse/jetty/embedded/LikeJettyXml.java +++ b/examples/embedded/src/main/java/org/eclipse/jetty/embedded/LikeJettyXml.java @@ -60,6 +60,7 @@ public class LikeJettyXml // Setup Connectors HttpConnectionFactory http = new HttpConnectionFactory(); http.getHttpConfiguration().setSecurePort(8443); + http.getHttpConfiguration().setSendServerVersion(true); ServerConnector connector = new ServerConnector(server,http); connector.setPort(8080); connector.setIdleTimeout(30000); @@ -119,7 +120,6 @@ public class LikeJettyXml requestLogHandler.setRequestLog(requestLog); server.setStopAtShutdown(true); - server.setSendServerVersion(true); server.start(); server.join(); diff --git a/examples/embedded/src/main/java/org/eclipse/jetty/embedded/SpdyServer.java b/examples/embedded/src/main/java/org/eclipse/jetty/embedded/SpdyServer.java index 4875c943101..3160e305c09 100644 --- a/examples/embedded/src/main/java/org/eclipse/jetty/embedded/SpdyServer.java +++ b/examples/embedded/src/main/java/org/eclipse/jetty/embedded/SpdyServer.java @@ -72,6 +72,7 @@ public class SpdyServer config.setSecurePort(8443); config.addCustomizer(new ForwardedRequestCustomizer()); config.addCustomizer(new SecureRequestCustomizer()); + config.setSendServerVersion(true); // Http Connector @@ -160,7 +161,6 @@ public class SpdyServer requestLogHandler.setRequestLog(requestLog); server.setStopAtShutdown(true); - server.setSendServerVersion(true); server.start(); server.dumpStdErr(); diff --git a/jetty-deploy/src/test/resources/jetty.xml b/jetty-deploy/src/test/resources/jetty.xml index 313c50a1dde..c3083f633c3 100644 --- a/jetty-deploy/src/test/resources/jetty.xml +++ b/jetty-deploy/src/test/resources/jetty.xml @@ -113,8 +113,6 @@ true - true - true 1000 diff --git a/jetty-http/src/main/java/org/eclipse/jetty/http/HttpField.java b/jetty-http/src/main/java/org/eclipse/jetty/http/HttpField.java index d7b9c3d6138..2acfcab104a 100644 --- a/jetty-http/src/main/java/org/eclipse/jetty/http/HttpField.java +++ b/jetty-http/src/main/java/org/eclipse/jetty/http/HttpField.java @@ -225,10 +225,14 @@ public class HttpField return false; } - private static class CachedHttpField extends HttpField + + /* ------------------------------------------------------------ */ + /** A HTTP Field optimised to be reused. + */ + public static class CachedHttpField extends HttpField { final byte[] _bytes; - CachedHttpField(HttpHeader header, String value) + public CachedHttpField(HttpHeader header, String value) { super(header,value); _bytes=new byte[header.asString().length()+2+value.length()+2]; diff --git a/jetty-http/src/main/java/org/eclipse/jetty/http/HttpFields.java b/jetty-http/src/main/java/org/eclipse/jetty/http/HttpFields.java index 8a2817c9c97..ad39094af8b 100644 --- a/jetty-http/src/main/java/org/eclipse/jetty/http/HttpFields.java +++ b/jetty-http/src/main/java/org/eclipse/jetty/http/HttpFields.java @@ -76,8 +76,7 @@ public class HttpFields implements Iterable private static final String[] MONTHS = { "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec", "Jan"}; - - private static class DateGenerator + public static class DateGenerator { private final StringBuilder buf = new StringBuilder(32); private final GregorianCalendar gc = new GregorianCalendar(__GMT); diff --git a/jetty-osgi/jetty-osgi-boot/jettyhome/etc/jetty.xml b/jetty-osgi/jetty-osgi-boot/jettyhome/etc/jetty.xml index 6e7dd851a2d..57928f1c0fc 100644 --- a/jetty-osgi/jetty-osgi-boot/jettyhome/etc/jetty.xml +++ b/jetty-osgi/jetty-osgi-boot/jettyhome/etc/jetty.xml @@ -49,8 +49,6 @@ true - true - true 1000 false false diff --git a/jetty-osgi/test-jetty-osgi/src/test/config/etc/jetty.xml b/jetty-osgi/test-jetty-osgi/src/test/config/etc/jetty.xml index 6e7dd851a2d..57928f1c0fc 100644 --- a/jetty-osgi/test-jetty-osgi/src/test/config/etc/jetty.xml +++ b/jetty-osgi/test-jetty-osgi/src/test/config/etc/jetty.xml @@ -49,8 +49,6 @@ true - true - true 1000 false false diff --git a/jetty-proxy/src/main/config/etc/jetty-proxy.xml b/jetty-proxy/src/main/config/etc/jetty-proxy.xml index b5729ecdde0..2ba165473d5 100644 --- a/jetty-proxy/src/main/config/etc/jetty-proxy.xml +++ b/jetty-proxy/src/main/config/etc/jetty-proxy.xml @@ -43,8 +43,6 @@ true - true - true 1000 diff --git a/jetty-rewrite/src/test/resources/org.mortbay.jetty.rewrite.handler/jetty-rewrite.xml b/jetty-rewrite/src/test/resources/org.mortbay.jetty.rewrite.handler/jetty-rewrite.xml index 0586134af33..a59094ec7fa 100644 --- a/jetty-rewrite/src/test/resources/org.mortbay.jetty.rewrite.handler/jetty-rewrite.xml +++ b/jetty-rewrite/src/test/resources/org.mortbay.jetty.rewrite.handler/jetty-rewrite.xml @@ -274,8 +274,6 @@ true - true - true 1000 diff --git a/jetty-runner/src/main/java/org/eclipse/jetty/runner/Runner.java b/jetty-runner/src/main/java/org/eclipse/jetty/runner/Runner.java index 95d46ff2efa..3ee1b6d47e1 100644 --- a/jetty-runner/src/main/java/org/eclipse/jetty/runner/Runner.java +++ b/jetty-runner/src/main/java/org/eclipse/jetty/runner/Runner.java @@ -449,7 +449,6 @@ public class Runner if (_server==null) usage("No Contexts defined"); _server.setStopAtShutdown(true); - _server.setSendServerVersion(true); switch ((stopPort > 0 ? 1 : 0) + (stopKey != null ? 2 : 0)) { diff --git a/jetty-server/src/main/config/etc/jetty.xml b/jetty-server/src/main/config/etc/jetty.xml index a00e26b0ed3..209e45f0b3c 100644 --- a/jetty-server/src/main/config/etc/jetty.xml +++ b/jetty-server/src/main/config/etc/jetty.xml @@ -110,8 +110,6 @@ true - true - true 5000 false false diff --git a/jetty-server/src/main/java/org/eclipse/jetty/server/AbstractConnector.java b/jetty-server/src/main/java/org/eclipse/jetty/server/AbstractConnector.java index 801337b4949..9f1337e6937 100644 --- a/jetty-server/src/main/java/org/eclipse/jetty/server/AbstractConnector.java +++ b/jetty-server/src/main/java/org/eclipse/jetty/server/AbstractConnector.java @@ -320,7 +320,7 @@ public abstract class AbstractConnector extends ContainerLifeCycle implements Co } @Override - public T getConnectionFactory(Class factoryType) + public T getConnectionFactory(Class factoryType) { synchronized (_factories) { diff --git a/jetty-server/src/main/java/org/eclipse/jetty/server/Connector.java b/jetty-server/src/main/java/org/eclipse/jetty/server/Connector.java index 52a76ccc923..7c3cdd8ea83 100644 --- a/jetty-server/src/main/java/org/eclipse/jetty/server/Connector.java +++ b/jetty-server/src/main/java/org/eclipse/jetty/server/Connector.java @@ -22,6 +22,7 @@ import java.util.Collection; import java.util.List; import java.util.concurrent.Executor; +import org.eclipse.jetty.http.HttpField; import org.eclipse.jetty.io.ByteBufferPool; import org.eclipse.jetty.util.annotation.ManagedAttribute; import org.eclipse.jetty.util.annotation.ManagedObject; @@ -63,7 +64,7 @@ public interface Connector extends LifeCycle, Graceful public ConnectionFactory getConnectionFactory(String nextProtocol); - public T getConnectionFactory(Class factoryType); + public T getConnectionFactory(Class factoryType); /** * @return the default {@link ConnectionFactory} associated with the default protocol name @@ -84,5 +85,6 @@ public interface Connector extends LifeCycle, Graceful * @return the underlying socket, channel, buffer etc. for the connector. */ public Object getTransport(); + } diff --git a/jetty-server/src/main/java/org/eclipse/jetty/server/HttpChannel.java b/jetty-server/src/main/java/org/eclipse/jetty/server/HttpChannel.java index 855aad1288b..044cdac6c08 100644 --- a/jetty-server/src/main/java/org/eclipse/jetty/server/HttpChannel.java +++ b/jetty-server/src/main/java/org/eclipse/jetty/server/HttpChannel.java @@ -494,13 +494,13 @@ public class HttpChannel implements HttpParser.RequestHandler, Runnable break; case HTTP_1_0: - if (getServer().getSendDateHeader()) - _response.getHttpFields().putDateField(HttpHeader.DATE.toString(), _request.getTimeStamp()); + if (_configuration.getSendDateHeader()) + _response.getHttpFields().put(_connector.getServer().getDateField()); break; case HTTP_1_1: - if (getServer().getSendDateHeader()) - _response.getHttpFields().putDateField(HttpHeader.DATE.toString(), _request.getTimeStamp()); + if (_configuration.getSendDateHeader()) + _response.getHttpFields().put(_connector.getServer().getDateField()); if (_expect) { diff --git a/jetty-server/src/main/java/org/eclipse/jetty/server/HttpConfiguration.java b/jetty-server/src/main/java/org/eclipse/jetty/server/HttpConfiguration.java index 86f1dbe483c..edd77d8b4ee 100644 --- a/jetty-server/src/main/java/org/eclipse/jetty/server/HttpConfiguration.java +++ b/jetty-server/src/main/java/org/eclipse/jetty/server/HttpConfiguration.java @@ -46,6 +46,9 @@ public class HttpConfiguration private int _responseHeaderSize=8*1024; private int _securePort; private String _secureScheme = HttpScheme.HTTPS.asString(); + private boolean _sendServerVersion = true; //send Server: header + private boolean _sendDateHeader = false; //send Date: header + public interface Customizer { @@ -73,6 +76,8 @@ public class HttpConfiguration _responseHeaderSize=config._responseHeaderSize; _securePort=config._securePort; _secureScheme=config._secureScheme; + _sendDateHeader=config._sendDateHeader; + _sendServerVersion=config._sendServerVersion; } /* ------------------------------------------------------------ */ @@ -131,6 +136,28 @@ public class HttpConfiguration { return _secureScheme; } + + public void setSendServerVersion (boolean sendServerVersion) + { + _sendServerVersion = sendServerVersion; + } + + @ManagedAttribute("if true, include the server version in HTTP headers") + public boolean getSendServerVersion() + { + return _sendServerVersion; + } + + public void setSendDateHeader(boolean sendDateHeader) + { + _sendDateHeader = sendDateHeader; + } + + @ManagedAttribute("if true, include the date in HTTP headers") + public boolean getSendDateHeader() + { + return _sendDateHeader; + } /* ------------------------------------------------------------ */ /** diff --git a/jetty-server/src/main/java/org/eclipse/jetty/server/HttpConnection.java b/jetty-server/src/main/java/org/eclipse/jetty/server/HttpConnection.java index b6806b703b4..58bee92d81a 100644 --- a/jetty-server/src/main/java/org/eclipse/jetty/server/HttpConnection.java +++ b/jetty-server/src/main/java/org/eclipse/jetty/server/HttpConnection.java @@ -108,7 +108,7 @@ public class HttpConnection extends AbstractConnection implements Runnable, Http _connector = connector; _bufferPool = _connector.getByteBufferPool(); _generator = new HttpGenerator(); // TODO: consider moving the generator to the transport, where it belongs - _generator.setSendServerVersion(getServer().getSendServerVersion()); + _generator.setSendServerVersion(_config.getSendServerVersion()); _channel = new HttpChannelOverHttp(connector, config, endPoint, this, new Input()); _parser = newHttpParser(); diff --git a/jetty-server/src/main/java/org/eclipse/jetty/server/Server.java b/jetty-server/src/main/java/org/eclipse/jetty/server/Server.java index 3e45aa11d2c..baf89e1e4d9 100644 --- a/jetty-server/src/main/java/org/eclipse/jetty/server/Server.java +++ b/jetty-server/src/main/java/org/eclipse/jetty/server/Server.java @@ -26,6 +26,7 @@ import java.util.Collections; import java.util.Date; import java.util.Enumeration; import java.util.List; +import java.util.TimerTask; import java.util.concurrent.CopyOnWriteArrayList; import java.util.concurrent.Future; import java.util.concurrent.TimeUnit; @@ -35,6 +36,8 @@ import javax.servlet.ServletException; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; +import org.eclipse.jetty.http.HttpField; +import org.eclipse.jetty.http.HttpFields; import org.eclipse.jetty.http.HttpGenerator; import org.eclipse.jetty.http.HttpHeader; import org.eclipse.jetty.http.HttpMethod; @@ -43,6 +46,7 @@ import org.eclipse.jetty.http.HttpURI; import org.eclipse.jetty.server.handler.HandlerWrapper; import org.eclipse.jetty.util.Attributes; import org.eclipse.jetty.util.AttributesMap; +import org.eclipse.jetty.util.DateCache; import org.eclipse.jetty.util.Jetty; import org.eclipse.jetty.util.MultiException; import org.eclipse.jetty.util.URIUtil; @@ -73,11 +77,10 @@ public class Server extends HandlerWrapper implements Attributes private final ThreadPool _threadPool; private final List _connectors = new CopyOnWriteArrayList<>(); private SessionIdManager _sessionIdManager; - private boolean _sendServerVersion = true; //send Server: header - private boolean _sendDateHeader = false; //send Date: header private boolean _stopAtShutdown; private boolean _dumpAfterStart=false; private boolean _dumpBeforeStop=false; + private HttpField _dateField; /* ------------------------------------------------------------ */ @@ -257,6 +260,11 @@ public class Server extends HandlerWrapper implements Attributes } + /* ------------------------------------------------------------ */ + public HttpField getDateField() + { + return _dateField; + } /* ------------------------------------------------------------ */ @Override @@ -296,6 +304,25 @@ public class Server extends HandlerWrapper implements Attributes if (isDumpAfterStart()) dumpStdErr(); + + // use DateCache timer for Date field reformat + final HttpFields.DateGenerator date = new HttpFields.DateGenerator(); + long now=System.currentTimeMillis(); + long tick=1000*((now/1000)+1)-now; + _dateField=new HttpField.CachedHttpField(HttpHeader.DATE,date.formatDate(now)); + DateCache.getTimer().scheduleAtFixedRate(new TimerTask() + { + @Override + public void run() + { + long now=System.currentTimeMillis(); + _dateField=new HttpField.CachedHttpField(HttpHeader.DATE,date.formatDate(now)); + if (!isRunning()) + this.cancel(); + } + },tick,1000); + + mex.ifExceptionThrow(); } @@ -494,32 +521,6 @@ public class Server extends HandlerWrapper implements Attributes _sessionIdManager=sessionIdManager; } - /* ------------------------------------------------------------ */ - public void setSendServerVersion (boolean sendServerVersion) - { - _sendServerVersion = sendServerVersion; - } - - /* ------------------------------------------------------------ */ - @ManagedAttribute("if true, include the server version in HTTP headers") - public boolean getSendServerVersion() - { - return _sendServerVersion; - } - - /* ------------------------------------------------------------ */ - public void setSendDateHeader(boolean sendDateHeader) - { - _sendDateHeader = sendDateHeader; - } - - /* ------------------------------------------------------------ */ - @ManagedAttribute("if true, include the date in HTTP headers") - public boolean getSendDateHeader() - { - return _sendDateHeader; - } - /* ------------------------------------------------------------ */ /* * @see org.eclipse.util.AttributesMap#clearAttributes() diff --git a/jetty-server/src/test/java/org/eclipse/jetty/server/NetworkTrafficListenerTest.java b/jetty-server/src/test/java/org/eclipse/jetty/server/NetworkTrafficListenerTest.java index 80885c74940..e1637e6ddac 100644 --- a/jetty-server/src/test/java/org/eclipse/jetty/server/NetworkTrafficListenerTest.java +++ b/jetty-server/src/test/java/org/eclipse/jetty/server/NetworkTrafficListenerTest.java @@ -56,10 +56,10 @@ public class NetworkTrafficListenerTest public void initConnector(Handler handler) throws Exception { server = new Server(); - server.setSendDateHeader(false); - server.setSendServerVersion(false); connector = new NetworkTrafficSelectChannelConnector(server); + connector.getConnectionFactory(HttpConfiguration.ConnectionFactory.class).getHttpConfiguration().setSendDateHeader(false); + connector.getConnectionFactory(HttpConfiguration.ConnectionFactory.class).getHttpConfiguration().setSendServerVersion(false); server.addConnector(connector); server.setHandler(handler); server.start(); diff --git a/jetty-servlet/src/test/java/org/eclipse/jetty/servlet/DefaultServletRangesTest.java b/jetty-servlet/src/test/java/org/eclipse/jetty/servlet/DefaultServletRangesTest.java index 47b8b50f76a..5662c8dfa72 100644 --- a/jetty-servlet/src/test/java/org/eclipse/jetty/servlet/DefaultServletRangesTest.java +++ b/jetty-servlet/src/test/java/org/eclipse/jetty/servlet/DefaultServletRangesTest.java @@ -22,6 +22,7 @@ import java.io.File; import java.io.FileOutputStream; import java.io.IOException; +import org.eclipse.jetty.server.HttpConfiguration; import org.eclipse.jetty.server.LocalConnector; import org.eclipse.jetty.server.Server; import org.eclipse.jetty.toolchain.test.FS; @@ -53,9 +54,9 @@ public class DefaultServletRangesTest public void init() throws Exception { server = new Server(); - server.setSendServerVersion(false); - connector = new LocalConnector(server); + connector = new LocalConnector(server); + connector.getConnectionFactory(HttpConfiguration.ConnectionFactory.class).getHttpConfiguration().setSendServerVersion(false); context = new ServletContextHandler(); context.setContextPath("/context"); diff --git a/jetty-servlet/src/test/java/org/eclipse/jetty/servlet/DefaultServletTest.java b/jetty-servlet/src/test/java/org/eclipse/jetty/servlet/DefaultServletTest.java index e8dd064ace9..648e34e9597 100644 --- a/jetty-servlet/src/test/java/org/eclipse/jetty/servlet/DefaultServletTest.java +++ b/jetty-servlet/src/test/java/org/eclipse/jetty/servlet/DefaultServletTest.java @@ -33,6 +33,7 @@ import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; import org.eclipse.jetty.http.HttpFields; +import org.eclipse.jetty.server.HttpConfiguration; import org.eclipse.jetty.server.LocalConnector; import org.eclipse.jetty.server.Server; import org.eclipse.jetty.toolchain.test.FS; @@ -64,9 +65,9 @@ public class DefaultServletTest public void init() throws Exception { server = new Server(); - server.setSendServerVersion(false); connector = new LocalConnector(server); + connector.getConnectionFactory(HttpConfiguration.ConnectionFactory.class).getHttpConfiguration().setSendServerVersion(false); context = new ServletContextHandler(); context.setContextPath("/context"); diff --git a/jetty-servlet/src/test/java/org/eclipse/jetty/servlet/DispatcherTest.java b/jetty-servlet/src/test/java/org/eclipse/jetty/servlet/DispatcherTest.java index 34a8cd84b57..01213239cbb 100644 --- a/jetty-servlet/src/test/java/org/eclipse/jetty/servlet/DispatcherTest.java +++ b/jetty-servlet/src/test/java/org/eclipse/jetty/servlet/DispatcherTest.java @@ -44,6 +44,7 @@ import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponseWrapper; import org.eclipse.jetty.server.Dispatcher; +import org.eclipse.jetty.server.HttpConfiguration; import org.eclipse.jetty.server.LocalConnector; import org.eclipse.jetty.server.Server; import org.eclipse.jetty.server.handler.ContextHandler; @@ -71,8 +72,8 @@ public class DispatcherTest public void init() throws Exception { _server = new Server(); - _server.setSendServerVersion(false); _connector = new LocalConnector(_server); + _connector.getConnectionFactory(HttpConfiguration.ConnectionFactory.class).getHttpConfiguration().setSendServerVersion(false); _contextCollection = new ContextHandlerCollection(); _contextHandler = new ServletContextHandler(); diff --git a/jetty-servlet/src/test/java/org/eclipse/jetty/servlet/InvokerTest.java b/jetty-servlet/src/test/java/org/eclipse/jetty/servlet/InvokerTest.java index 4ee8da42432..d70a7d5b403 100644 --- a/jetty-servlet/src/test/java/org/eclipse/jetty/servlet/InvokerTest.java +++ b/jetty-servlet/src/test/java/org/eclipse/jetty/servlet/InvokerTest.java @@ -25,6 +25,7 @@ import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; +import org.eclipse.jetty.server.HttpConfiguration; import org.eclipse.jetty.server.LocalConnector; import org.eclipse.jetty.server.Server; import org.junit.After; @@ -46,9 +47,9 @@ public class InvokerTest { _server = new Server(); _connector = new LocalConnector(_server); + _connector.getConnectionFactory(HttpConfiguration.ConnectionFactory.class).getHttpConfiguration().setSendServerVersion(false); ServletContextHandler context = new ServletContextHandler(ServletContextHandler.SESSIONS); - _server.setSendServerVersion(false); _server.addConnector(_connector); _server.setHandler(context); diff --git a/jetty-spring/src/test/resources/org/eclipse/jetty/spring/jetty.xml b/jetty-spring/src/test/resources/org/eclipse/jetty/spring/jetty.xml index dbdf6e63621..76d27fb6173 100644 --- a/jetty-spring/src/test/resources/org/eclipse/jetty/spring/jetty.xml +++ b/jetty-spring/src/test/resources/org/eclipse/jetty/spring/jetty.xml @@ -31,8 +31,6 @@ - - diff --git a/jetty-util/src/main/java/org/eclipse/jetty/util/DateCache.java b/jetty-util/src/main/java/org/eclipse/jetty/util/DateCache.java index 9904caaf96e..cb99ca9afcd 100644 --- a/jetty-util/src/main/java/org/eclipse/jetty/util/DateCache.java +++ b/jetty-util/src/main/java/org/eclipse/jetty/util/DateCache.java @@ -60,6 +60,16 @@ public class DateCache private static Timer __timer; + public static Timer getTimer() + { + synchronized (DateCache.class) + { + if (__timer==null) + __timer=new Timer("DateCache",true); + return __timer; + } + } + /* ------------------------------------------------------------ */ /* ------------------------------------------------------------ */ private static class Tick @@ -94,11 +104,9 @@ public class DateCache synchronized (DateCache.class) { - if (__timer==null) - __timer=new Timer("DateCache@"+Integer.toHexString(hashCode()),true); - - Date start = new Date((2+(System.currentTimeMillis()/1000))*1000); - __timer.scheduleAtFixedRate(new TimerTask() + long now=System.currentTimeMillis(); + long tick=1000*((now/1000)+1)-now; + getTimer().scheduleAtFixedRate(new TimerTask() { @Override public void run() @@ -106,7 +114,7 @@ public class DateCache formatNow(); } }, - start, + tick, 1000); } } @@ -264,7 +272,7 @@ public class DateCache } /* ------------------------------------------------------------ */ - private void formatNow() + protected void formatNow() { long now = System.currentTimeMillis(); long seconds = now / 1000; diff --git a/tests/test-integration/src/test/resources/DefaultHandler.xml b/tests/test-integration/src/test/resources/DefaultHandler.xml index ceaa43f28b1..a71200f526a 100644 --- a/tests/test-integration/src/test/resources/DefaultHandler.xml +++ b/tests/test-integration/src/test/resources/DefaultHandler.xml @@ -63,8 +63,6 @@ true - true - true 1000 diff --git a/tests/test-integration/src/test/resources/RFC2616Base.xml b/tests/test-integration/src/test/resources/RFC2616Base.xml index f791c1af004..8ede492f29b 100644 --- a/tests/test-integration/src/test/resources/RFC2616Base.xml +++ b/tests/test-integration/src/test/resources/RFC2616Base.xml @@ -139,8 +139,6 @@ true - true - true 1000 diff --git a/tests/test-webapps/test-jetty-webapp/src/test/java/org/eclipse/jetty/TestServer.java b/tests/test-webapps/test-jetty-webapp/src/test/java/org/eclipse/jetty/TestServer.java index 9db3b74b53f..ecb9aa08598 100644 --- a/tests/test-webapps/test-jetty-webapp/src/test/java/org/eclipse/jetty/TestServer.java +++ b/tests/test-webapps/test-jetty-webapp/src/test/java/org/eclipse/jetty/TestServer.java @@ -76,7 +76,6 @@ public class TestServer // Setup server Server server = new Server(threadPool); server.manage(threadPool); - server.setSendDateHeader(true); // Setup JMX MBeanContainer mbContainer=new MBeanContainer(ManagementFactory.getPlatformMBeanServer()); @@ -89,6 +88,8 @@ public class TestServer config.setSecurePort(8443); config.addCustomizer(new ForwardedRequestCustomizer()); config.addCustomizer(new SecureRequestCustomizer()); + config.setSendDateHeader(true); + config.setSendServerVersion(true); // Http Connector @@ -161,7 +162,6 @@ public class TestServer requestLogHandler.setRequestLog(requestLog); server.setStopAtShutdown(true); - server.setSendServerVersion(true); WebAppContext webapp = new WebAppContext(); webapp.setParentLoaderPriority(true); diff --git a/tests/test-webapps/test-proxy-webapp/src/test/java/org/eclipse/jetty/TestTransparentProxyServer.java b/tests/test-webapps/test-proxy-webapp/src/test/java/org/eclipse/jetty/TestTransparentProxyServer.java index 4fda0d70a82..47a213fe8ea 100644 --- a/tests/test-webapps/test-proxy-webapp/src/test/java/org/eclipse/jetty/TestTransparentProxyServer.java +++ b/tests/test-webapps/test-proxy-webapp/src/test/java/org/eclipse/jetty/TestTransparentProxyServer.java @@ -62,7 +62,6 @@ public class TestTransparentProxyServer // Setup server Server server = new Server(threadPool); server.manage(threadPool); - server.setSendDateHeader(true); // Setup JMX MBeanContainer mbContainer=new MBeanContainer(ManagementFactory.getPlatformMBeanServer()); @@ -75,6 +74,8 @@ public class TestTransparentProxyServer config.setSecurePort(8443); config.addCustomizer(new ForwardedRequestCustomizer()); config.addCustomizer(new SecureRequestCustomizer()); + config.setSendDateHeader(true); + config.setSendServerVersion(true); // Http Connector @@ -134,7 +135,6 @@ public class TestTransparentProxyServer // start server server.setStopAtShutdown(true); - server.setSendServerVersion(true); server.start(); server.join(); }