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

相关推荐

  • 如何确认光纤接口状态正常?

    通过设备管理工具识别光纤接口物理连接状态,并检查其信号传输与协商状态,确保接口工作正常、通信无异常。

    2025年7月21日
    17700
  • Linux如何切换桌面环境?

    Linux系统以其高度的可定制性和开源特性,吸引了大量用户,而桌面环境作为用户与系统交互的核心界面,其选择直接影响使用体验,用户可能因性能需求、功能偏好或操作习惯的改变,需要转换桌面系统,这种转换既包括在同一Linux发行版内更换桌面环境,也涉及从其他操作系统(如Windows)迁移到Linux桌面,本文将详细……

    2025年9月17日
    14500
  • Linux系统下如何查看不同类型压缩文件的编码格式及方法?

    在Linux系统中,处理压缩文件时,“编码”通常涉及两个层面:一是压缩文件内文本内容的字符编码(如UTF-8、GBK等),二是压缩文件本身的文件名编码(尤其是从Windows系统传来的zip文件,可能因编码差异导致乱码),本文将详细介绍如何查看这两类编码,涵盖主流压缩格式(zip、tar.gz、tar.bz2……

    2025年8月24日
    14600
  • Linux下cout如何控制终端颜色?实现方法与代码示例解析

    在Linux环境下,C++的cout本身并不直接提供颜色控制功能,但可以通过输出ANSI转义序列来实现终端颜色和样式的调整,ANSI转义序列是一组以ESC(ASCII码27,八进制\033或十六进制\x1b)开头的控制字符,终端会解析这些序列并改变后续文本的显示效果,如颜色、背景、加粗、闪烁等,这种方法在Lin……

    2025年8月23日
    13800
  • Linux如何查看光驱信息?,或,各Linux系统怎么检测光驱?

    命令行方法(推荐)使用 lsblk 命令这是最直观的方法,可列出所有块设备(包括光驱):lsblk输出示例: NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINTsr0 11:0 1 1024M 0 rom /run/media/user/CDROMsr0 或 cdrom 表示光驱设备……

    2025年6月15日
    18400

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信