You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@sling.apache.org by kw...@apache.org on 2018/06/02 15:59:00 UTC
[sling-slingstart-maven-plugin] branch master updated: SLING-6543
block start goal until http port is really bound
This is an automated email from the ASF dual-hosted git repository.
kwin pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/sling-slingstart-maven-plugin.git
The following commit(s) were added to refs/heads/master by this push:
new 60d4d95 SLING-6543 block start goal until http port is really bound
new 5903541 Merge branch 'master' of git@github.com:apache/sling-slingstart-maven-plugin.git
60d4d95 is described below
commit 60d4d95b890723af8dd03b5fa64d4673a3b0246a
Author: Konrad Windszus <kw...@apache.org>
AuthorDate: Sat Jun 2 17:58:28 2018 +0200
SLING-6543 block start goal until http port is really bound
---
.../maven/slingstart/run/LauncherCallable.java | 35 ++++++++++++++++++++++
1 file changed, 35 insertions(+)
diff --git a/src/main/java/org/apache/sling/maven/slingstart/run/LauncherCallable.java b/src/main/java/org/apache/sling/maven/slingstart/run/LauncherCallable.java
index 0f8bcde..b3cf4bb 100644
--- a/src/main/java/org/apache/sling/maven/slingstart/run/LauncherCallable.java
+++ b/src/main/java/org/apache/sling/maven/slingstart/run/LauncherCallable.java
@@ -24,8 +24,10 @@ import java.io.IOException;
import java.io.InputStreamReader;
import java.io.LineNumberReader;
import java.lang.ProcessBuilder.Redirect;
+import java.net.ConnectException;
import java.net.InetSocketAddress;
import java.net.Socket;
+import java.net.SocketTimeoutException;
import java.nio.file.Paths;
import java.util.ArrayList;
import java.util.List;
@@ -96,6 +98,7 @@ public class LauncherCallable implements Callable<ProcessDescription> {
} catch ( final IllegalThreadStateException itse) {
// everything as expected
}
+
}
if ( finished ) {
@@ -104,6 +107,16 @@ public class LauncherCallable implements Callable<ProcessDescription> {
if ( !started ) {
throw new Exception("Launchpad did not start successfully in " + this.environment.getReadyTimeOutSec() + " seconds.");
}
+ // now check for the availability of the HTTP port
+ boolean httpAvailable = isLocalhostPortAvailable(Integer.valueOf(this.configuration.getPort()));
+ // repeat until http service is up as well
+ while ( !httpAvailable && System.currentTimeMillis() < endTime ) {
+ Thread.sleep(1000);
+ httpAvailable = isLocalhostPortAvailable(Integer.valueOf(this.configuration.getPort()));
+ }
+ if ( !httpAvailable ) {
+ throw new Exception("Launchpad did not start http service on port " + this.configuration.getPort() + " successfully in " + this.environment.getReadyTimeOutSec() + " seconds.");
+ }
this.logger.info("Started Launchpad '" + configuration.getId() +
"' at port " + configuration.getPort()+ " [run modes: " + configuration.getRunmode()+ "]");
} finally {
@@ -121,6 +134,28 @@ public class LauncherCallable implements Callable<ProcessDescription> {
return cfg;
}
+ private boolean isLocalhostPortAvailable(int port) throws IOException {
+ // https://stackoverflow.com/questions/46436813/difference-between-a-connection-refused-exception-and-a-timeout-in-httpclient
+ Socket clientSocket = new Socket();
+ try {
+ clientSocket.connect(new InetSocketAddress("127.0.0.1", port), 500);
+ // without that, read() call on the InputStream associated with this Socket is infinite
+ this.logger.debug("Successfully connected to localhost, port " + port);
+ clientSocket.close();
+ return true;
+ } catch (SocketTimeoutException e) {
+ // we ran into a timeout (port most probably blocked by firewall)
+ this.logger.debug("Ran into a timeout while connecting to localhost, port " + port, e);
+ return false;
+ } catch (ConnectException e) {
+ // port not bound
+ this.logger.debug("Could not connect to localhost, port " + port, e);
+ return false;
+ } finally {
+ clientSocket.close();
+ }
+ }
+
public boolean isRunning() {
return getControlPortFile(this.configuration.getFolder()).exists();
}
--
To stop receiving notification emails like this one, please contact
kwin@apache.org.