From 03b792501ef0c01bb3b453bf138ecafb6f75be22 Mon Sep 17 00:00:00 2001 From: Greg Wilkins Date: Mon, 8 Jan 2018 17:18:22 +0100 Subject: [PATCH] Issue #2103 open connectors before starting Signed-off-by: Greg Wilkins --- .../java/org/eclipse/jetty/server/Server.java | 130 +++++++++++------- 1 file changed, 81 insertions(+), 49 deletions(-) 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 ef2549202563..3b3ef31c5b26 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 @@ -346,68 +346,100 @@ public HttpField getDateField() @Override protected void doStart() throws Exception { - // Create an error handler if there is none - if (_errorHandler==null) - _errorHandler=getBean(ErrorHandler.class); - if (_errorHandler==null) - setErrorHandler(new ErrorHandler()); - if (_errorHandler instanceof ErrorHandler.ErrorPageMapper) - LOG.warn("ErrorPageMapper not supported for Server level Error Handling"); - _errorHandler.setServer(this); - - //If the Server should be stopped when the jvm exits, register - //with the shutdown handler thread. - if (getStopAtShutdown()) - ShutdownThread.register(this); + try + { + // Create an error handler if there is none + if (_errorHandler==null) + _errorHandler=getBean(ErrorHandler.class); + if (_errorHandler==null) + setErrorHandler(new ErrorHandler()); + if (_errorHandler instanceof ErrorHandler.ErrorPageMapper) + LOG.warn("ErrorPageMapper not supported for Server level Error Handling"); + _errorHandler.setServer(this); + + //If the Server should be stopped when the jvm exits, register + //with the shutdown handler thread. + if (getStopAtShutdown()) + ShutdownThread.register(this); + + //Register the Server with the handler thread for receiving + //remote stop commands + ShutdownMonitor.register(this); + + //Start a thread waiting to receive "stop" commands. + ShutdownMonitor.getInstance().start(); // initialize + + String gitHash = Jetty.GIT_HASH; + String timestamp = Jetty.BUILD_TIMESTAMP; + + LOG.info("jetty-{}, build timestamp: {}, git hash: {}", getVersion(), timestamp, gitHash); + if (!Jetty.STABLE) + { + LOG.warn("THIS IS NOT A STABLE RELEASE! DO NOT USE IN PRODUCTION!"); + LOG.warn("Download a stable release from http://download.eclipse.org/jetty/"); + } - //Register the Server with the handler thread for receiving - //remote stop commands - ShutdownMonitor.register(this); + HttpGenerator.setJettyVersion(HttpConfiguration.SERVER_VERSION); - //Start a thread waiting to receive "stop" commands. - ShutdownMonitor.getInstance().start(); // initialize + MultiException mex=new MultiException(); + + // Open network connector to ensure ports are available + _connectors.stream().filter(NetworkConnector.class::isInstance).map(NetworkConnector.class::cast).forEach(connector-> + { + try + { + connector.open(); + } + catch(Throwable th) + { + mex.add(th); + } + }); + + // Throw now if verified start sequence and there was an open exception + mex.ifExceptionThrow(); - String gitHash = Jetty.GIT_HASH; - String timestamp = Jetty.BUILD_TIMESTAMP; + // Start the server and components, but not connectors! + // #start(LifeCycle) is overridden so that connectors are not started + super.doStart(); + + // start connectors + for (Connector connector : _connectors) + { + try + { + connector.start(); + } + catch(Throwable e) + { + mex.add(e); + } + } - LOG.info("jetty-{}, build timestamp: {}, git hash: {}", getVersion(), timestamp, gitHash); - if (!Jetty.STABLE) - { - LOG.warn("THIS IS NOT A STABLE RELEASE! DO NOT USE IN PRODUCTION!"); - LOG.warn("Download a stable release from http://download.eclipse.org/jetty/"); - } - - HttpGenerator.setJettyVersion(HttpConfiguration.SERVER_VERSION); + if (isDumpAfterStart()) + dumpStdErr(); - MultiException mex=new MultiException(); - try - { - super.doStart(); + mex.ifExceptionThrow(); + LOG.info(String.format("Started @%dms",Uptime.getUptime())); } - catch(Throwable e) - { - mex.add(e); - } - - // start connectors last - for (Connector connector : _connectors) + catch(Throwable e1) { try { - connector.start(); + // Stop any components already started! + super.doStop(); } - catch(Throwable e) + catch(Exception e2) { - mex.add(e); + e1.addSuppressed(e2); + } + finally + { + // Close any connectors that were opened + _connectors.stream().filter(NetworkConnector.class::isInstance).map(NetworkConnector.class::cast).forEach(NetworkConnector::close); } + throw e1; } - - if (isDumpAfterStart()) - dumpStdErr(); - - mex.ifExceptionThrow(); - - LOG.info(String.format("Started @%dms",Uptime.getUptime())); } @Override