1 什么是SYN Flood攻击

  在TCP三次握手时,服务器接收客户端的SYN请求,操作系统将为该请求分配一个TCP(Transmission Control Block),服务器返回一个SYN/ACK请求,并将处于SYN_RCVD状态(半开连接状态)。

  从以上过程可以看到,如果恶意的向某个服务器端口发送大量的SYN包,则可以使服务器打开大量的半开连接,分配TCB,从而消耗大量的服务器资源,同时也使得正常的连接请求无法被相应。而攻击发起方的资源消耗相比较可忽略不计。

  SYN Flood是当前最流行的DoS(拒绝服务攻击)与DDoS(分布式拒绝服务攻击)的方式之一。

2 怎样发现自己处于被攻击状态

  (1)服务端无法提供正常的TCP服务。连接请求被拒绝或超时;

  (2)通过 netstat -an 命令检查系统,发现有大量的SYN_RECV连接状态。  

3 防御措施

  (1)使用TCP Wrapper,服务端只处理有限来源IP的TCP连接请求,其它未指定来源的连接请求一概拒绝。

  (2)缩短SYN Timeout时间,由于SYN Flood攻击的效果取决于服务器上保持的SYN半连接数,这个值=SYN攻击的频度 x  SYN Timeout,所以通过缩短从接收到SYN报文到确定这个报文无效并丢弃改连接的时间,例如设置为20秒以下(过低的SYN Timeout设置可能会影响客户的正常访问),可以成倍的降低服务器的负荷。

  (3)设置SYN Cookie,就是给每一个请求连接的IP地址分配一个Cookie,如果短时间内连续受到某个IP的重复SYN报文,就认定是受到了攻击,以后从这个IP地址来的包会被一概丢弃。

  (4)使用SYN Proxy防火墙

      Syn Cache技术和Syn Cookie技术总的来说是一种主机保护技术,需要系统的TCP/IP协议栈的支持,而目前并非所有的操作系统支持这些技术。因此很多防火墙中都提供一种 SYN代理的功能,其主要原理是对试图穿越的SYN请求进行验证后才放行,下图描述了这种过程:

从上图(左图)中可以看出,防火墙在确认了连接的有效性后,才向内部的服务器(Listener)发起SYN请求,在右图中,所有的无效连接均无法到达内 部的服务器。而防火墙采用的验证连接有效性的方法则可以是Syn Cookie或Syn Flood等其他技术。
采用这种方式进行防范需要注意的一点就是防火墙需要对整个有效连接的过程发生的数据包进行代理,如下图所示:

因为防火墙代替发出的SYN ACK包中使用的序列号为c,而服务器真正的回应包中序列号为c’,这其中有一个差值|c-c’|,在每个相关数据报文经过防火墙的时候进行序列号的修改。

