SYN cookie

✍ dations ◷ 2025-04-12 08:26:30 #计算机网络安全,TCP/IP

SYN cookie 是一种用于阻止 SYN flood 攻击的技术。这项技术的主要发明人 Daniel J. Bernstein 将 SYN cookies 定义为“TCP 服务器进行的对开始TCP数据包序列数字的特定选择”。举例来说,SYN Cookies 的应用允许服务器当 SYN 队列被填满时避免丢弃连接。相反,服务器会表现得像 SYN 队列扩大了一样。服务器会返回适当的 SYN+ACK 响应,但会丢弃 SYN 队列条目。如果服务器接收到客户端随后的ACK响应,服务器能够使用编码在 TCP 序号内的信息重构 SYN 队列条目。

发起一个 TCP 连接时,客户端将一个 TCP SYN 包发送给服务器。作为响应,服务器将 TCP SYN + ACK 包返回给客户端。此数据包中有一个序号(sequence number,TCP头中的第二个32 bit),它被 TCP 用来重新组装数据流。根据 TCP 规范,由端点发送的第一个序号可以是由该端点决定的任何值。SYN Cookies 是根据以下规则构造的初始序号:

初始 TCP 序号,也就是所谓的 ,按照如下算法得到:

注:由于 必须用 3 位进行编码,服务器在启用了 SYN Cookie 时只能为 发送八种不同的数值。

根据 TCP 规范,当客户端发回 TCP ACK 包给服务器以响应服务器的 SYN + ACK 包时,客户端必须使用由服务器发送的初始序号加1作为数据包中的确认号。服务器接着从确认号中减去 1 以便还原向客户端发送的原始 SYN Cookie。

接下来服务器进行以下检查:

SYN Cookies 的使用不与任何协议定义冲突,照理来说它该和所有的 TCP 实现兼容。然而,当 SYN Cookies 使用的时候,会发生两种值得注意的变化:首先,服务器只能编码八种 MSS 数值,因为只有 3 位二进制空间可用。其次,这个服务器必须拒绝所有的 TCP 选用项,例如大型窗口和时间戳,因为服务器会在信息被用其他方式存储时丢弃 SYN 队列条目。

尽管这些限制将不可避免地导致一个不如最佳的体验,它们的效果很少被客户端注意到——这些改变只在被攻击时值得注意。在这样的情况下,牺牲 TCP 选项来保护连接一般被认为是合乎情理的。

Linux内核 从 2.6.26 版本开始为 TCP 选用项加入了有限的支持,通过把它们编码在时间戳内实现。

较新的 TCP Cookie 传输(TCPCT)标准被设计用来克服 SYN Cookies 的这些问题,并且在各种方面改进这套机制。不像 SYN Cookies,TCPCT 是一个 TCP 拓展并且要求两端点都支持 TCPCT。

被设置为允许所有出站连接但对入站连接有限制(例如在 Web 服务器上只允许 80 端口)的简单防火墙一般是这样实现的:只阻断不必要端口的 SYN 请求。如果 SYN Cookies 被启动了,应当小心以保证攻击者不能使用伪造 ACK、尝试随机序列号的方式来绕过这样的防火墙。因此 SYN cookies 应该按照每个端口单独处理的方式来调节开关,这样的话一个公共端口上的 SYN Cookies 并不会在一个私有端口上被认可。

Daniel J. Bernstein 和 Eric Schenk 于 1996 年九月创造了这个技术。Jeff Weisberg 在一个月后发布了最早的实现(在 SunOS 上),Eric Schenk 随后在 1997 年二月发布了他的 Linux 实现(目前的实现使用,例如 net.ipv4.tcp_syncookies 页面存档备份,存于互联网档案馆)。

相关

  • 化疗脑化疗脑,在学界又称化疗后认知异常(Post-chemotherapy cognitive impairment,简称PCCI)或化疗相关认知异常(Chemotherapy-Related Cognitive Impairments,简称CRCIs)等,所指的是因为
  • 中山科学研究院国家中山科学研究院(简称:中山科学研究院、中科院,英文简称:NCSIST),为中华民国国防科技研发机构,属于国防部监督之行政法人。主要目标为提升国防科技能力、建立自主国防工业、拓展
  • 世界丰收国际广播电台世界丰收国际广播电台(英语:World Harvest Radio International,WHRI),是总部位于美国的一家福音广播电台,对外使用WHRI、KWHR和WHRA3种呼号。1985年,WHRI开办了Angel 1频道,覆盖拉
  • 欧洲左翼党欧洲左翼党(英语:Party of the European Left,缩写为PEL)是一个欧洲政党,由欧盟成员国及其它欧洲国家的民主社会主义政党和共产主义政党组成。欧洲左翼党在2004年1月开始组织,同年
  • 约翰·德·兰西约翰·德·兰西(英语:John de Lancie,1948年3月20日-)是美国的喜剧演员、演员、导演、制片人、作家、歌手、音乐家、配音演员,最出名的作品是在《星际迷航》系列的《银河飞龙》、
  • 弗吉尼亚级攻击型核潜艇弗吉尼亚级核动力攻击潜艇(Virginia-class submarine,又称774级)是美国海军第一艘同时针对大洋和近海两种功能设计的核子潜艇。弗吉尼亚级是美国海军“新型攻击潜艇计划”(New A
  • 克里斯托弗罗·兰迪诺克里斯托弗罗·兰迪诺(英语:Cristoforo Landino),(1424年-1504年),文艺复兴时期欧洲意大利语言学家、诗人。他主要评注古典作家的著作,并将他们的著作与基督教教义和新柏拉图主义学说
  • 盲签名盲签名在密码学中是指,由 David Chaum 提出的盲签名是一种数字签名方式,其中消息的内容在签名之前对签名者是不可见的(盲化)。得到的盲签名可以对原始的、非盲消息以常规数字签
  • 首相答问环节 政治主题首相答问环节(英语:Prime Minister's Questions, PMQs),正式名称为向首相提问环节(英语:Questions to the Prime Minister)是英国的一种政治传统,自1997年起,逢星期三英国下
  • 努坦努坦(英语:Nutan,1936年6月4日-1991年2月21日)是印度知名女演员。努坦是印地语电影最受尊崇的女演员之一。在超过40年年的电影生涯中,她出演了大约70多部电影。她曾五次荣获印度电