diff options
Diffstat (limited to 'server/sonar-process/src/main/java')
5 files changed, 55 insertions, 36 deletions
diff --git a/server/sonar-process/src/main/java/org/sonar/process/ProcessCommands.java b/server/sonar-process/src/main/java/org/sonar/process/ProcessCommands.java index 259af6b1eeb..417d62cb5bf 100644 --- a/server/sonar-process/src/main/java/org/sonar/process/ProcessCommands.java +++ b/server/sonar-process/src/main/java/org/sonar/process/ProcessCommands.java @@ -57,22 +57,19 @@ public class ProcessCommands { this.stopFile = stopFile; } - /** - * Executed by monitor - delete shared files before starting child process - */ - public void prepareMonitor() { + public void prepare() { deleteFile(readyFile); deleteFile(stopFile); } - public void finalizeProcess() { + public void endWatch() { // do not fail if files can't be deleted FileUtils.deleteQuietly(readyFile); FileUtils.deleteQuietly(stopFile); } - public boolean wasReadyAfter(long launchedAt) { - return isCreatedAfter(readyFile, launchedAt); + public boolean isReady() { + return readyFile.exists(); } /** @@ -89,8 +86,8 @@ public class ProcessCommands { createFile(stopFile); } - public boolean askedForStopAfter(long launchedAt) { - return isCreatedAfter(stopFile, launchedAt); + public boolean askedForStop() { + return stopFile.exists(); } File getReadyFile() { @@ -117,9 +114,4 @@ public class ProcessCommands { } } } - - private boolean isCreatedAfter(File file, long launchedAt) { - // File#lastModified() can have second precision on some OS - return file.exists() && file.lastModified() / 1000 >= launchedAt / 1000; - } } diff --git a/server/sonar-process/src/main/java/org/sonar/process/ProcessEntryPoint.java b/server/sonar-process/src/main/java/org/sonar/process/ProcessEntryPoint.java index f4d6e7f90f7..870f1aea067 100644 --- a/server/sonar-process/src/main/java/org/sonar/process/ProcessEntryPoint.java +++ b/server/sonar-process/src/main/java/org/sonar/process/ProcessEntryPoint.java @@ -21,7 +21,7 @@ package org.sonar.process; import org.slf4j.LoggerFactory; -public class ProcessEntryPoint { +public class ProcessEntryPoint implements Stoppable { public static final String PROPERTY_PROCESS_KEY = "process.key"; public static final String PROPERTY_TERMINATION_TIMEOUT = "process.terminationTimeout"; @@ -32,7 +32,6 @@ public class ProcessEntryPoint { private final ProcessCommands commands; private final SystemExit exit; private volatile Monitored monitored; - private volatile long launchedAt; private volatile StopperThread stopperThread; private final StopWatcher stopWatcher; @@ -49,7 +48,6 @@ public class ProcessEntryPoint { this.props = props; this.exit = exit; this.commands = commands; - this.launchedAt = System.currentTimeMillis(); this.stopWatcher = new StopWatcher(commands, this); } @@ -68,6 +66,7 @@ public class ProcessEntryPoint { if (!lifecycle.tryToMoveTo(Lifecycle.State.STARTING)) { throw new IllegalStateException("Already started"); } + commands.prepare(); monitored = mp; try { @@ -116,10 +115,12 @@ public class ProcessEntryPoint { exit.exit(0); } - void stopAsync() { + @Override + public void stopAsync() { if (lifecycle.tryToMoveTo(Lifecycle.State.STOPPING)) { stopperThread = new StopperThread(monitored, commands, Long.parseLong(props.nonNullValue(PROPERTY_TERMINATION_TIMEOUT))); stopperThread.start(); + stopWatcher.stopWatching(); } } @@ -131,10 +132,6 @@ public class ProcessEntryPoint { return shutdownHook; } - long getLaunchedAt() { - return launchedAt; - } - public static ProcessEntryPoint createForArguments(String[] args) { Props props = ConfigurationUtils.loadPropsFromCommandLineArgs(args); ProcessCommands commands = new ProcessCommands( diff --git a/server/sonar-process/src/main/java/org/sonar/process/StopWatcher.java b/server/sonar-process/src/main/java/org/sonar/process/StopWatcher.java index 090b0052423..b7b4ffa15d8 100644 --- a/server/sonar-process/src/main/java/org/sonar/process/StopWatcher.java +++ b/server/sonar-process/src/main/java/org/sonar/process/StopWatcher.java @@ -23,31 +23,35 @@ import org.slf4j.LoggerFactory; public class StopWatcher extends Thread { - private final ProcessEntryPoint process; + private final Stoppable stoppable; private final ProcessCommands commands; private boolean watching = true; - public StopWatcher(ProcessCommands commands, ProcessEntryPoint process) { + public StopWatcher(ProcessCommands commands, Stoppable stoppable) { super("Stop Watcher"); this.commands = commands; - this.process = process; + this.stoppable = stoppable; } @Override public void run() { - while (watching) { - if (commands.askedForStopAfter(process.getLaunchedAt())) { - LoggerFactory.getLogger(getClass()).info("Stopping process"); - process.stopAsync(); - watching = false; - } else { - try { - Thread.sleep(500L); - } catch (InterruptedException ignored) { + commands.prepare(); + try { + while (watching) { + if (commands.askedForStop()) { + LoggerFactory.getLogger(getClass()).info("Stopping process"); + stoppable.stopAsync(); watching = false; + } else { + try { + Thread.sleep(500L); + } catch (InterruptedException ignored) { + watching = false; + } } } - + } finally { + commands.endWatch(); } } diff --git a/server/sonar-process/src/main/java/org/sonar/process/Stoppable.java b/server/sonar-process/src/main/java/org/sonar/process/Stoppable.java new file mode 100644 index 00000000000..afd464a67a1 --- /dev/null +++ b/server/sonar-process/src/main/java/org/sonar/process/Stoppable.java @@ -0,0 +1,26 @@ +/* + * SonarQube, open source software quality management tool. + * Copyright (C) 2008-2014 SonarSource + * mailto:contact AT sonarsource DOT com + * + * SonarQube is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * SonarQube is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +package org.sonar.process; + +public interface Stoppable { + + void stopAsync(); + +} diff --git a/server/sonar-process/src/main/java/org/sonar/process/StopperThread.java b/server/sonar-process/src/main/java/org/sonar/process/StopperThread.java index 317cd6f62c3..764d551a93c 100644 --- a/server/sonar-process/src/main/java/org/sonar/process/StopperThread.java +++ b/server/sonar-process/src/main/java/org/sonar/process/StopperThread.java @@ -57,6 +57,6 @@ class StopperThread extends Thread { LoggerFactory.getLogger(getClass()).error(String.format("Can not stop in %dms", terminationTimeout), e); } executor.shutdownNow(); - commands.finalizeProcess(); + commands.endWatch(); } } |