Merge pull request #557 from youbeiwuhuan/master

IpUtil获取本地地址的bug
pull/8/MERGE
许雪里 6 years ago committed by GitHub
commit 7b373b66bc
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -1,14 +1,17 @@
package com.xxl.job.core.util; package com.xxl.job.core.util;
import org.slf4j.Logger; import java.net.Inet6Address;
import org.slf4j.LoggerFactory;
import java.net.InetAddress; import java.net.InetAddress;
import java.net.NetworkInterface; import java.net.NetworkInterface;
import java.net.SocketException;
import java.net.UnknownHostException; import java.net.UnknownHostException;
import java.util.ArrayList;
import java.util.Enumeration; import java.util.Enumeration;
import java.util.regex.Pattern; import java.util.regex.Pattern;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/** /**
* get ip * get ip
* @author xuxueli 2016-5-22 11:38:05 * @author xuxueli 2016-5-22 11:38:05
@ -42,15 +45,6 @@ public class IpUtil {
* @return * @return
*/ */
private static InetAddress getFirstValidAddress() { private static InetAddress getFirstValidAddress() {
InetAddress localAddress = null;
try {
localAddress = InetAddress.getLocalHost();
if (isValidAddress(localAddress)) {
return localAddress;
}
} catch (Throwable e) {
logger.error("Failed to retriving ip address, " + e.getMessage(), e);
}
try { try {
Enumeration<NetworkInterface> interfaces = NetworkInterface.getNetworkInterfaces(); Enumeration<NetworkInterface> interfaces = NetworkInterface.getNetworkInterfaces();
if (interfaces != null) { if (interfaces != null) {
@ -78,9 +72,22 @@ public class IpUtil {
} catch (Throwable e) { } catch (Throwable e) {
logger.error("Failed to retriving ip address, " + e.getMessage(), e); logger.error("Failed to retriving ip address, " + e.getMessage(), e);
} }
InetAddress localAddress = null;
try {
localAddress = InetAddress.getLocalHost();
if (isValidAddress(localAddress)) {
return localAddress;
}
} catch (Throwable e) {
logger.error("Failed to retriving ip address, " + e.getMessage(), e);
}
logger.error("Could not get local host ip address, will use 127.0.0.1 instead."); logger.error("Could not get local host ip address, will use 127.0.0.1 instead.");
return localAddress; return localAddress;
} }
/** /**
* get address * get address

Loading…
Cancel
Save