dubbo注册服务IP解析异常及IP解析源码分析

在使用dubbo注册服务时会遇到IP解析错误导致无法正常访问.
错误信息如下:

Could not get local host ip address, will use 127.0.0.1 instead., dubbo version: 2.0.1, current hos

解决方案一:

绑定hostname+ip
先执行 :

vi /etc/hostname
假定hostname 为: zzf

获取hostname , 在hosts 中绑定

vim /etc/hosts
添加如下 :
10.2.3.4 zzf

解决方案2:(不建议使用)

在dubbo的配置文件中写死host

在协议上绑定
<dubbo:protocol host="172.16.11.111"/>

或者在每个provider中绑定host
<dubbo:provider host="172.16.11.111">
源码部分

报错提示部分的源代码:

private static InetAddress getLocalAddress0() {
     InetAddress localAddress = null;
     try {
         localAddress = InetAddress.getLocalHost();
         if (isValidAddress(localAddress)) {
             return localAddress;
         }
     } catch (Throwable e) {
         logger.warn("Failed to retrieving ip address, " + e.getMessage(), e);
     }
     try {
         Enumeration<NetworkInterface> interfaces = NetworkInterface.getNetworkInterfaces();
         if (interfaces != null) {
             while (interfaces.hasMoreElements()) {
                 try {
                     NetworkInterface network = interfaces.nextElement();
                     Enumeration<InetAddress> addresses = network.getInetAddresses();
                     if (addresses != null) {
                         while (addresses.hasMoreElements()) {
                             try {
                                 InetAddress address = addresses.nextElement();
                                 if (isValidAddress(address)) {
                                     return address;
                                 }
                             } catch (Throwable e) {
                                 logger.warn("Failed to retrieving ip address, " + e.getMessage(), e);
                             }
                         }
                     }
                 } catch (Throwable e) {
                     logger.warn("Failed to retrieving ip address, " + e.getMessage(), e);
                 }
             }
         }
     } catch (Throwable e) {
         logger.warn("Failed to retrieving ip address, " + e.getMessage(), e);
     }
     logger.error("Could not get local host ip address, will use 127.0.0.1 instead.");
     return localAddress;
 }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值