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操作系统上搭建MySQL数据库环境的具体方法是什么?

    在Linux操作系统上搭建MySQL数据库环境是许多开发者和运维人员的必备技能,MySQL作为开源的关系型数据库管理系统,广泛应用于Web应用、数据存储等场景,本文将以主流的Linux发行版(如CentOS/RHEL和Ubuntu/Debian)为例,详细说明从环境准备到MySQL安装、配置、安全初始化及测试验……

    2025年9月27日
    11200
  • linux vi如何新建文件

    Linux 中,使用 vi 新建文件可通过 vi 文件名,若文件不存在

    2025年8月15日
    13500
  • Linux环境下C语言开发如何从环境搭建到程序运行的详细流程?

    在Linux环境下进行C语言开发,需要掌握工具链使用、编译流程、调试技巧及项目管理等核心技能,以下是详细步骤和要点:开发环境搭建是第一步,Linux系统通常已预装GCC(GNU Compiler Collection),可通过gcc –version检查,若未安装,在基于Debian的系统(如Ubuntu)中……

    2025年9月9日
    11900
  • Linux僵尸进程为何无法用kill杀死?如何彻底清除?

    在Linux/Unix系统中,进程是程序执行的基本单位,具有多种运行状态,其中僵尸进程(Zombie Process)是一种特殊且需要关注的异常状态,僵尸进程指的是子进程已经终止(完成执行或被强制终止),但其父进程尚未通过系统调用(如wait()或waitpid())获取子进程的终止状态,导致子进程的进程描述符……

    2025年8月31日
    11700
  • 大白菜如何安装Linux系统教程?

    用大白菜装机工具安装Linux系统虽然不如安装Windows常见,但通过正确的步骤同样可以实现,以下是详细教程,涵盖从准备到安装完成的全流程,帮助新手顺利完成Linux系统的部署,准备工作在开始操作前,需确保硬件和软件准备到位,避免中途出错,以下是具体清单:准备项目具体要求作用说明电脑确保电脑能正常开机,支持U……

    2025年9月17日
    12800

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信