开发者社区 > 云原生 > 正文

dubbo 选中随机端口时 ServerSocket ignored = new ServerSoc

问题

无论我怎么重启服务,甚至重启电脑也无法解决。dubbo 提示:Address already in use 问题。 最后debug 一层一层网上找。最后经过测试发现 ServerSocket ignored = new ServerSocket(i); 会存在ignored.close(); 关闭失败问题。

现象

当我运行至portToBind = NetUtils.getAvailablePort(defaultPort); 时 sudo lsof -i tcp:20882 显示没有监听此端口。 当执行至ServerSocket ignored = new ServerSocket(i); 执行sudo lsof -i tcp:20882 显示端口已被监听,当执行ignored.close(); 成功执行未报错。 再次查看端口时,还是显示被监听。最后就提示端口已经被使用。 貌似 20880和20881 一般会启动成功。

截图

提问26.png

提问27.png

原提问者GitHub用户hai-go

展开
收起
大圣东游 2023-05-11 16:39:36 204 0
1 条回答
写回答
取消 提交回答
  • 这段代码逻辑你自己写个 demo 跑一下看看 IOException 是不是有东西,可能是环境配置的问题

    public static synchronized int getAvailablePort(int port) { if (port < MIN_PORT) { return MIN_PORT; }

        for (int i = port; i < MAX_PORT; i++) {
            if (USED_PORT.get(i)) {
                continue;
            }
            try (ServerSocket ignored = new ServerSocket(i)) {
                USED_PORT.set(i);
                port = i;
                break;
            } catch (IOException e) {
                // continue
            }
        }
        return port;
    }
    

    原回答者GitHub用户

    2023-05-12 10:29:38
    赞同 展开评论 打赏
问答标签:
问答地址:

阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。

相关电子书

更多
Dubbo开源现状与2.7规划 立即下载
Dubbo分布式服务治理实战 立即下载
《Dubbo 3.0 前瞻》 立即下载