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

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

2025-06-19 21:17:17作者:鲍丁臣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)。

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

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
176
261
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
860
511
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
259
300
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
332
1.08 K
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
kernelkernel
deepin linux kernel
C
22
5