记一次InetAddress.getLocalHost()异常导致系统运行缓慢的处理过程

现象:

系统运行在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环境下正常:

记一次InetAddress.getLocalHost()异常导致系统运行缓慢的处理过程_第1张图片

运行在linux环境下的异常:

记一次InetAddress.getLocalHost()异常导致系统运行缓慢的处理过程_第2张图片

从图上看,花了10秒时间

原因分析:

以上截图是我本机的机器名称,执行getLocalHost()方法的时候,根据“cenos1”名称去hosts文件里找匹配的ip发现找不到合适的IP,一直处于等待状态。

解决方法:

(1)、编辑hosts文件

(2)、在其后补充“cenos1”

(3)、保存,退出,再运行

问题解决!

 

 

 

 

你可能感兴趣的:(JAVA)