]> source.dussan.org Git - sonarqube.git/commitdiff
SONAR-4898 do not use IPv6 loopback address
authorSimon Brandhof <simon.brandhof@sonarsource.com>
Wed, 27 Aug 2014 15:13:33 +0000 (17:13 +0200)
committerSimon Brandhof <simon.brandhof@sonarsource.com>
Wed, 27 Aug 2014 15:13:42 +0000 (17:13 +0200)
Conflict with -Djava.net.preferIPv4Stack=true recommended for ES

server/process/sonar-process/src/main/java/org/sonar/process/LoopbackAddress.java
server/process/sonar-process/src/test/java/org/sonar/process/LoopbackAddressTest.java

index da70cac778cea5e0bb0330d002535d3181aa9c37..17366850be3b23b1169a540c43a6076d58d3aaa2 100644 (file)
@@ -20,7 +20,6 @@
 package org.sonar.process;
 
 import java.net.Inet4Address;
-import java.net.Inet6Address;
 import java.net.InetAddress;
 import java.net.NetworkInterface;
 import java.net.SocketException;
@@ -35,8 +34,9 @@ public class LoopbackAddress {
   }
 
   /**
-   * Similar to InetAddress.getLoopbackAddress() which was introduced in Java 7. This
-   * method aims to support Java 6.
+   * Quite similar to InetAddress.getLoopbackAddress() which was introduced in Java 7. This
+   * method aims to support Java 6. It returns an IPv4 address, but not IPv6 in order to
+   * support -Djava.net.preferIPv4Stack=true recommended for Elasticsearch
    */
   public static InetAddress get() {
     if (instance == null) {
@@ -57,14 +57,14 @@ public class LoopbackAddress {
       Enumeration<InetAddress> addresses = iface.getInetAddresses();
       while (addresses.hasMoreElements()) {
         InetAddress addr = addresses.nextElement();
-        if (addr.isLoopbackAddress()) {
+        if (addr.isLoopbackAddress() && addr instanceof Inet4Address) {
           result = addr;
           break;
         }
       }
     }
     if (result == null) {
-      throw new IllegalStateException("Impossible to get a IP loopback address");
+      throw new IllegalStateException("Impossible to get a IPv4 loopback address");
     }
     return result;
   }
index 0e4885a6407cd8da1471f842dcf2089c660af857..6a8819c3a81440f91d2c0f6f71c14569bf4b2e25 100644 (file)
@@ -45,7 +45,7 @@ public class LoopbackAddressTest {
       LoopbackAddress.doGet(ifaces);
       fail();
     } catch (IllegalStateException e) {
-      assertThat(e).hasMessage("Impossible to get a IP loopback address");
+      assertThat(e).hasMessage("Impossible to get a IPv4 loopback address");
     }
   }
 }