25.1 tcp三次握手及tcp连接状态(含tcpdum抓包分析)

25.2 tcp四次挥手及tcp连接状态

25.3 实战:在局域网中使用 awl伪装MAC地址进行多线程SYN攻击

ssh 客户端: xuegod63 192.168.1.63

sshd服务端: xuegod64 192.168.1.64

本节所使用实验环境:RHEL 7 (如有使用RHEL 6,会特别注明)

5.1 tcp三次握手及tcp连接状态(含tcpdum抓包分析)

25.1.1 TCP报文段的首部格式:

需要了解的信息:

ACK : TCP协议规定,只有ACK=1时有效,也规定连接建立后所有发送的报文的ACK必须为1

SYN(SYNchronization) : 在连接建立时用来同步序号。当SYN=1而ACK=0时,表明这是一个连接请求报文。对方若同意建立连接,则应在响应报文中使SYN=1和ACK=1. 因此, SYN置1就表示这是一个连接请求或连接接受报文。

synchronization [?s??kr?na?’ze??n] 同步

FIN (finis)即完,终结的意思, 用来释放一个连接。当 FIN = 1 时,表明此报文段的发送方的数据已经发送完毕,并要求释放连接。

finis ['fa?n?s] 终结

建立tcp连接时的tcp三次握手和断开tcp连接时的4次挥手整体过程

25.1.2 实战:使用tcpdump抓取tcp三次握手

tcp三次握手过程:

Client:我可以给你发数据吗?

Server:可以

Client:好的

tcp三次握手过程:

1、首先由Client发出请求连接即 SYN=1,声明自己的序号是 seq=x

2、然后Server 进行回复确认,即 SYN=1 ,声明自己的序号是 seq=y, 并设置为ack=x+1,

3、最后Client 再进行一次确认,设置 ack=y+1.

seq 序列号范围:2^32 -1 到最大值,再从0开始

seq 序列号作用:依据这个序列号来组数据

实战1:使用tcpdump抓包查看tcp三次握手过程

tcpdump

常用参数:

-c 指定包个数

-n IP,端口用数字方式显示(不把IP解析成域名)

port 指定端口

在xuegod63上登录,抓取ssh远程产生的tcp三次握手包:

[root@xuegod63 ~]# tcpdump port 22 -c 3 -n -i ens33

打开另一个终端,开始建立tcp连接:

[root@xuegod63 Desktop]# ssh root@192.168.1.64

The authenticity of host ‘192.168.1.64 (192.168.1.64)’ can’t be established.

RSA key fingerprint is b2:29:c8:62:98:80:92:3c:e2:67:3f:f0:7c:40:69:63.

Are you sure you want to continue connecting (yes/no)? #到这里就不用执行了,tcp已经建议连接

查看数据包:

[root@xuegod63 ~]# tcpdump -i eth0 -vn -t tcp port 22

tcpdump: listening on eth0, link-type EN10MB (Ethernet), capture size 65535 bytes

IP (tos 0x10, ttl 64, id 1908, offset 0, flags [DF], proto TCP (6), length 60)

192.168.1.63.57521 > 192.168.1.64.ssh: Flags [S], cksum 0x4730 (correct), seq 3666297820, win 14600, options [mss 1460,sackOK,TS val 2245802 ecr 0,nop,wscale 7], length 0

IP (tos 0x0, ttl 64, id 0, offset 0, flags [DF], proto TCP (6), length 60)

192.168.1.64.ssh > 192.168.1.63.57521: Flags [S.], cksum 0x3ee0 (correct), seq 1491746863, ack 3666297821, win 14480, options [mss 1460,sackOK,TS val 1011598 ecr 2245802,nop,wscale 7], length 0

IP (tos 0x10, ttl 64, id 1909, offset 0, flags [DF], proto TCP (6), length 52)

192.168.1.63.57521 > 192.168.1.64.ssh: Flags [.], cksum 0xa5c8 (correct), ack 1, win 115, options [nop,nop,TS val 2245803 ecr 1011598], length 0

注:Flags [S] 中的 S 表示为SYN包为1

为什么最后一个ack为1 不是为y+1 ?

client主机返回ACK,包序号为ack=1 ,这是相对序号(相对于原来的加1),如果需要看绝对序号,可以在tcpdump命令中加-S

[root@xuegod63 ~]# tcpdump port 22 -c 3 -n -S

tcpdump: verbose output suppressed, use -v or -vv for full protocol decode

listening on eth0, link-type EN10MB (Ethernet), capture size 65535 bytes

16:00:54.310316 IP 192.168.1.63.57528 > 192.168.1.64.ssh: Flags [S], seq 1932774705, win 14600, options [mss 1460,sackOK,TS val 5103659 ecr 0,nop,wscale 7], length 0

16:00:54.311072 IP 192.168.1.64.ssh > 192.168.1.63.57528: Flags [S.], seq 3006844046, ack 1932774706, win 14480, options [mss 1460,sackOK,TS val 3869455 ecr 5103659,nop,wscale 7], length 0

16:00:54.311175 IP 192.168.1.63.57528 > 192.168.1.64.ssh: Flags [.], ack 3006844047, win 115, options [nop,nop,TS val 5103660 ecr 3869455], length 0

3 packets captured

3 packets received by filter

0 packets dropped by kernel

25.2 tcp四次挥手及tcp连接状态

25.2.1 实战:tcp断开连接时的 4次挥手过程

4次挥手过程:

1、当客户A 没有东西要发送时就要释放 A 这边的连接,A会发送一个报文(没有数据),其中 FIN 设置为1, seq=u;

2、 服务器B收到后会给应用程序一个信,这时A那边的连接已经关闭,即A不再发送信息(但仍可接收信息)。 B会发送收一个报文,其中 FIN 设置为1, ack=u+1; A收到B的确认包后,进入等待状态,等待B请求释放连接。

3、服务器B向客户A发送断开连接请求,包中FIN=1,seq=w, ack = u+1

4、A收到后回复一个确认信息,发送包,ack=w+1,并进入 TIME_WAIT 状态

25.2.2 实战: 使用tcpdum抓取4次挥手数据包

在xuegod63上登录,抓取ssh远程连接断开时,产生的tcp 4次挥手包:

[root@xuegod63 ~]# tcpdump port 22 -n -S

打开另一个终端,开始建立tcp连接:

[root@xuegod63 ~]# ssh root@192.168.1.64

root@192.168.1.64’s password:

Last login: Tue Oct 25 17:28:57 2016 from 192.168.1.63

[root@xuegod64 ~]# exit

查看数据包:

[root@xuegod63 ~]# tcpdump port 22 -n -S

。。。 #只看最后4个包就可以了

17:29:31.709503 IP 192.168.1.63.57533 > 192.168.1.64.ssh: Flags [F.], seq 2176876951, ack 247624733, win 164, options [nop,nop,TS val 10421058 ecr 9186853], length 0

17:29:31.710515 IP 192.168.1.64.ssh > 192.168.1.63.57533: Flags [.], ack 2176876952, win 175, options [nop,nop,TS val 9186854 ecr 10421058], length 0

17:29:31.743381 IP 192.168.1.64.ssh > 192.168.1.63.57533: Flags [F.], seq 247624733, ack 2176876952, win 175, options [nop,nop,TS val 9186858 ecr 10421058], length 0

17:29:31.743433 IP 192.168.1.63.57533 > 192.168.1.64.ssh: Flags [.], ack 247624734, win 164, options [nop,nop,TS val 10421092 ecr 9186858], length 0

为什么第二次和第四次没有seq序列号?

因为已经要断开了,没有必要产生新的序列号。

总结:4次挥手

a 我没有数据要传输了,我要断了 -》 b 好 ; b 数据传输完,我也要断了 -》 a 好

25.2.3 TCP连接状态详解:

TCP连接状态详解:

服务器端:LISTEN:侦听来自远方的TCP端口的连接请求

客户端:SYN-SENT:在发送请求连接后等待匹配的连接请求

服务器端:SYN-RECEIVED:再收到和发送一个连接请求后等待对方对连接请求的确认

客户端/服务器端:ESTABLISHED:代表一个打开的连接

客户端:FIN-WAIT-1:等待远程TCP连接中断请求,或先前的连接中断请求的确认

服务器端:CLOSE-WAIT:等待从本地用户发来的连接中断请求

客户端:FIN-WAIT-2:从远程TCP等待连接中断请求

服务器端:LAST-ACK:等待原来的发向远程TCP的连接中断请求的确认

客户端:TIME-WAIT:等待足够的时间以确保远程TCP接收到连接中断请求的确认

服务器端:CLOSED:没有任何连接状态

25.3 实战:在局域网中使用 awl伪装MAC地址进行多线程SYN攻击

25.3.1 SYN洪水攻击概述:

SYN洪水攻击主要源于: tcp协议的三次握手机制

tcp协议面向链接的协议:

正常的TCP三次握手过程:

实战拓扑图:

SYN洪水攻击的过程:

在服务端返回一个确认的SYN-ACK包的时候有个潜在的弊端,如果发起的客户是一个不存在的客户端,那么服务端就不会接到客户端回应的ACK包。

这时服务端需要耗费一定的数量的系统内存来等待这个未决的连接,直到等待超关闭,才能释放内存。

如果恶意者通过ip欺骗,发送大量SYN包给受害者系统,导致服务端存在大量未解决连接并占用大量内存和tcp连接,从而导致正常客户端无法访问服务端,这就是SYN洪水攻击的过程。

25.3.2 实战:使用awl伪装MAC对内网的服务器施实syn洪水攻击

实战拓扑图:

1、在xuegod63 awl软件进行攻击:

下载地址:https://gitlab.com/davical-project/awl/tags

通过xshell上传awl-0.2.tar.gz到Linux系统中

2、开始安装awl 0.56 0.53 不能用

[root@xuegod63 ~]#tar zxvf awl-0.2.tar.gz #解压

[root@xuegod63 ~]#cd awl-0.2

[root@xuegod63 awl-0.2]#./configure # 查检软件包安装环境

[root@xuegod63 awl-0.2]#make -j 4

#make 把源代码编译成可执行的二进制文件

-j 4以4个进程同时编译,速度快

[root@xuegod63 awl-0.2]#make install #安装

3、查看安装的命令:

[root@xuegod63 awl-0.2]# which awl

/usr/local/bin/awl

在xuegod64上搭建一台web服务器,模拟要被攻击的服务器

[root@xuegod64 ~]# yum install httpd -y #安装web服务器

[root@xuegod64 ~]# systemctl start httpd

4、开始攻击:

实战: 在局域网中使用 awl伪装MAC地址进行多线程SYN攻击

获取对方的IP地址解析成MAC地址

[root@xuegod63 ~]# ping 192.168.1.64

[root@xuegod63 ~]# arp -n

Address HWtype HWaddress Flags Mask Iface

192.168.1.17 ether e0:b9:a5:ac:c5:76 C eth0

192.168.1.64 ether 00:0c:29:48:80:95 C ens33

开始攻击:

awl参数如下:

-i 发送包的接口,如果省略默认是ens33

-m 指定目标mac地址 注:如果-m没有指定mac,默认目标MAC地址是“FF.FF.FF.FF.FF.FF”,这表示向同一网段内的所有主机,进行SYN攻击,1-2分钟内,还容易使整个局域网瘫痪。

-d 被攻击机器的IP

-p 被攻击机器的端口

[root@xuegod63 ~]# awl -i ens33 -m 00:0c:29:48:80:95 -d 192.168.1.64 -p 80

测试攻击效果:

在xuegod64上查看:发现很多伪装成公网的IP在攻击我们

总结:

25.1 tcp三次握手及tcp连接状态

25.2 tcp四次挥手及tcp连接状态

25.3 实战:在局域网中使用 awl伪装MAC地址进行多线程SYN攻击

云架构Linux运维,【Linux云计算架构:第三阶段-Linux高级运维...相关推荐

  1. 天成之作,踏云而来——“天成云”升级发布,领航企业云计算发展第三阶段

    经过一场疫情洗礼,企业的数字化战略从未向今天这样迫切.而作为数字化业务的基石,云计算也在十余年高速狂奔后,站上了一个新的发展时点. 当前,各行各业用户面对的,是一个多技术架构并存.部署模式混合化.多家 ...

  2. 第三阶段.Linux+arm

    一.树莓派开发 1.刷机 2.登录树莓派 3.分文件编程 a.分模块的编程思想 b.方便调试 c.主程序简洁 注:其他文件的功能函数需要在.h文件中声明,并且主程序文件包含此.h的头文件 头文件&qu ...

  3. 【Linux云计算架构:第三阶段-Linux高级运维架构】第13章——redis

    本节内容: 13.1 redis概述 13.2 安装redis 13.3 redis基本操作 13.4 redis持久化 13.5 redis主从架构(实现读写分离) 13.6 使用sentinel实 ...

  4. 【Linux云计算架构:第三阶段-Linux高级运维架构】第25章—— 搭建jumperserver管理王者荣耀数万台游戏服务器

    本节内容: 34.1 Jumpserver堡垒机概述-部署Jumpserver运行环境 34.2 安装Coco组件 34.3 安装Web-Terminal前端-Luna组件-配置Nginx整合各组件 ...

  5. 【Linux云计算架构:第三阶段-Linux高级运维架构】第19章——安装Kali黑客操作系统-利用ettercap实施中间人攻击

    内容: 19.1 安装Kali黑客操作系统及相关实战 19.2 实战:linux之kali系统ssh服务开启 19.3 实战: kali下的nmap扫描工具 19.4 MITM中间人攻击理论 19.5 ...

  6. 【Linux云计算架构:第三阶段-Linux高级运维架构】第26章——tcp三次握手四次挥手及在局域网中使用 awl伪装MAC地址进行多线程SYN攻击

    25.1 tcp三次握手及tcp连接状态(含tcpdum抓包分析) 25.2 tcp四次挥手及tcp连接状态 25.3 实战:在局域网中使用 awl伪装MAC地址进行多线程SYN攻击 ssh 客户端: ...

  7. linux mv 保持目录结构_(三)Linux系统目录结构

    点击蓝字 关注我们 Linux系统目录结构: 所有的类Unix系统根分区下的文件系统都基本一致.分别介绍一下功能:/bin:所有常用的可执行的二进制文件,就是"命令",这些命令是所 ...

  8. linux 嵌入式 交叉 环境搭建 实验原理,实验三 嵌入式Linux开发环境的搭建

    南京邮电大学通达学院 实 验 报 告 实验 实验三题目 嵌入式Linux开发环境的搭建 课程名称 嵌入式驱动开发实验 学院 专业 班 实验者学号同做者学号 08002210 姓名 毛骏超 同做者学号 ...

  9. linux运行c语言实验总结,实验三:LINUX 下C语言使用、编译与调试实验

    一.目的: 1. 练习并掌握Linux提供的vi编辑器来编译C程序 2. 学会利用gcc.gdb编译.调试C程序 3. 学会使用make工具 二.内容 1. 编写C语言程序,用gcc编译并观察编译后的 ...

最新文章

  1. android 定时换图片,android 视频和图片切换并进行自动轮播
  2. 50颗传感器、超1亿像素,算力700TOPS,这个自动驾驶平台有点儿炫!
  3. NSMutableString和NSString区别,及相互转换方法
  4. 过程控制系统模拟信号标准
  5. tableau必知必会之如何将 Tableau Server 从 Windows 迁移到 Linux 的方法
  6. 「mysql优化专题」90%程序员面试都用得上的索引优化手册(5)【面试重点】
  7. art-template在项目中的应用
  8. java 怎么输出地址,Java中char[]输出不是内存地址的原因详解
  9. 深度学习框架TensorFlow(1.安装和简介)
  10. LuoguP2292 L语言
  11. Android网络编程http派/申请服务
  12. linux下基于Posix message queue的同步消息队列的实现
  13. 2021-11-21 使用for循环打印出大写字母ascll码对照表。
  14. lordPE 破除只显示60个进程限制 win10下可运行
  15. android 办公桌面壁纸,android系统励志的壁纸欣赏
  16. 彻底清除微软拼音输入法
  17. Excel VBA一行代码搞定分组排序
  18. 硬件设计——关于电路设计的一些知识
  19. OpenJudge[计算邮资]之满分代码
  20. HDU 3518 HDU 4416【后缀自动机len的使用】

热门文章

  1. 如何获取easyclick手机安装包
  2. mysql误删数据恢复操作
  3. 原理图端口符号_200 一步步开始学习制作PCBamp;PCBA--绘制原理图
  4. domian shift
  5. 相比传统监控,智慧门店的摄像机有多“能干”
  6. MySQL B+树如何实现联合索引
  7. 人机交互及用户体验、GUI思考
  8. Android平台美颜相机/Camera实时滤镜/视频编解码/影像后期/人脸技术探索——1.1 工程思路与难点
  9. 用于地址解析的协议是服务器,用于解析域名的协议是什么?
  10. c语言编程统计学生个数,c编程统计并显示500至800之间所有素数的总个数以及总和...