码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • [网络篇]TCP SYN Flood Attack(洪范攻击)


    文章目录

    • SYN Flood Attack是什么?
    • SYN Flood Attack的阶段
    • SYN Flood Attack原理
    • SYN Flood Attack的防御措施
      • 具体防御手段:syn cookie

    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队列会添加一个队列内容(全连接)。

  • 相关阅读:
    迅为iTOP-iMX6Q&PLUS-Android6.0下uboot添加网卡驱动
    一个完整的程序化交易系统包含了哪些因素?
    数据挖掘(1)概述
    Cloudflare CDN(泛播)支持转发的网络端口
    windows共享文件夹,免密访问
    网络地址转换技术NAT(第九课)
    ACU-01B 3HNA024871-001/03 机器人将如何改变世界
    找不到d3dx9_43.dll如何修复?d3dx9_43.dll丢失的解决办法分享
    java项目开发经验总结
    qt QMutex 判断对象是否已经锁的状态
  • 原文地址:https://blog.csdn.net/weixin_42857472/article/details/127957171
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号