现象:
系统运行在linux环境下,登录的时候突然变得异常缓慢,需要一分钟以上才能正常登录系统,里里外外排查后发现是因为InetAddress.getLocalHost()无法正常获取本地IP地址导致。
因是涉密项目,源码模拟如下:
package com.lijun.security.ddy.address;
import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.stereotype.Controller;
import java.net.InetAddress;
import java.net.UnknownHostException;
@Controller
public class MyAddresController implements ApplicationRunner {
@Override
public void run(ApplicationArguments args) {
long start=System.currentTimeMillis();
System.out.println("获取本机地址开始时间:"+start);
InetAddress localAddress= null;
try {
localAddress = InetAddress.getLocalHost();
System.out.println("本地地址:"+localAddress.toString());
} catch (UnknownHostException e) {
}
long end=System.currentTimeMillis();
System.out.println("获取本机地址,结束时间:"+end);
System.out.println("获取本机地址,耗时:"+(end-start)/1000);
}
}
运行在win环境下正常:
运行在linux环境下的异常:
从图上看,花了10秒时间
原因分析:
以上截图是我本机的机器名称,执行getLocalHost()方法的时候,根据“cenos1”名称去hosts文件里找匹配的ip发现找不到合适的IP,一直处于等待状态。
解决方法:
(1)、编辑hosts文件
(2)、在其后补充“cenos1”
(3)、保存,退出,再运行
问题解决!