摘要

在开发与运维工作中,Connection Refused 是一个常见的错误提示,通常表示无法成功连接目标服务。
本篇博客将详细讲解这一问题的原因、排查方法及解决方案,并附上代码示例,帮助小白用户快速掌握处理思路。如果你也遇到类似问题,不妨跟随本文一起深入学习,彻底解决问题!


引言

什么是 Connection Refused?
Connection Refused 表示客户端尝试连接目标服务器时,服务器拒绝了该连接请求。

在这里插入图片描述

博主 默语带您 Go to New World.
个人主页—— 默语 的博客👦🏻 优秀内容
《java 面试题大全》
《java 专栏》
《idea技术专区》
《spring boot 技术专区》
《MyBatis从入门到精通》
《23种设计模式》
《经典算法学习》
《spring 学习》
《MYSQL从入门到精通》数据库是开发者必会基础之一~
🍩惟余辈才疏学浅,临摹之作或有不妥之处,还请读者海涵指正。☕🍭
🪁 吾期望此文有资助于尔,即使粗浅难及深广,亦备添少许微薄之助。苟未尽善尽美,敬请批评指正,以资改进。!💻⌨


默语是谁?

大家好,我是 默语,别名默语博主,擅长的技术领域包括Java、运维和人工智能。我的技术背景扎实,涵盖了从后端开发到前端框架的各个方面,特别是在Java 性能优化、多线程编程、算法优化等领域有深厚造诣。

目前,我活跃在CSDN、掘金、阿里云和 51CTO等平台,全网拥有超过10万的粉丝,总阅读量超过1400 万。统一 IP 名称为 默语 或者 默语博主。我是 CSDN 博客专家、阿里云专家博主和掘金博客专家,曾获博客专家、优秀社区主理人等多项荣誉,并在 2023 年度博客之星评选中名列前 50。我还是 Java 高级工程师、自媒体博主,北京城市开发者社区的主理人,拥有丰富的项目开发经验和产品设计能力。希望通过我的分享,帮助大家更好地了解和使用各类技术产品,在不断的学习过程中,可以帮助到更多的人,结交更多的朋友.


我的博客内容涵盖广泛,主要分享技术教程、Bug解决方案、开发工具使用、前沿科技资讯、产品评测与使用体验。我特别关注云服务产品评测、AI 产品对比、开发板性能测试以及技术报告,同时也会提供产品优缺点分析、横向对比,并分享技术沙龙与行业大会的参会体验。我的目标是为读者提供有深度、有实用价值的技术洞察与分析。


解决 Connection Refused: 系统错误


常见的触发场景

  • 访问本地或远程服务时(如 HTTP、TCP 连接)。
  • 使用 SSH 或远程桌面连接服务器。
  • 数据库服务连接失败。

常见报错形式

  1. Java 程序错误

    java.net.ConnectException: Connection refused
    
  2. SSH 连接错误

    ssh: connect to host example.com port 22: Connection refused
    
  3. 数据库连接错误

    SQLException: Connection refused: connect
    

接下来,我们将通过实际场景的分析与代码示例,从问题根源出发,逐步排查并解决问题。


正文

一、问题原因分析

导致 Connection Refused 错误的主要原因包括:

  1. 目标服务未启动:目标服务器上的服务进程未运行或意外停止。
  2. 网络通信受阻:网络配置问题或防火墙限制导致通信失败。
  3. 端口错误:客户端连接了错误的端口号。
  4. 服务地址配置问题:使用了错误的 IP 地址或主机名。
  5. 客户端超时或权限不足:客户端请求被服务器阻止或未授权。

二、详细解决方案
1. 确保服务已启动

排查步骤

  • 检查目标服务是否正常运行:

    ps -ef | grep <服务名>
    
  • 如果服务未启动,则启动服务。例如,对于 Nginx:

    sudo systemctl start nginx
    

注意:如果你使用的是 Docker 服务,可以用以下命令检查容器状态:

docker ps
2. 检查目标地址和端口

验证地址的可用性

  • 使用

    ping
    

    测试主机是否可达:

    ping example.com
    
  • 使用

    telnet
    

    测试端口是否开放:

    telnet example.com 8080
    

修改代码中的连接参数
确保代码中 IP 和端口配置正确,例如:

错误示例

Socket socket = new Socket("192.168.0.1", 9090); // 错误的 IP 或端口

修正后代码

Socket socket = new Socket("127.0.0.1", 8080); // 本地服务的正确配置
3. 检查防火墙和安全组
  • 本地防火墙
    检查防火墙规则:

    sudo ufw status
    

    开放端口:

    sudo ufw allow 8080
    
  • 云服务器安全组
    登录云服务提供商控制台,确保实例的安全组中添加了目标端口的入站规则。

4. 查看服务日志

服务端的日志往往包含更详细的信息。例如:

  • Nginx 日志

    tail -f /var/log/nginx/error.log
    
  • SSH 日志

    journalctl -u sshd
    

根据日志提示调整服务配置,例如修改绑定的地址或端口。

5. 示例:解决数据库连接问题

以下示例演示了如何正确配置数据库连接:

错误代码

Connection connection = DriverManager.getConnection(
    "jdbc:mysql://localhost:3307/mydb", "root", "password");

修正代码

Connection connection = DriverManager.getConnection(
    "jdbc:mysql://127.0.0.1:3306/mydb", "root", "password");

此外,还需要确保数据库服务已启动:

sudo systemctl start mysql
6. 调整服务器配置

对于部分服务,可能需要更新配置文件。例如:

  • Nginx

    确保在

    nginx.conf
    

    中正确绑定地址和端口:

    server {
        listen 80;
        server_name localhost;
    }
    

    重启服务:

    sudo systemctl restart nginx
    

三、案例复现与解决

以下是一个实际案例的完整解决流程:

场景:Java 客户端连接远程服务器失败,报错:

java.net.ConnectException: Connection refused

解决流程

  1. 确认服务状态:登录服务器,发现目标服务未启动。

  2. 启动服务

    sudo systemctl start my-service
    
  3. 测试端口

使用

telnet
验证端口:
telnet 192.168.0.1 8080
  1. 修复代码:将错误的端口号从 9090 修改为 8080

修复后,问题成功解决。


总结

通过上述方法,我们可以快速排查并解决 Connection Refused 错误。
解决步骤概括

  1. 检查目标服务状态。
  2. 验证 IP 地址和端口。
  3. 调整防火墙与安全组配置。
  4. 检查服务端日志,分析错误原因。
  5. 修复客户端代码中的配置。

参考资料


加入技术交流群

如果在解决过程中遇到任何问题,欢迎添加我的微信,我们可以一起探讨技术问题!

扫码加微信,加入我们的技术交流群,获取更多技术干货!😊


如对本文内容有任何疑问、建议或意见,请联系作者,作者将尽力回复并改进📓;(联系微信:Solitudemind )
点击下方名片,加入IT技术核心学习团队。一起探索科技的未来,共同成长。

更多推荐