如何避免 SYN 攻击?

文章目录

  • [一、增大 TCP 半连接队列](#一、增大 TCP 半连接队列)
  • [二、减少 SYN+ACK 重传次数](#二、减少 SYN+ACK 重传次数)
  • [三、开启 tcp_syncookies](#三、开启 tcp_syncookies)

什么是 SYN 攻击?

一、增大 TCP 半连接队列

增大 TCP 半连接队列,需要同时增大三个参数:

  • /proc/sys/net/ipv4/tcp_max_syn_backlog
  • /proc/sys/net/core/somazconn
  • listen() 函数的 backlog 参数

引申问题

为什么要同时增大这三个参数?详见TCP 半连接队列和全连接队列详解(结合 Linux 2.6.32 内核源码分析)

二、减少 SYN+ACK 重传次数

服务端受到 SYN 攻击时,会有大量处于 SYN_RCVD 状态的 TCP 连接,处于该状态的 TCP 会重传 SYN+ACK 报文,重传 tcp_synack_retries 次后,就会断开连接,我们可以通过减少 SYN+ACK 报文的重传次数,加快断开处于 SYN_RCVD 状态的 TCP 连接

三、开启 tcp_syncookies

我们先来看下 Linux 内核的「SYN 队列」和 「Accept 队列」是如何工作的?

开启 tcp_syncookies,可以在不使用「SYN 队列」的情况下建立 TCP 连接

  1. 「SYN 队列」满了的情况下,服务端不会丢弃后续收到的 SYN 报文,而是根据算法计算出 cookie 值,将其填入 TCP 首部的「序列号」字段后发送 SYN+ACK 报文给客户端
  2. 服务端收到客户端的 ACK 报文后,会检查其合法性,如果合法,将该连接放入「Accept 队列」中,最后应用程序通过调用 accpet() 接口从「Accept 队列」取出连接

/proc/sys/net/ipv4/tcp_syncookies 主要有三个值:

  • 0:关闭该功能
  • 1:「SYN 队列」放不下时,启用该功能
  • 2:无条件启用该功能
相关推荐
weixin_5118404723 分钟前
2026年5月4日 OCS技术方案路线选择与优劣深度调研报告
网络·人工智能
绝知此事24 分钟前
Netty实战:从零构建高性能TCP通信服务(含心跳检测)
java·网络·spring boot·网络协议·tcp/ip
小初生ZLD2 小时前
AI开发者的网络卡点:Anthropic连接超时实战避坑
网络
Bobolink_2 小时前
跨境网络中“高延迟”问题的技术成因与解决路径
网络·网络优化·跨境网络
呉師傅2 小时前
UPS滴滴告警!如何测量UPS电池内阻【UPS学习】
运维·服务器·网络·学习·电脑
@insist1232 小时前
信息安全工程师-工控安全产品体系与行业实践全解析
网络·安全·软考·信息安全工程师·软件水平考试
段一凡-华北理工大学2 小时前
2026 高炉炼铁智能化技术全景与演进路径~系列文章03:高炉工业数据治理标准化与全生命周期血缘体系
网络·人工智能·高炉炼铁·工业智能体·炉温监测·高炉智能化
tedcloud1233 小时前
wifi-densepose部署教程:构建无线人体感知系统
服务器·javascript·网络·typescript·ocr
星融元asterfusion4 小时前
INT 技术实现流量路径预览:RoCE网络监控小工具的深度解析
网络
cui_ruicheng4 小时前
Linux网络编程(七):TCP Socket编程与EchoServer
linux·服务器·网络·tcp/ip