SYN攻击原理

news/2024/5/17 19:25:23 标签: 防火墙, tcp, linux, linux内核, server, 服务器

SYN攻击原理
chinayoung 发表于 - 2005-8-2 10:10:00
0
推荐SYN攻击

最近对SYN Flood特别感兴趣,看到一个关于SYN cookie firewall的文章,在google搜了一下,没中文的,翻译他一下 
本文介绍了4个概念
一:介绍SYN
二:什么是SYN洪水攻击
三:什么是SYN cookie
四:什么是SYN cookie防火墙
C=client(客户器)
S=Server(服务器)
FW=Firewall(防火墙)
一:介绍SYN
SYN cookie是一个防止SYN洪水攻击技术。他由D. J. Bernstein和Eric Schenk发明。现在SYN COOKIE已经是linux内核的一部分了(我插一句

,默认的stat是no),但是在linux系统的执行过程中它只保护linux系统。我们这里只是说创建一个linux防火墙,他可以为整个网络和所有的网

络操作系统提供SYN COOKIE保护你可以用这个防火墙来阻断半开放式tcp连接,所以这个受保护的系统不会进入半开放状态(TCP_SYN_RECV)。当

连接完全建立的时候,客户机到服务器的连接要通过防火墙来中转完成。

二:什么是SYN洪水攻击?(来自CERT的警告)
当一个系统(我们叫他客户端)尝试和一个提供了服务的系统(服务器)建立TCP连接,C和服务端会交换一系列报文。
这种连接技术广泛的应用在各种TCP连接中,例如telnet,Web,email,等等。
首先是C发送一个SYN报文给服务端,然后这个服务端发送一个SYN-ACK包以回应C,接着,C就返回一个ACK包来实现一次完

整的TCP连接。就这样,C到服务端的连接就建立了,这时C和服务端就可以互相交换数据了。下面是上文的图片说明:)
Client Server
------ ------
SYN-------------------->

<--------------------SYN-ACK

ACK-------------------->

Client and server can now
send service-specific data

在S返回一个确认的SYN-ACK包的时候有个潜在的弊端,他可能不会接到C回应的ACK包。这个也就是所谓的半开放连接,S需要

耗费一定的数量的系统内存来等待这个未决的连接,虽然这个数量是受限的,但是恶意者可以通过创建很多的半开放式连接来发动SYN洪水攻击 。
通过ip欺骗可以很容易的实现半开放连接。攻击者发送SYN包给受害者系统,这个看起来是合法的,但事实上所谓的C根本不会回应这个 。
SYN-ACK报文,这意味着受害者将永远不会接到ACK报文。
而此时,半开放连接将最终耗用受害者所有的系统资源,受害者将不能再接收任何其他的请求。通常等待ACK返回包有超时限制,所以半开放 。

连接将最终超时,而受害者系统也会自动修复。虽然这样,但是在受害者系统修复之前,攻击者可以很容易的一直发送虚假的SYN请求包来持续

攻击。
在大多数情况下,受害者几乎不能接受任何其他的请求,但是这种攻击不会影响到已经存在的进站或者是出站连接。虽然这样,受害者系统

还是可能耗尽系统资源,以导致其他种种问题。
攻击系统的位置几乎是不可确认的,因为SYN包中的源地址多数都是虚假的。当SYN包到达受害者系统的时候,没有办法找到他的真实地址

,因为在基于源地址的数据包传输中,源ip过滤是唯一可以验证数据包源的方法。

三:什么是SYN cookie?
SYN cookie就是用一个cookie来响应TCP SYN请求的TCP实现,根据上面的描述,在正常的TCP实现中,当S接收到一个SYN数据包,他返回

一个SYN-ACK包来应答,然后进入TCP-SYN-RECV(半开放连接)状态来等待最后返回的ACK包。S用一个数据空间来描述所有未决的连接,

然而这个数据空间的大小是有限的,所以攻击者将塞满这个空间。
在TCP SYN COOKIE的执行过程中,当S接收到一个SYN包的时候,他返回一个SYN-ACK包,这个数据包的ACK序列号是经过加密的,也就

是说,它由源地址,端口源次序,目标地址,目标端口和一个加密种子计算得出。然后S释放所有的状态。如果一个ACK包从C返回,

S将重新计算它来判断它是不是上个SYN-ACK的返回包。如果这样,S就可以直接进入TCP连接状态并打开连接。这样,S就可以

避免守侯半开放连接了。
以上只是SYN COOKIE的基本思路,它在应用过程中仍然有许多技巧。请在前几年的kernel邮件列表查看archive of discussions的相关详细

