Linux下SSH连接服务器全攻略?

基础连接步骤

  1. 安装SSH客户端
    大多数Linux发行版已预装OpenSSH客户端,检查是否安装:

    ssh -V  # 显示版本即表示已安装

    若未安装,执行:

    sudo apt install openssh-client  # Debian/Ubuntu
    sudo yum install openssh-clients # CentOS/RHEL
  2. 发起连接
    基础命令格式:

    ssh 用户名@服务器IP -p 端口号
    • 示例
      ssh root@192.168.1.100 -p 22  # 默认端口22可省略
    • 首次连接提示
      会显示服务器指纹,输入yes确认信任。
  3. 输入密码登录
    按提示输入用户密码(输入时无显示),成功后进入服务器终端。


密钥认证(免密登录,更安全)

步骤1:生成密钥对
本地终端执行:

ssh-keygen -t ed25519  # 推荐ed25519算法,或使用rsa
  • 按提示设置密钥存储路径(默认~/.ssh/id_ed25519)和密码(可选)。

步骤2:上传公钥到服务器

ssh-copy-id -i ~/.ssh/id_ed25519.pub 用户名@服务器IP

输入服务器密码后,公钥会自动添加到服务器的~/.ssh/authorized_keys文件中。

步骤3:密钥登录验证

ssh 用户名@服务器IP  # 无需密码直接登录

常见问题与解决方案

问题 原因与解决方式
连接超时 检查防火墙:sudo ufw allow 22(Ubuntu)或firewall-cmd --add-port=22/tcp --permanent(CentOS)
Permission denied 密码错误:重新输入
服务器未开启密码登录:需使用密钥
用户无SSH权限:联系管理员
No route to host 服务器IP错误或网络不通,用ping 服务器IP测试
端口被修改 确认服务端口:ssh -p 新端口 用户@IP

高级技巧

  1. SSH配置文件简化连接
    编辑本地~/.ssh/config文件:

    Host myserver          # 自定义别名
      HostName 192.168.1.100
      User root
      Port 2222
      IdentityFile ~/.ssh/id_ed25519  # 指定密钥

    之后只需执行:ssh myserver

  2. 文件传输

    • 上传到服务器
      scp -P 22 本地文件.txt 用户名@服务器IP:/目标路径/
    • 从服务器下载
      scp 用户名@服务器IP:/远程文件.txt 本地路径/
  3. 端口转发(调试用)

    ssh -L 8080:localhost:80 用户@服务器IP  # 将本地8080映射到服务器80端口

安全最佳实践

  1. 禁用密码登录(提升安全性)
    登录服务器后编辑/etc/ssh/sshd_config

    PasswordAuthentication no  # 关闭密码登录
    PermitRootLogin no         # 禁止root直接登录
    Port 2222                  # 更改默认端口

    重启服务生效:sudo systemctl restart sshd

  2. 其他建议

    • 使用强密码或密钥密码(避免纯密钥无密码)。
    • 定期更新SSH服务:sudo apt upgrade openssh-server
    • fail2ban防御暴力破解。

SSH是Linux服务器管理的必备技能,掌握密钥登录和配置文件可大幅提升效率,务必遵循安全实践,如禁用密码登录、修改默认端口,以保护服务器免受攻击,遇到连接问题时,逐步检查网络、防火墙、服务状态(systemctl status sshd)和配置参数。

引用说明参考OpenSSH官方文档(openssh.com)、Linux man手册及服务器安全最佳实践,操作命令基于主流Linux发行版(Ubuntu/CentOS)验证。

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

(0)
酷番叔酷番叔
上一篇 2025年8月8日 05:37
下一篇 2025年8月8日 05:56

相关推荐

  • Linux系统如何通过命令查询内存使用情况?

    在Linux系统中,内存管理是系统性能优化的核心环节,准确查询内存使用情况有助于及时发现资源瓶颈、排查内存泄漏等问题,Linux提供了多种命令和工具来查询内存信息,涵盖系统总内存、已用内存、空闲内存、缓存、交换分区(Swap)等维度,以下从基础到进阶详细介绍各类方法,基础内存查询命令:freefree是最常用的……

    2025年8月28日
    8300
  • Ubuntu 20.04比CentOS 7强在哪?

    在Linux系统上安装Oracle客户端是连接Oracle数据库的关键步骤,以下为详细操作指南(以Oracle Instant Client为例,适用于CentOS/RHEL/Ubuntu等主流发行版),整个过程注重安全性和可维护性,遵循Oracle官方最佳实践,依赖包:# CentOS/RHELsudo yu……

    2025年7月14日
    11400
  • 测试人员如何用linux

    人员用 Linux 可进行功能、性能测试,利用命令行工具执行脚本,监控系统资源

    2025年8月17日
    10700
  • 在Linux系统中运行Python程序的具体方法与环境配置步骤是什么?

    在Linux系统中运行Python是开发过程中的常见需求,无论是脚本开发、数据分析还是Web应用,Python都因其简洁高效的特性被广泛应用,以下是Linux环境下运行Python的详细步骤和注意事项,帮助用户从环境准备到实际操作全面掌握,环境准备:检查Python是否已安装大多数Linux发行版默认会预装Py……

    2025年9月29日
    10100
  • 在Linux下,终端如何打开文件夹的具体操作步骤是怎样的?

    在Linux系统中,终端(Terminal)是高效管理文件和目录的重要工具,通过命令行打开文件夹(目录)有多种方式,可根据需求选择纯命令行操作或调用图形文件管理器,以下是详细说明:基础目录操作命令:切换与查看内容若需在终端中“打开”文件夹并进入其内部操作,核心命令是cd(change directory),搭配……

    2025年9月21日
    10600

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信