首页
/ SSH-Audit项目:OpenSSH连接限速配置最佳实践

SSH-Audit项目:OpenSSH连接限速配置最佳实践

2025-06-19 05:47:05作者:鲍丁臣Ursa

背景介绍

在OpenSSH服务器的安全配置中,连接速率限制是一个重要的安全措施,特别是针对CVE-2002-20001(DHEat DoS攻击)这类漏洞的防护。SSH-Audit工具在检测过程中会评估服务器的连接速率限制配置,当发现潜在不足时会发出警告提示。

问题分析

SSH-Audit检测到连接速率超过20次/秒时会提示警告,这表明服务器可能容易受到DHEat DoS攻击。这种攻击通过大量快速建立的连接消耗服务器资源,导致服务不可用。

解决方案

方案一:OpenSSH内置配置

使用OpenSSH自带的PerSourceMaxStartups参数可以限制每个源IP的最大并发连接数:

PerSourceMaxStartups 1

优点

  • 配置简单直接
  • 无需额外工具支持

缺点

  • 会影响SSH-Audit的组交换测试
  • 可能干扰需要同时建立多个SSH连接的合法用例

方案二:系统防火墙配置

更灵活和全面的解决方案是通过系统防火墙实现连接速率限制。

Linux iptables方案

对于使用iptables的系统,以下规则将限制每个IP地址在10秒内最多建立10个新连接:

iptables -I INPUT -p tcp --dport 22 -m state --state NEW -m recent --set
iptables -I INPUT -p tcp --dport 22 -m state --state NEW -m recent --update --seconds 10 --hitcount 10 -j DROP

ip6tables -I INPUT -p tcp --dport 22 -m state --state NEW -m recent --set
ip6tables -I INPUT -p tcp --dport 22 -m state --state NEW -m recent --update --seconds 10 --hitcount 10 -j DROP

firewalld方案

对于使用firewalld的系统,等效配置如下:

firewall-cmd --permanent --direct --add-rule ipv4 filter INPUT_direct 0 -p tcp --dport 22 -m state --state NEW -m recent --set
firewall-cmd --permanent --direct --add-rule ipv4 filter INPUT_direct 1 -p tcp --dport 22 -m state --state NEW -m recent --update --seconds 10 --hitcount 10 -j REJECT --reject-with tcp-reset

firewall-cmd --permanent --direct --add-rule ipv6 filter INPUT_direct 0 -p tcp --dport 22 -m state --state NEW -m recent --set
firewall-cmd --permanent --direct --add-rule ipv6 filter INPUT_direct 1 -p tcp --dport 22 -m state --state NEW -m recent --update --seconds 10 --hitcount 10 -j REJECT --reject-with tcp-reset

firewall-cmd --reload

macOS PF防火墙方案

对于macOS系统,可以使用PF防火墙实现类似功能:

  1. 首先检查当前PF规则:
sudo pfctl -sr
  1. 编辑/etc/pf.conf文件,添加:
pass in proto tcp to port 22 keep state \
    (max-src-conn-rate 10/10, source-track rule)
  1. 重新加载PF配置:
sudo pfctl -f /etc/pf.conf

防火墙方案优点

  • 不影响SSH-Audit测试
  • 不会干扰合法用例
  • 配置灵活可调

防火墙方案缺点

  • 配置相对复杂
  • 需要系统管理员权限

实施建议

对于大多数生产环境,推荐使用防火墙方案,因为它提供了更精细的控制且不影响正常使用。对于简单环境或测试系统,可以使用OpenSSH内置配置方案。

无论选择哪种方案,都应定期使用SSH-Audit工具验证配置效果,确保连接速率确实被限制在安全范围内(建议低于20次/秒/源IP)。

登录后查看全文
热门项目推荐
相关项目推荐