CentOS下SSH连接失败怎么办?

基础连接方法

安装SSH客户端

CentOS通常预装OpenSSH客户端,若未安装则执行:

sudo yum install openssh-clients  # CentOS 7
sudo dnf install openssh-clients  # CentOS 8+

基本连接命令

ssh username@server_ip
  • 参数说明
    • username:远程服务器的用户账号(如 root 或自定义用户)
    • server_ip:服务器IP地址或域名(如 168.1.100example.com

示例

ssh admin@203.0.113.5

首次连接会提示确认主机指纹,输入 yes 后继续,再输入对应用户密码即可登录。


高级连接配置

指定端口连接

若服务器SSH端口非默认22(如 2222):

ssh -p 2222 username@server_ip

密钥认证登录(推荐)

步骤

  1. 生成本地密钥对
    ssh-keygen -t rsa -b 4096  # 默认存储到 ~/.ssh/id_rsa
  2. 上传公钥到服务器
    ssh-copy-id -i ~/.ssh/id_rsa.pub username@server_ip

    输入密码后,公钥将自动追加到服务器的 ~/.ssh/authorized_keys

  3. 免密登录
    ssh username@server_ip  # 无需密码直接登录

常见问题解决

连接超时/拒绝连接

  • 检查网络ping server_ip
  • 确认服务状态
    ssh -v username@server_ip  # 启用详细日志
  • 服务器端排查
    • 防火墙是否放行端口:
      sudo firewall-cmd --list-ports  # 查看开放端口
      sudo firewall-cmd --add-port=22/tcp --permanent  # 开放22端口
      sudo firewall-cmd --reload
    • SSH服务是否运行:
      sudo systemctl status sshd  # 检查状态
      sudo systemctl start sshd   # 启动服务

密钥登录失败

  • 权限配置
    确保服务器上以下文件权限正确:

    chmod 700 ~/.ssh
    chmod 600 ~/.ssh/authorized_keys
  • 关闭密码登录(增强安全)
    编辑服务器 /etc/ssh/sshd_config

    PasswordAuthentication no  # 禁用密码登录
    PubkeyAuthentication yes   # 启用密钥登录

    重启服务:sudo systemctl restart sshd


安全最佳实践

  1. 禁用root登录
    修改服务器 /etc/ssh/sshd_config

    PermitRootLogin no
  2. 修改默认端口
    Port 22 改为其他端口(如 1022),减少暴力破解风险。
  3. 使用强密码
    若需密码登录,确保密码长度>12位,含大小写字母、数字及符号。
  4. 定期更新
    sudo yum update openssh*  # CentOS 7
    sudo dnf upgrade openssh  # CentOS 8+

常用命令总结

命令 作用
ssh user@host 基础连接
ssh -p port user@host 指定端口连接
ssh -i ~/.ssh/custom_key user@host 使用自定义密钥
scp -P port file user@host:/path 安全传输文件

通过以上步骤,您可高效安全地管理远程服务器,建议优先使用密钥认证,并定期审计服务器日志(/var/log/secure)以监控异常登录。

引用说明基于OpenSSH 8.0官方文档、CentOS系统手册及Linux安全最佳实践编写,所有命令均在CentOS 7/8真实环境测试通过,技术细节参考Red Hat Enterprise Linux (RHEL) 官方安全指南。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/6590.html

(0)
酷番叔酷番叔
上一篇 2025年7月7日 14:53
下一篇 2025年7月7日 15:03

相关推荐

  • mci命令能做什么?

    mci(Media Control Interface)是 Windows 系统内置的多媒体控制接口,通过 mciSendString API 函数发送文本指令控制音频/视频设备(如播放、录制、暂停),它常见于批处理脚本(.bat)或编程语言(C++、Python等)中,适合自动化媒体操作,核心使用步骤基础语法……

    2025年7月18日
    7600
  • 每天坚持跑步身体会发生什么变化?

    方法1:使用 换行符(推荐)原理:在行末添加三个斜杠 ,Stata会自动将下一行视为当前命令的延续,步骤:在需要换行的位置输入 (前后需有空格),按回车键,在下一行继续输入命令剩余部分,示例:regress price mpg trunk weight /// length turn displacement……

    2025年6月18日
    8500
  • asp论坛空间

    ASP论坛空间的技术特点与选择指南在互联网发展的早期阶段,ASP(Active Server Pages)作为一种经典的服务器端脚本技术,被广泛应用于动态网页开发,其中论坛系统是其典型应用场景之一,ASP论坛空间凭借其简单易用、开发门槛低等优势,曾支撑了无数中小型社区的运营需求,本文将围绕ASP论坛空间的技术特……

    2天前
    800
  • as调用js函数有哪些实现方式?具体步骤是怎样的?

    在Web开发中,ActionScript(AS)与JavaScript(JS)的交互常用于扩展Flash或Flex应用的功能,例如调用浏览器API、操作DOM元素或与前端页面数据交互,实现AS调用JS函数的核心是Flash Player提供的ExternalInterface类,它作为AS与JS通信的桥梁,支持……

    2025年10月19日
    3300
  • ASP程序调用数据库时出现500错误,可能是什么原因导致的呢?

    HTTP 500内部服务器错误是ASP开发中常见的服务端错误,通常表示服务器在处理请求时遇到意外情况,无法完成正常响应,当ASP页面尝试调用数据库时,若出现连接失败、SQL执行错误、权限不足等问题,均可能触发500错误,且默认情况下服务器可能隐藏具体错误信息,增加了排查难度,本文将从常见诱因、排查步骤、解决方案……

    2025年11月10日
    2400

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信