XXL-JOB 执行器用docker的方式来运行,执行的IP为虚拟IP解决方案
微服务均以docker方式运行,注册到xxljob的IP均为自动获取,导致为docker容器的虚拟IP 172.x.x.x,怎么办?同一个微服务多个实例同时运行在服务器上。nacos的一套配置IP就不好使了,怎么办?IpUtil.java类内容如下,带走不谢...
·
问题症状
-
微服务均以docker方式运行,注册到xxljob的IP均为自动获取,导致为docker容器的虚拟IP 172.x.x.x,怎么办?
Nacos配置 xxl.job.executor.ip 设置为你的服务器真实IP即可
-
同一个微服务多个实例同时运行在服务器上。nacos的一套配置IP就不好使了,怎么办?
代码层面处理,初始化xxljob bean时动态获取当前服务器物理IP
加餐
IpUtil.java类内容如下,带走不谢
package org.jamelli.common.base.util;
import cn.hutool.core.util.StrUtil;
import lombok.extern.slf4j.Slf4j;
import javax.servlet.http.HttpServletRequest;
import java.net.InetAddress;
import java.net.NetworkInterface;
import java.net.SocketException;
import java.net.UnknownHostException;
import java.util.Enumeration;
/**
* IP地址
*
* @author jamel.li
*/
@Slf4j
public class IpUtil {
/**
* 获取IP地址
* <p>
* 使用Nginx等反向代理软件, 则不能通过request.getRemoteAddr()获取IP地址
* 如果使用了多级反向代理的话,X-Forwarded-For的值并不止一个,而是一串IP地址,X-Forwarded-For中第一个非unknown的有效IP字符串,则为真实IP地址
*/
public static String getIpAddr(HttpServletRequest request) {
String ip = null;
try {
ip = request.getHeader("x-forwarded-for");
if (StrUtil.isEmpty(ip) || StringPool.UNKNOWN.equalsIgnoreCase(ip)) {
ip = request.getHeader("Proxy-Client-IP");
}
if (StrUtil.isEmpty(ip) || ip.length() == 0 || StringPool.UNKNOWN.equalsIgnoreCase(ip)) {
ip = request.getHeader("WL-Proxy-Client-IP");
}
if (StrUtil.isEmpty(ip) || StringPool.UNKNOWN.equalsIgnoreCase(ip)) {
ip = request.getHeader("HTTP_CLIENT_IP");
}
if (StrUtil.isEmpty(ip) || StringPool.UNKNOWN.equalsIgnoreCase(ip)) {
ip = request.getHeader("HTTP_X_FORWARDED_FOR");
}
if (StrUtil.isEmpty(ip) || StringPool.UNKNOWN.equalsIgnoreCase(ip)) {
ip = request.getRemoteAddr();
}
// x-forwarded-for多次反向代理后会有多个ip值,第一个ip才是真实ip
int index = ip.indexOf(",");
if (index != -1) {
return ip.substring(0, index);
} else {
return ip;
}
} catch (Exception e) {
log.error("IPUtil ERROR ", e);
}
return ip;
}
/**
* 获取本地IP地址
*/
public static String getServerIp() {
if (isWindowsOs()) {
try {
return InetAddress.getLocalHost().getHostAddress();
} catch (UnknownHostException e) {
return StringPool.EMPTY;
}
} else {
return getLinuxLocalIp();
}
}
/**
* 判断操作系统是否是Windows
*/
public static boolean isWindowsOs() {
boolean isWindowsOs = false;
String osName = System.getProperty("os.name");
if (osName.toLowerCase().contains(StringPool.WINDOWS)) {
isWindowsOs = true;
}
return isWindowsOs;
}
/**
* 获取Linux下的IP地址
*
* @return IP地址
*/
private static String getLinuxLocalIp() {
String ip = "";
try {
for (Enumeration<NetworkInterface> en = NetworkInterface.getNetworkInterfaces(); en.hasMoreElements(); ) {
NetworkInterface networkInterface = en.nextElement();
String name = networkInterface.getName();
if (!name.contains("docker") && !name.contains("lo")) {
for (Enumeration<InetAddress> enumIpAddr = networkInterface.getInetAddresses(); enumIpAddr.hasMoreElements(); ) {
InetAddress inetAddress = enumIpAddr.nextElement();
if (!inetAddress.isLoopbackAddress()) {
String ipaddress = inetAddress.getHostAddress();
if (!ipaddress.contains("::") && !ipaddress.contains("0:0:") && !ipaddress.contains("fe80")) {
ip = ipaddress;
}
}
}
}
}
} catch (SocketException ex) {
log.error("获取ip地址异常", ex);
}
return ip;
}
}
更多推荐
已为社区贡献3条内容
所有评论(0)