• [网络篇]TCP SYN Flood Attack(洪范攻击)


    SYN Flood Attack是什么?

    SYN Flood Attack是属于Dos(Denial of service)攻击,也就是拒绝服务。简单来说就是只要把服务器搞崩掉。使得服务器无法提供服务。

    SYN Flood Attack的阶段

    发生在TCP三次握手过程中

    SYN Flood Attack原理

    正常三次握手的流程:
    第一次握手:客户端发送SYN给服务器(服务器建立半连接)
    第二次握手:服务器SYN+ACK回复给客户端
    第三次握手:客户端ACK给服务器(服务器建立全连接)

    SYN Flood Attack下的握手流程:
    第一次握手:客户端发送SYN给服务器(服务器建立半连接)
    第二次握手:服务器SYN+ACK回复给客户端
    第三次握手:客户端不回复ACK给服务器

    也就是第三次握手无法完成。
    那么第三次握手无法完成会给服务器带来什么危害呢?
    答案是消耗资源。

    正常情况下,如果客户端在发送SYN之后掉电或者掉线。那么服务器在回复SYN+ACK之后没有等到ACK会选择重发,在等待一分钟左右之后会选择丢弃连接。
    但是这种只是属于单个连接异常,假如客户端很多,或者单个客户端去模拟这种异常情况,不断的伪造新端口去建立连接,但是就是不ACK给服务器。那么服务器会为每个SYN分配资源直至消耗殆尽,服务崩溃。

    SYN Flood Attack的防御措施

    如果不想让服务器崩溃,做法是不为客户端的每个SYN分配资源。而是为每个客户端的ACK分配资源,前提是ACK是合理的。

    具体防御手段:syn cookie

    原理:在服务器收到SYN包之后不马上分配资源,会先计算出一个cookie值,并携带在SYN+ACK报文段的序号中,而客户端会根据序号+1作为确认号来ACK回复给服务器。服务器收到之后对确认号-1,若和发送出去的cookie值一致,则认为该连接有效,分配资源并建立全连接

    科普:
    半连接,为SYN队列
    全连接,为accepet 队列
    可以了理解为两个缓存。
    客户端每次发送一个SYN,那么服务器的SYN队列就会添加一个队列内容(半连接),
    服务器发送SYN+ACK给客户端,并且客户端回复ACK给服务器之后,那么SYN队列出队一个SYN,Accepet队列会添加一个队列内容(全连接)。

  • 相关阅读:
    C Primer Plus(6) 中文版 第8章 字符输入/输出和输入验证 8.3 结束键盘输入
    HTTP 头部- Origin Referer
    电脑怎么设置开机密码?简单几步给你的电脑“上锁”
    【每日一题】实现 Trie (前缀树)
    Springboot+druid
    LabVIEW和MES系统的智能化车间数据对接
    Synopsys ICC学习(1)
    c++之旅第七弹——继承
    第一章 计算机系统概述
    vue3的7种路由守卫使用大全
  • 原文地址:https://blog.csdn.net/weixin_42857472/article/details/127957171