SYN Flood应如何应对相关推荐

  1. 如何应対syn flood

    syn flood的原理就不介绍了 主要总结一下解决方法: 防火墙禁IP 内核参数的调优 Linux内核参数调优主要有下面三个: 增大tcp_max_syn_backlog 减小tcp_synack_ ...

  2. 网络(13)-SYN flood及其应对方法

    什么是SYN flood 攻击者伪装大量的IP地址给服务器发送SYN报文,由于伪造的IP地址几乎不可能存在,也就几乎没有设备会给服务器返回任何应答了.因此,服务器将会维持一个庞大的等待列表,不停地重试 ...

  3. SYN Flood攻击防范技术白皮书

    SYN Flood攻击防范技术白皮书 关键词:SYN Flood ,SYN Cookie,Safe Reset 摘    要:本文主要介绍了H3C防火墙为保护服务器免受SYN Flood攻击采用的防范 ...

  4. 重学TCP协议(10)SYN flood 攻击

    1.SYN flood 攻击 SYN Flood(半开放攻击)是一种拒绝服务(DDoS)攻击,其目的是通过消耗所有可用的服务器资源使服务器不可用于合法流量.通过重复发送初始连接请求(SYN)数据包,攻 ...

  5. TCP洪水攻击(SYN Flood)的诊断和处理

    TCP洪水攻击(SYN Flood)的诊断和处理 SYN Flood介绍 前段时间网站被攻击多次,其中最猛烈的就是TCP洪水攻击,即SYN Flood. SYN Flood是当前最流行的DoS(拒绝服 ...

  6. 当遭遇TCP洪水(SYN Flood)后的的诊断思路和处理过程

    转载来源 :当遭遇TCP洪水(SYN Flood)后的的诊断思路和处理过程 : http://www.safebase.cn/article-258753-1.html 摘要: SYN Flood介绍 ...

  7. syn flood攻击原理及防范

    sync攻击原理 DoS是Denial of Service的简称,即拒绝服务,造成DoS的攻击行为被称为DoS攻击,其目的是使计算机或网络无法提供正常的服务.最常见的DoS攻击有计算机网络带宽攻击和 ...

  8. 什么是SYN Flood?

    一.SYN Flood的概念 SYN Flood是一种广为人知的DoS(拒绝服务攻击)是DDoS(分散式拒绝服务攻击)的方式之一,这是一种利用TCP协定缺陷,传送大量伪造的TCP连线请求,从而使得被攻 ...

  9. TCP协议中的核心知识点,SYN Flood?ISN?滑动窗口?数据重传?拆包粘包?单tcp连接多请求?拥塞管理?(个人收藏学习笔记)

    TCP协议中的核心知识点,滑动窗口?数据重传?拆包粘包?单tcp连接多请求? 1.前言 2.TCP/IP四层结构 3. TCP 3.1 TCP 协议头 3.2 TCP通信过程 3.2.1 建立连接的三 ...

  10. Q2# ZK SYN Flood与参数优化

    引言 Zookeeper集群部分节点连接数量瞬时跌零,导致不少服务发生重连,对业务造成了影响(惊吓),本文就发生的现象进行分析和整理. 一.ZK监控情况 zk集群部分节点服务发生重连 伴随着集群CPU ...

最新文章

  1. 编程人员需知的Windows平台编程的环境设置技巧
  2. Web 服务器 之 安装 Apache 2 和 Tomcat 5.5
  3. java中的集合_Java中集合中的基本概念
  4. QShell下的进程和ILE中的Job
  5. java窗体线条切换消失_java – 如何更改apache poi生成的图表不使用平滑线条并将空单元格显示为间隙?...
  6. 开源阅读书源_安卓神器 | 开源小说软件阅读3.0,附赠大量书源
  7. windows7+fedora16双系统安装
  8. 基于MATLAB车牌识别算法实现 GUI界面
  9. python读取多张图片_Python批量导出多个PPT/PPTX文件中每个幻灯片为独立JPG图片
  10. SVLsimulator与apollo6.0联合仿真
  11. windows10系统如何安装日语输入法
  12. 会议记录管理系统(1)
  13. 打开EXCEL运行脚本,报无法运行宏问题
  14. DQN笔记:高估问题 target network Double DQN
  15. 第三代测序技术在微生物研究中的应用
  16. MATLAB基础应用精讲-【基础知识篇】MATLAB中的标点符号
  17. 软件项目管理——人力资源管理
  18. html中头向下的箭头怎么打出来,向下的箭头怎么打,最简单实用的电脑知识
  19. redis缓存穿透和缓存雪崩的浅析以及解决方案
  20. Rot加密and逆序函数(废话版)

热门文章

  1. js navigator platform
  2. Kongzue的APP拍照相册选择工具
  3. RedHat下通过Rdesktop连接window远程桌面
  4. Asp.net 构建可扩展的的Comet Web 应用(一)
  5. 《MATLAB图像处理375例》——1.3 MATLAB概述
  6. UVALive 5135 Mining Your Own Business 双连通分量
  7. 13.Linux/Unix 系统编程手册(上) -- 文件IO缓冲
  8. 循序渐进之Spring AOP(4) - Introduction
  9. 前端面试宝典(4)——必掌握
  10. C# 匿名对象(匿名类型)、var、动态类型 dynamic