定时任务涉及到多机部署时,绑定IP是其中的一种解决方案。
设定某一IP的主机执行任务,定时任务先获取本服务器的IP,和绑定的IP进行比较,匹配则执行任务。
Java用户获取IP地址的是java.net包下的NetworkInterface类。
代码比较简单,直接上
public static String getLocalIp() {
Enumeration<NetworkInterface> netInterfaces = null;
try {
netInterfaces = NetworkInterface.getNetworkInterfaces();
while (netInterfaces.hasMoreElements()) {
NetworkInterface nif = netInterfaces.nextElement();
Enumeration<InetAddress> InetAddress = nif.getInetAddresses();
while (InetAddress.hasMoreElements()) {
String ip = InetAddress.nextElement().getHostAddress();
if (ip.startsWith("192.168")) {
return ip;
}
}
}
} catch (SocketException e) {
}
return "127.0.0.1";
}
简单说下IP的规则
- 127.xxx.xxx.xxx 属于"loopback" 地址,即只能你自己的本机可见,就是本机地址,比较常见的有127.0.0.1;
- 192.168.xxx.xxx 属于private 私有地址(site local address),属于本地组织内部访问,只能在本地局域网可见。同样10.xxx.xxx.xxx、从172.16.xxx.xxx 到 172.31.xxx.xxx都是私有地址,也是属于组织内部访问;
- 169.254.xxx.xxx 属于连接本地地址(link local IP),在单独网段可用;
-
从224.xxx.xxx.xxx 到 239.xxx.xxx.xxx 属于组播地址,比较特殊的255.255.255.255 属于广播地址;
-
除此之外的地址就是点对点的可用的公开IPv4地址。
公司内部的IP是192.168开头,所以用startWith("192.168")进行匹配过滤。
比如设定的执行IP是 192.168.100.21 ,部署的机器三台 192.168.100.21、 192.168.100.22、 192.168.100.23,则只有第一台会执行定时任务。