Linux装SSH怎样最安全?

安装前检查

  1. 查看是否已安装
    终端执行:

    ssh -v  # 若显示版本信息则已安装
    systemctl status ssh  # 检查服务状态(Debian/Ubuntu)
    systemctl status sshd # 检查服务状态(CentOS/RHEL)

分发行版安装步骤

Debian/Ubuntu 系

sudo apt update && sudo apt upgrade -y  # 更新系统
sudo apt install openssh-server -y     # 安装SSH服务端
sudo systemctl enable --now ssh        # 启动并设置开机自启

CentOS/RHEL/Fedora

sudo yum check-update && sudo yum update -y  # 更新系统
sudo yum install openssh-server openssh-clients -y  # 安装服务端和客户端
sudo systemctl enable --now sshd             # 启动并设置开机自启

Arch Linux/Manjaro

sudo pacman -Syu openssh           # 更新系统并安装
sudo systemctl enable --now sshd   # 启动服务

openSUSE

sudo zypper refresh && sudo zypper update -y  # 更新系统
sudo zypper install openssh        # 安装
sudo systemctl enable --now sshd   # 启动服务

基础配置与安全加固

  1. 修改配置文件
    编辑 /etc/ssh/sshd_config

    sudo nano /etc/ssh/sshd_config
    • 更改默认端口(避免22端口扫描):
      Port 2222
    • 禁止root远程登录:
      PermitRootLogin no
    • 仅允许密钥认证(更高安全):
      PasswordAuthentication no
    • 限制用户白名单:
      AllowUsers your_username
  2. 重启服务生效

    sudo systemctl restart sshd  # 或 ssh(Ubuntu系)

防火墙放行SSH

  • UFW(Ubuntu)
    sudo ufw allow 2222/tcp  # 替换为自定义端口
    sudo ufw reload
  • Firewalld(CentOS/RHEL)
    sudo firewall-cmd --permanent --add-port=2222/tcp
    sudo firewall-cmd --reload

连接测试

  • 本地验证:
    ssh username@localhost -p 2222  # 使用自定义端口
  • 远程连接(其他设备):
    ssh username@服务器IP -p 2222

高级安全措施

  1. 密钥认证替代密码

    • 本地生成密钥:ssh-keygen -t ed25519
    • 上传公钥到服务器:ssh-copy-id -p 2222 user@host
  2. Fail2ban防护暴力破解

    sudo apt install fail2ban  # Debian/Ubuntu
    sudo yum install fail2ban  # CentOS/RHEL
  3. 定期更新SSH

    sudo apt upgrade openssh-server  # Ubuntu
    sudo yum update openssh-server   # CentOS

故障排查

  • 连接被拒:检查服务状态 systemctl status sshd 和防火墙规则。
  • 认证失败:确认 sshd_configPasswordAuthentication 和用户权限。
  • 端口占用sudo netstat -tuln | grep 2222 查看端口监听。

重要提示

  • 修改配置前备份原文件:sudo cp /etc/ssh/sshd_config{,.bak}
  • 测试配置有效性:sudo sshd -t
  • 首次配置建议保留一个活动会话,避免锁死服务器。

引用说明
操作参考 OpenSSH官方文档、Ubuntu Server指南 及 Red Hat系统管理手册,安全建议遵循NIST SP 800-123标准。

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

(0)
酷番叔酷番叔
上一篇 2025年7月10日 06:25
下一篇 2025年7月10日 06:37

相关推荐

  • 刻录Linux竟如此简单?

    将Linux系统镜像文件写入U盘或光盘的过程称为刻录,其目的是制作一个可启动的安装介质,用于在计算机上安装或运行Linux操作系统,通常需要专用刻录工具完成。

    2025年7月25日
    7400
  • Linux教程,如何在系统中正确创建一个新文件?

    Linux作为一款广泛使用的开源操作系统,其文件系统是管理数据的核心,掌握在Linux中创建文件的方法是日常操作和系统管理的基础技能,无论是编写脚本、编辑配置文件还是存储数据,都需要通过不同方式创建文件,本文将详细介绍Linux中创建文件的多种方法,涵盖命令行工具、文本编辑器及脚本实现,帮助用户根据不同场景选择……

    2025年9月22日
    4400
  • 为什么异常行为是最直接的危险信号?

    异常行为是最直观的警示信号,表现为明显偏离常态的言行举止,它能迅速引起注意,提示潜在风险或问题,是识别危机的重要依据。

    2025年7月4日
    7100
  • 如何快速上手并熟练掌握linux2.6系统的使用方法?

    Linux 2.6作为Linux内核的一个重要版本,自2003年发布以来,凭借其稳定的性能、增强的硬件支持和优化的调度算法,被广泛应用于服务器、嵌入式系统等领域,掌握Linux 2.6的使用,需要从安装、基础操作、系统管理到安全配置逐步实践,以下将详细介绍其核心使用方法,安装与初始配置Linux 2.6的安装可……

    2025年10月7日
    3500
  • Linux系统中释放文件句柄的方法有哪些?资源管理技巧

    在Linux系统中,文件句柄(File Handle)是操作系统用于管理打开文件、网络连接等资源的标识符,每个进程能打开的句柄数量受系统限制,当句柄耗尽时,系统无法创建新的文件或连接,可能导致服务异常甚至崩溃,因此及时释放无用句柄至关重要,以下是Linux释放文件句柄的详细方法和操作步骤,查看当前文件句柄使用情……

    2025年8月30日
    4700

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信