Mercurial Hosting > luan
changeset 879:a3775d0c6985
remove ShutdownThread
author | Franklin Schmidt <fschmidt@gmail.com> |
---|---|
date | Tue, 04 Oct 2016 15:55:02 -0600 (2016-10-04) |
parents | 5f8a242392da |
children | 00b3bd6e0ada |
files | src/org/eclipse/jetty/server/Server.java src/org/eclipse/jetty/server/ShutdownMonitor.java src/org/eclipse/jetty/util/thread/ShutdownThread.java |
diffstat | 3 files changed, 0 insertions(+), 570 deletions(-) [+] |
line wrap: on
line diff
--- a/src/org/eclipse/jetty/server/Server.java Tue Oct 04 14:50:32 2016 -0600 +++ b/src/org/eclipse/jetty/server/Server.java Tue Oct 04 15:55:02 2016 -0600 @@ -44,7 +44,6 @@ import org.eclipse.jetty.util.component.LifeCycle; import org.slf4j.Logger; import org.slf4j.LoggerFactory; -import org.eclipse.jetty.util.thread.ShutdownThread; /* ------------------------------------------------------------ */ /** Jetty HTTP Servlet Server. @@ -65,7 +64,6 @@ public final ThreadPoolExecutor threadPool; public final Connector connector; private int _graceful=0; - private boolean _stopAtShutdown; private boolean _dumpAfterStart=false; private boolean _dumpBeforeStop=false; private boolean _uncheckedPrintWriter=false; @@ -93,32 +91,6 @@ return __version; } - /* ------------------------------------------------------------ */ - public boolean getStopAtShutdown() - { - return _stopAtShutdown; - } - - /* ------------------------------------------------------------ */ - public void setStopAtShutdown(boolean stop) - { - //if we now want to stop - if (stop) - { - //and we weren't stopping before - if (!_stopAtShutdown) - { - //only register to stop if we're already started (otherwise we'll do it in doStart()) - if (isStarted()) - ShutdownThread.register(this); - } - } - else - ShutdownThread.deregister(this); - - _stopAtShutdown=stop; - } - /** * @return true if {@link #dumpStdErr()} is called after starting */ @@ -157,13 +129,6 @@ @Override protected void doStart() throws Exception { - if (getStopAtShutdown()) - { - ShutdownThread.register(this); - } - - ShutdownMonitor.getInstance().start(); // initialize - LOG.info("jetty-"+__version); HttpGenerator.setServerVersion(__version); @@ -224,9 +189,6 @@ try {super.doStop(); } catch(Throwable e) { mex.add(e);} mex.ifExceptionThrow(); - - if (getStopAtShutdown()) - ShutdownThread.deregister(this); } /* ------------------------------------------------------------ */
--- a/src/org/eclipse/jetty/server/ShutdownMonitor.java Tue Oct 04 14:50:32 2016 -0600 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,384 +0,0 @@ -// -// ======================================================================== -// Copyright (c) 1995-2014 Mort Bay Consulting Pty. Ltd. -// ------------------------------------------------------------------------ -// All rights reserved. This program and the accompanying materials -// are made available under the terms of the Eclipse Public License v1.0 -// and Apache License v2.0 which accompanies this distribution. -// -// The Eclipse Public License is available at -// http://www.eclipse.org/legal/epl-v10.html -// -// The Apache License v2.0 is available at -// http://www.opensource.org/licenses/apache2.0.php -// -// You may elect to redistribute this code under either of these licenses. -// ======================================================================== -// - -package org.eclipse.jetty.server; - -import java.io.IOException; -import java.io.InputStreamReader; -import java.io.LineNumberReader; -import java.io.OutputStream; -import java.net.InetAddress; -import java.net.ServerSocket; -import java.net.Socket; -import java.util.Properties; - -import org.eclipse.jetty.util.StringUtil; -import org.eclipse.jetty.util.thread.ShutdownThread; - -/** - * Shutdown/Stop Monitor thread. - * <p> - * This thread listens on the port specified by the STOP.PORT system parameter (defaults to -1 for not listening) for request authenticated with the key given - * by the STOP.KEY system parameter (defaults to "eclipse") for admin requests. - * <p> - * If the stop port is set to zero, then a random port is assigned and the port number is printed to stdout. - * <p> - * Commands "stop" and "status" are currently supported. - */ -public class ShutdownMonitor -{ - // Implementation of safe lazy init, using Initialization on Demand Holder technique. - static class Holder - { - static ShutdownMonitor instance = new ShutdownMonitor(); - } - - public static ShutdownMonitor getInstance() - { - return Holder.instance; - } - - /** - * ShutdownMonitorThread - * - * Thread for listening to STOP.PORT for command to stop Jetty. - * If ShowndownMonitor.exitVm is true, then Sytem.exit will also be - * called after the stop. - * - */ - public class ShutdownMonitorThread extends Thread - { - - public ShutdownMonitorThread () - { - setDaemon(true); - setName("ShutdownMonitor"); - } - - @Override - public void run() - { - if (serverSocket == null) - { - return; - } - - while (serverSocket != null) - { - Socket socket = null; - try - { - socket = serverSocket.accept(); - - LineNumberReader lin = new LineNumberReader(new InputStreamReader(socket.getInputStream())); - String receivedKey = lin.readLine(); - if (!key.equals(receivedKey)) - { - System.err.println("Ignoring command with incorrect key"); - continue; - } - - OutputStream out = socket.getOutputStream(); - - String cmd = lin.readLine(); - debug("command=%s",cmd); - if ("stop".equals(cmd)) - { - // Graceful Shutdown - debug("Issuing graceful shutdown.."); - ShutdownThread.getInstance().run(); - - // Reply to client - debug("Informing client that we are stopped."); - out.write("Stopped\r\n".getBytes(StringUtil.__UTF8)); - out.flush(); - - // Shutdown Monitor - debug("Shutting down monitor"); - close(socket); - socket = null; - close(serverSocket); - serverSocket = null; - - if (exitVm) - { - // Kill JVM - debug("Killing JVM"); - System.exit(0); - } - } - else if ("status".equals(cmd)) - { - // Reply to client - out.write("OK\r\n".getBytes(StringUtil.__UTF8)); - out.flush(); - } - } - catch (Exception e) - { - debug(e); - System.err.println(e.toString()); - } - finally - { - close(socket); - socket = null; - } - } - } - - public void start() - { - if (isAlive()) - { - System.err.printf("ShutdownMonitorThread already started"); - return; // cannot start it again - } - - startListenSocket(); - - if (serverSocket == null) - { - return; - } - if (DEBUG) - System.err.println("Starting ShutdownMonitorThread"); - super.start(); - } - - private void startListenSocket() - { - if (port < 0) - { - if (DEBUG) - System.err.println("ShutdownMonitor not in use (port < 0): " + port); - return; - } - - try - { - serverSocket = new ServerSocket(port,1,InetAddress.getByName("127.0.0.1")); - if (port == 0) - { - // server assigned port in use - port = serverSocket.getLocalPort(); - System.out.printf("STOP.PORT=%d%n",port); - } - - if (key == null) - { - // create random key - key = Long.toString((long)(Long.MAX_VALUE * Math.random() + this.hashCode() + System.currentTimeMillis()),36); - System.out.printf("STOP.KEY=%s%n",key); - } - } - catch (Exception e) - { - debug(e); - System.err.println("Error binding monitor port " + port + ": " + e.toString()); - serverSocket = null; - } - finally - { - // establish the port and key that are in use - debug("STOP.PORT=%d",port); - debug("STOP.KEY=%s",key); - debug("%s",serverSocket); - } - } - - } - - private boolean DEBUG; - private int port; - private String key; - private boolean exitVm; - private ServerSocket serverSocket; - private ShutdownMonitorThread thread; - - - - /** - * Create a ShutdownMonitor using configuration from the System properties. - * <p> - * <code>STOP.PORT</code> = the port to listen on (empty, null, or values less than 0 disable the stop ability)<br> - * <code>STOP.KEY</code> = the magic key/passphrase to allow the stop (defaults to "eclipse")<br> - * <p> - * Note: server socket will only listen on localhost, and a successful stop will issue a System.exit() call. - */ - private ShutdownMonitor() - { - Properties props = System.getProperties(); - - this.DEBUG = props.containsKey("DEBUG"); - - // Use values passed thru via /jetty-start/ - this.port = Integer.parseInt(props.getProperty("STOP.PORT","-1")); - this.key = props.getProperty("STOP.KEY",null); - this.exitVm = true; - } - - private void close(ServerSocket server) - { - if (server == null) - { - return; - } - - try - { - server.close(); - } - catch (IOException ignore) - { - /* ignore */ - } - } - - private void close(Socket socket) - { - if (socket == null) - { - return; - } - - try - { - socket.close(); - } - catch (IOException ignore) - { - /* ignore */ - } - } - - private void debug(String format, Object... args) - { - if (DEBUG) - { - System.err.printf("[ShutdownMonitor] " + format + "%n",args); - } - } - - private void debug(Throwable t) - { - if (DEBUG) - { - t.printStackTrace(System.err); - } - } - - public String getKey() - { - return key; - } - - public int getPort() - { - return port; - } - - public ServerSocket getServerSocket() - { - return serverSocket; - } - - public boolean isExitVm() - { - return exitVm; - } - - - public void setDebug(boolean flag) - { - this.DEBUG = flag; - } - - public void setExitVm(boolean exitVm) - { - synchronized (this) - { - if (thread != null && thread.isAlive()) - { - throw new IllegalStateException("ShutdownMonitorThread already started"); - } - this.exitVm = exitVm; - } - } - - public void setKey(String key) - { - synchronized (this) - { - if (thread != null && thread.isAlive()) - { - throw new IllegalStateException("ShutdownMonitorThread already started"); - } - this.key = key; - } - } - - public void setPort(int port) - { - synchronized (this) - { - if (thread != null && thread.isAlive()) - { - throw new IllegalStateException("ShutdownMonitorThread already started"); - } - this.port = port; - } - } - - protected void start() throws Exception - { - ShutdownMonitorThread t = null; - synchronized (this) - { - if (thread != null && thread.isAlive()) - { - System.err.printf("ShutdownMonitorThread already started"); - return; // cannot start it again - } - - thread = new ShutdownMonitorThread(); - t = thread; - } - - if (t != null) - t.start(); - } - - - protected boolean isAlive () - { - boolean result = false; - synchronized (this) - { - result = (thread != null && thread.isAlive()); - } - return result; - } - - - @Override - public String toString() - { - return String.format("%s[port=%d]",this.getClass().getName(),port); - } -}
--- a/src/org/eclipse/jetty/util/thread/ShutdownThread.java Tue Oct 04 14:50:32 2016 -0600 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,148 +0,0 @@ -// -// ======================================================================== -// Copyright (c) 1995-2014 Mort Bay Consulting Pty. Ltd. -// ------------------------------------------------------------------------ -// All rights reserved. This program and the accompanying materials -// are made available under the terms of the Eclipse Public License v1.0 -// and Apache License v2.0 which accompanies this distribution. -// -// The Eclipse Public License is available at -// http://www.eclipse.org/legal/epl-v10.html -// -// The Apache License v2.0 is available at -// http://www.opensource.org/licenses/apache2.0.php -// -// You may elect to redistribute this code under either of these licenses. -// ======================================================================== -// - -package org.eclipse.jetty.util.thread; - -import java.util.Arrays; -import java.util.List; -import java.util.concurrent.CopyOnWriteArrayList; - -import org.eclipse.jetty.util.component.Destroyable; -import org.eclipse.jetty.util.component.LifeCycle; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - - -/* ------------------------------------------------------------ */ -/** - * ShutdownThread is a shutdown hook thread implemented as - * singleton that maintains a list of lifecycle instances - * that are registered with it and provides ability to stop - * these lifecycles upon shutdown of the Java Virtual Machine - */ -public class ShutdownThread extends Thread -{ - private static final Logger LOG = LoggerFactory.getLogger(ShutdownThread.class); - private static final ShutdownThread _thread = new ShutdownThread(); - - private boolean _hooked; - private final List<LifeCycle> _lifeCycles = new CopyOnWriteArrayList<LifeCycle>(); - - /* ------------------------------------------------------------ */ - /** - * Default constructor for the singleton - * - * Registers the instance as shutdown hook with the Java Runtime - */ - private ShutdownThread() - { - } - - /* ------------------------------------------------------------ */ - private synchronized void hook() - { - try - { - if (!_hooked) - Runtime.getRuntime().addShutdownHook(this); - _hooked=true; - } - catch(Exception e) - { - LOG.trace("",e); - LOG.info("shutdown already commenced"); - } - } - - /* ------------------------------------------------------------ */ - private synchronized void unhook() - { - try - { - _hooked=false; - Runtime.getRuntime().removeShutdownHook(this); - } - catch(Exception e) - { - LOG.trace("",e); - LOG.debug("shutdown already commenced"); - } - } - - /* ------------------------------------------------------------ */ - /** - * Returns the instance of the singleton - * - * @return the singleton instance of the {@link ShutdownThread} - */ - public static ShutdownThread getInstance() - { - return _thread; - } - - /* ------------------------------------------------------------ */ - public static synchronized void register(LifeCycle... lifeCycles) - { - _thread._lifeCycles.addAll(Arrays.asList(lifeCycles)); - if (_thread._lifeCycles.size()>0) - _thread.hook(); - } - - /* ------------------------------------------------------------ */ - public static synchronized void register(int index, LifeCycle... lifeCycles) - { - _thread._lifeCycles.addAll(index,Arrays.asList(lifeCycles)); - if (_thread._lifeCycles.size()>0) - _thread.hook(); - } - - /* ------------------------------------------------------------ */ - public static synchronized void deregister(LifeCycle lifeCycle) - { - _thread._lifeCycles.remove(lifeCycle); - if (_thread._lifeCycles.size()==0) - _thread.unhook(); - } - - /* ------------------------------------------------------------ */ - @Override - public void run() - { - for (LifeCycle lifeCycle : _thread._lifeCycles) - { - try - { - if (lifeCycle.isStarted()) - { - lifeCycle.stop(); - LOG.debug("Stopped {}",lifeCycle); - } - - if (lifeCycle instanceof Destroyable) - { - ((Destroyable)lifeCycle).destroy(); - LOG.debug("Destroyed {}",lifeCycle); - } - } - catch (Exception ex) - { - LOG.debug("",ex); - } - } - } -}