定时任务涉及到多机部署时,绑定IP是其中的一种解决方案。
设定某一IP的主机执行任务,定时任务先获取本服务器的IP,和绑定的IP进行比较,匹配则执行任务。
Java用户获取IP地址的是java.net包下的NetworkInterface类。
代码比较简单,直接上
public static String getLocalIp() {
Enumeration netInterfaces = null;
try {
netInterfaces = NetworkInterface.getNetworkInterfaces();
while (netInterfaces.hasMoreElements()) {
NetworkInterface nif = netInterfaces.nextElement();
Enumeration 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";
}
从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,则只有第一台会执行定时任务。