有人可以幫助我了解 HAProxy DDoS 攻擊防護配置嗎?

有人可以幫助我了解 HAProxy DDoS 攻擊防護配置嗎?

我現在使用 HAP 一段時間,現在我嘗試為每個前端配置 DDoS 保護,如果每秒從同一來源 IP 收到超過 200 個請求,則阻止連接 5 分鐘,考慮到這一事實考慮到多源ip可以/將被用來發動攻擊。我查看了互聯網上的各種部落格文章和帖子,我發現我對實現我的目的所需的正確配置感到更加困惑。

以下是我迄今為止收集的所有配置:

backend ip_rates_abuse
  stick-table type ip size 200k expire 5m store gpc0,conn_cur,conn_rate(10s),http_req_rate(10s),http_err_rate(10s)

frontend fe_dev_mydomain_com
  .....
  ## ----- TCP Layer DDoS protection ------------ ##
  timeout       tarpit 15s
  tcp-request   inspect-delay 5s
  #
  tcp-request   content reject if { src_conn_rate(ip_rates_abuse) ge 200 }
  tcp-request   content reject if { src_conn_cur(ip_rates_abuse) ge 500 }
  tcp-request   content reject if { src_get_gpc0(ip_rates_abuse) gt 0 }
  tcp-request   session track-sc0 src table ip_rates_abuse
  #
  ## ----- Application Layer DDoS protection ------------ ##
  acl           too_many_reqs sc_http_req_rate(0) gt 200
  http-request  track-sc1 src table ip_rates_abuse
  http-request  set-var(txn.ratelimited) str(RATE-LIMITED) if too_many_reqs
  http-request  capture var(txn.ratelimited) len 12
  http-request  deny deny_status 429 if too_many_reqs
  .....
  use_backend   be_waf if no_tarpit || tarpit_max_capacity

然後在後台:

backend be_waf
  acl          too_many_clicks sc1_http_req_rate gt 200
  acl          mark_as_abuser sc0_inc_gpc0(ip_rates_abuse) gt 0
  tcp-request  content track-sc1 src table ip_rates_abuse
  tcp-request  content reject if too_many_clicks mark_as_abuser
  .....

我很確定我不明白很多事情,但我做對了嗎?對我來說似乎有點過頭了,而且似乎也不起作用。誰能建議我實現目標所需的最低配置?

-S

相關內容