Linux如何启动SSH远程服务?

SSH(Secure Shell)是远程管理 Linux 系统的核心工具,通过加密通道实现安全登录和文件传输,以下是专业、安全且适用于主流 Linux 发行版的 SSH 启动方法,涵盖安装、配置、防火墙设置及安全加固。


检查与安装 SSH 服务

  1. 确认 SSH 状态
    终端执行:

    systemctl status ssh   # Ubuntu/Debian
    systemctl status sshd  # CentOS/RHEL
    • 若显示 active (running),表示 SSH 已启动。
    • 若未安装,根据发行版安装 OpenSSH:

    Ubuntu/Debian

    sudo apt update && sudo apt install openssh-server -y

    CentOS/RHEL

    sudo yum install openssh-server openssh-clients -y

启动 SSH 并设置开机自启

  • 启动 SSH 服务

    sudo systemctl start ssh   # Ubuntu/Debian
    sudo systemctl start sshd  # CentOS/RHEL
  • 设置开机自动启动

    sudo systemctl enable ssh   # Ubuntu/Debian
    sudo systemctl enable sshd  # CentOS/RHEL

配置防火墙放行 SSH

默认 SSH 端口为 22,需在防火墙放行:

  • Ubuntu(UFW 防火墙)

    sudo ufw allow 22
    sudo ufw reload
  • CentOS/RHEL(Firewalld)

    sudo firewall-cmd --permanent --add-service=ssh
    sudo firewall-cmd --reload

注意:云服务器(如 AWS/Aliyun)需在安全组中额外开放端口 22。


安全加固配置(关键步骤)

强烈建议修改默认配置,防止暴力破解:

  1. 编辑配置文件:

    sudo nano /etc/ssh/sshd_config
  2. 调整以下参数:

    Port 2222                   # 修改默认端口(2222)
    PermitRootLogin no          # 禁止 root 远程登录
    PasswordAuthentication no   # 禁用密码登录(推荐用密钥)
    AllowUsers your_username    # 仅允许特定用户登录
  3. 保存后重启 SSH:

    sudo systemctl restart ssh   # 或 sshd

验证 SSH 连接

  • 本地测试:
    ssh username@localhost -p 2222  # 替换端口和用户名
  • 远程连接(其他设备):
    ssh username@服务器IP -p 2222

故障排查

  • 连接失败?检查防火墙、安全组、端口是否正确。
  • 日志路径:/var/log/auth.log(Ubuntu)或 /var/log/secure(CentOS)。

高级安全措施

  1. 密钥认证(更安全):

    • 生成密钥对:ssh-keygen -t ed25519
    • 上传公钥到服务器:ssh-copy-id -i ~/.ssh/id_ed25519.pub user@host -p 2222
  2. Fail2Ban 防护
    自动封禁暴力破解 IP:

    sudo apt install fail2ban   # Ubuntu
    sudo yum install fail2ban   # CentOS

启动 SSH 只需三步:安装 → 启动 → 放行端口,但安全配置才是核心,务必:
✅ 修改默认端口
✅ 禁用 root 登录和密码认证
✅ 使用密钥登录
✅ 定期更新系统:sudo apt upgradesudo yum update

遵循此指南,您将获得一个既可用又安全的 SSH 服务,适用于 Ubuntu、Debian、CentOS 等主流系统。


引用说明

  • OpenSSH 官方文档:https://www.openssh.com/manual.html
  • Ubuntu SSH 指南:https://help.ubuntu.com/lts/serverguide/openssh-server.html
  • CentOS 安全加固:https://wiki.centos.org/HowTos/Network/SecuringSSH

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

(0)
酷番叔酷番叔
上一篇 2025年7月9日 08:36
下一篇 2025年7月9日 08:47

相关推荐

  • Linux如何解压deb包?具体步骤和命令有哪些?

    在Linux系统中,deb包是Debian及其衍生发行版(如Ubuntu)常用的软件包格式,它采用ar归档工具打包,内部包含三个主要部分:debian-binary(包的版本信息)、control.tar.xz/zst(控制文件,包含安装脚本、依赖关系等元数据)和data.tar.xz/zst(实际安装的文件……

    2025年10月3日
    5900
  • U盘装Linux系统教程

    准备U盘,下载目标Linux发行版ISO镜像文件,使用专用工具(如Rufus、BalenaEtcher)将ISO写入U盘,制作完成后,重启电脑并设置从该U盘启动即可安装或体验Linux系统。

    2025年8月4日
    9700
  • Linux如何连接SMB共享文件夹?

    在Linux系统中连接SMB(Server Message Block)共享资源是常见的跨平台文件共享需求,SMB协议主要用于Windows系统间的文件共享,但通过Linux工具也能方便地访问这类共享,本文将详细介绍Linux连接SMB的多种方法,包括命令行和图形界面操作,涵盖安装工具、配置参数、权限管理等关键……

    2025年9月25日
    7000
  • 如何在Linux系统中搭建C语言开发环境并编写代码?

    Linux环境下进行C语言开发是许多开发者的首选,其强大的命令行工具链和开源生态为C语言提供了高效、灵活的编程环境,本文将详细介绍从环境搭建到代码编写、编译运行、调试及项目管理的完整流程,帮助读者快速上手Linux下的C语言开发,开发环境的准备是基础,Linux系统通常默认安装了GCC(GNU Compiler……

    2025年9月23日
    7100
  • Linux如何删除用户名?

    在Linux系统中,用户管理是系统维护的重要环节,当需要移除不再使用的用户时,需通过特定命令操作以确保系统安全与数据完整性,删除用户不仅涉及用户账户本身的移除,还需处理关联的主目录、邮件文件及权限配置,本文将详细说明Linux系统中删除用户名的完整流程、注意事项及常见场景处理方法,删除用户的核心命令与选项Lin……

    2025年9月19日
    7500

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信