SSH 安全实战:配置加固、防爆破与二次验证!

目录:

一、引言

二、sshd 服务配置加固

三、基于 IP 的访问控制(hosts.allow/hosts.deny)

  1. 默认拒绝所有外部访问

  2. 允许指定源 IP 地址

四、fail2ban: 动态防御暴力破解

  1. 安装 fail2ban

  2. 配置规则

  3. 启动与验证

五、Google Authenticator:二次认证(2FA)

  1. 安装并初始化

  2. 修改 PAM 验证模块

  3. 启用质询响应

  4. 重启 sshd 服务

  5. 登录流程

六、总结

一、引言

SSH 是 Linux 系统中最基础且最常被攻击的远程访问协议。任何暴露在公网的 SSH 服务都可能在短时间内遭受端口扫描与暴力破解尝试。本篇文章旨在从 服务配置、访问控制、行为防御与多因素认证 四个方面,系统性提升 SSH 服务的安全性。

二、sshd 服务配置加固

文件位置:/etc/ssh/sshd_config

配置项 推荐值 说明
Port 非默认端口,如 22922 减少被扫描概率
PermitRootLogin no 禁止 root 用户登录
PasswordAuthentication no 禁止密码认证,仅使用密钥认证
AllowUsers opsuser 限定允许登录的账户名
MaxAuthTries 3 限制登录尝试次数
LoginGraceTime 30 限制认证超时时间
X11Forwarding no 禁止图形转发
AllowTcpForwarding no 禁止 TCP 转发

修改后执行 systemctl restart sshd 使配置生效。

三、基于 IP 的访问控制(hosts.allow/hosts.deny)

文件位置:

  • /etc/hosts.allow

  • /etc/hosts.deny

这两份文件属于 TCP Wrapper 控制机制(sshd 默认支持)。

1. 默认拒绝所有外部访问

/etc/hosts.deny 中写入:

复制代码
sshd: ALL

2. 允许指定源 IP 地址

/etc/hosts.allow 中写入:

复制代码
sshd: 10.10.10.0/24,10.188.188.188

支持配置网段和单个 IP 地址,无论你是一行写多个地址,还是分行列出来,hosts.allow 都能正常识别,效果完全一样。配置方式可以根据你自己的习惯来。

复制代码
sshd: 10.10.10.0/24
sshd: 10.188.188.188

四、fail2ban: 动态防御暴力破解

fail2ban 通过监控日志文件自动封禁异常 IP。

1. 安装 fail2ban

复制代码
apt -y install fail2ban

2. 配置规则

新建 /etc/fail2ban/jail.local

复制代码
[sshd]
enabled  = true
port     = 22
filter   = sshd
logpath  = /var/log/auth.log
maxretry = 3
findtime = 10m
bantime  = 1h

3. 启动与验证

fail2ban 会基于日志匹配封禁源 IP,防御大多数自动化爆破工具。

五、Google Authenticator:二次认证(2FA)

1. 安装并初始化

复制代码
apt install libpam-google-authenticator
google-authenticator

扫描生成的二维码并保存应急码。

2. 修改 PAM 验证模块

编辑 /etc/pam.d/sshd

在顶部添加:

复制代码
auth required pam_google_authenticator.so

3. 启用查询响应

编辑 /etc/ssh/sshd_config

复制代码
ChallengeResponseAuthentication yes

4. 重启 sshd 服务

复制代码
systemctl restart sshd

5. 登录流程

  • Verification code --> Password

  • 任何单一凭据泄露都不足以登录系统

六、总结

安全与便捷从来是一对对立的矛盾。 SSH 加固的每一步操作------无论是禁用密码登录、限制来源 IP,还是启用二次认证------都会让远程登录变得更加繁琐。 但这正是安全的本质:牺牲效率,换取确定性

对于生产环境而言,SSH 并不只是一个"登录入口",而是系统边界的最后防线。 一个未做限制的端口、一个共享的密钥文件、一次被遗忘的测试账户,都可能成为入侵的切入点。

所以,在安全与便捷之间,理性的选择不是偏向任何一端,而是明确权衡边界

  • 在个人环境,可以降低部分约束、保留便捷;

  • 在服务器生产环境,应优先考虑最小暴露面与最小权限;

  • 在企业或多用户环境,应引入集中密钥管理与审计机制。

相关推荐
晚霞的不甘33 分钟前
守护智能边界:CANN 的 AI 安全机制深度解析
人工智能·安全·语言模型·自然语言处理·前端框架
枷锁—sha34 分钟前
【SRC】SQL注入快速判定与应对策略(一)
网络·数据库·sql·安全·网络安全·系统安全
数字护盾(和中)36 分钟前
信创生态 + 国密算法 筑牢数字安全韧性根基
安全
devmoon2 小时前
在 Polkadot 上部署独立区块链Paseo 测试网实战部署指南
开发语言·安全·区块链·polkadot·erc-20·测试网·独立链
傻小胖2 小时前
22.ETH-智能合约-北大肖臻老师客堂笔记
笔记·区块链·智能合约
成茂峰2 小时前
软考高级·系统架构设计师 | 四、信息技术安全知识
安全·信息安全·系统架构·架构设计师
浅念-2 小时前
C++入门(2)
开发语言·c++·经验分享·笔记·学习
向哆哆2 小时前
CANN生态安全保障:cann-security-module技术解读
人工智能·安全·cann
wuli_滔滔3 小时前
CANN安全机制源码探秘 仓库中的权限校验与数据加密实现
安全·cann
张人玉3 小时前
VisionPro 定位与卡尺测量学习笔记
笔记·学习·计算机视觉·vsionprp