内容。
4,什么是SYN COOKIE 防火墙
SYN COOKIE 防火墙是SYN cookie的一个扩展,SYN cookie是建立在TCP堆栈上的,他为linux操作系统提供保护。SYN cookie防火墙linux

一大特色,你可以使用一个防火墙来保护你的网络以避免遭受SYN洪水攻击。
下面是SYN cookie防火墙的原理
client firewall server
------ ---------- ------
1. SYN----------- - - - - - - - - - ->
2. <------------SYN-ACK(cookie)
3. ACK----------- - - - - - - - - - ->
4. - - - - - - -SYN--------------->
5. <- - - - - - - - - ------------SYN-ACK
6. - - - - - - -ACK--------------->

7. -----------> relay the ------->
<----------- connection <-------
1:一个SYN包从C发送到S
2:防火墙在这里扮演了S的角色来回应一个带SYN cookie的SYN-ACK包给C
3:C发送ACK包,接着防火墙和C的连接就建立了。
4:防火墙这个时候扮演C的角色发送一个SYN给S
5:S返回一个SYN给C
6:防火墙扮演C发送一个ACK确认包给S,这个时候防火墙和S的连接也就建立了
7:防火墙转发C和S间的数据
如果系统遭受SYN Flood,那么第三步就不会有,而且无论在防火墙还是S都不会收到相应在第一步的SYN包,所以我们就击退了这次SYN洪水攻 击。


http://www.niftyadmin.cn/n/1825855.html

相关文章

自媒体平台(33家)的细分化时代,我们该如何取舍

最近自媒体平台真是层出不穷。先是做下载的迅雷做了迅雷自媒体平台&#xff0c;再是做WIFI万能钥匙的WIFI做了WIFI自媒体&#xff0c;做社区的天涯出了天涯号&#xff0c;今天又发现做O2O市场的点评做了点评头条。 请点击此处输入图片描述 目前写作者面临的局面可谓是尴尬&…

几种不同的NAT方式

几种不同的NAT方式 &#xff11; 背景   目前&#xff0c;&#xff2e;&#xff27;&#xff2e;正逐步从试验走向商用&#xff0c;在此过程中遇到了很多实际问题&#xff0c;特别是&#xff2e;&#xff27;&#xff2e;用户的接入问题。&#xff2e;&#xff27;&#xf…

C#程序出现引用失败的原因

原因之一&#xff1a; 1.目标框架不一致造成的&#xff0c;如程序是.NET Framework 4 Client Profile,引用的类库是 .NET Framework 4 就会造成引用失败&#xff0c;解决方法&#xff1a;类库或程序右键->属性将目标框架改为一致即可 转载于:https://www.cnblogs.com/janfes…

推论统计5

2019独角兽企业重金招聘Python工程师标准>>> 转载于:https://my.oschina.net/Bettyty/blog/810498

mysql 线程等待时间,解决sleep进程过多的办法

如果你没有修改过MySQL的配置&#xff0c;缺省情况下&#xff0c;wait_timeout的初始值是28800。wait_timeout 过大有弊端&#xff0c;其体现就是MySQL里大量的SLEEP进程无法及时释放&#xff0c;拖累系统性能&#xff0c;不过也不能把这个指设置的过小&#xff0c;否则你可能会…

[dp]Luogu P1169 棋盘制作

题目描述 国际象棋是世界上最古老的博弈游戏之一&#xff0c;和中国的围棋、象棋以及日本的将棋同享盛名。据说国际象棋起源于易经的思想&#xff0c;棋盘是一个8*8大小的黑白相间的方阵&#xff0c;对应八八六十四卦&#xff0c;黑白对应阴阳。 而我们的主人公小Q&#xff0c;…

单片机小白学步系列(八) 用面包板搭建实验电路

前面介绍了几种准备实验板的方案。这里先介绍方案一&#xff0c;我将同大家一起搭建一块简易的单片机实验板。一起感受动手实践的乐趣。 我们有两种自己搭建实验板的方案&#xff0c;一是用面包板&#xff0c;二是用万用焊板。本篇我们介绍面包板搭建电路。面包板是一种用于电路…

JavaWeb的json包装以及跨域问题--博客园老牛大讲堂

1、下面内容简介---博客园老牛大讲堂 下面我主要说一下javaweb端怎样利用MVC框架包装json数据。和json数据的跨域问题解决。 这个文章不适用与javaEE初学者&#xff0c;需要一定基础。 2、知识补充&#xff1a;---博客园老牛大讲堂 ①&#xff1a;java分为三种javaEE&#xff0…