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系统,配置网络连接后,使用系统自带或安装的下载工具(如wget、curl或图形化下载器)进行文件下载,注意管理虚拟磁盘空间。

    2025年7月30日
    13200
  • 为什么早睡早起身体好吗

    在Linux系统中,处理文本时经常需要去除特殊字符(如!@#$%^&*()、制表符、换行符等),这些字符可能导致脚本错误、数据解析失败或安全风险,以下是多种经过验证的专业方法,适用于不同场景:什么是特殊字符?特殊字符指非字母数字的常规字符(ASCII 0-32及127-255),常见于:控制字符:换行符……

    2025年7月19日
    11100
  • Linux系统如何登录root用户?详细操作步骤与方法是什么?

    在Linux系统中,root用户是超级用户,拥有对系统的完全控制权限,包括修改系统文件、安装软件、管理用户等操作,由于权限过高,直接使用root用户登录存在较大安全风险,因此通常推荐普通用户通过sudo命令临时获取root权限,但在某些特殊场景下(如系统维护、紧急修复),仍需要掌握root用户的登录方法,本文将……

    2025年9月29日
    20600
  • Linux Qt5如何使用qmake进行项目配置编译?

    在Linux环境下使用Qt5开发时,qmake是官方推荐的构建工具,它通过解析项目配置文件(.pro文件)自动生成Makefile,简化了跨平台项目的编译和构建流程,以下是详细的使用步骤和注意事项,环境准备在使用qmake前,需确保系统已安装Qt5开发环境,以Ubuntu/Debian系统为例,可通过以下命令安……

    2025年8月25日
    10700
  • 终端死循环卡屏?速解妙招在此!

    在Linux系统中,死循环通常指因代码逻辑错误(如while true未设退出条件)或命令执行异常导致的进程持续占用资源且无法正常退出的情况,以下是针对不同场景的解决方案,操作前请务必确认目标进程,避免误杀系统关键进程,快捷键强制退出按下组合键 Ctrl + C(发送 SIGINT 信号),大多数前台进程会立即……

    2025年6月13日
    12700

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信