第一个包不是SYN包?用科来数据包分析软件排除一次故障。

#第一个包不是SYN包?用科来数据包分析软件排除一次故障。

某金融机构防火墙安全运维人员巡检发现,在互联网区域防火墙不断报送First packet isn’t SYN的日志(见图1),几乎时时刻刻有,影响了防火墙日志存储,但是无业务影响,运维人员觉得比较奇怪,为分析清楚问题,求助于网络抓包人员进行分析。网络抓包人员利用科来数据包分析软件进行分析。
图1 异常现象
图1 异常现象

分析过程

根据日志字面意思,第一个包不是SYN包,我们都知道,TCP三次握手,建立会话过程中,首先建立三次握手(见图2),三次握手第一个包就是SYN包,那这里第一个包不是SYN包,那是什么包呢,抓包人员决定通过部署科来回溯分析系统进行分析。
在这里插入图片描述
图2 三次握手
如图3所示拓扑结构,在防火墙发现有该异常日志,抓包人员决定首先在服务器接入交换机处进行抓包。
在这里插入图片描述
图3 网络拓扑
通过在服务器端抓包分析(图4),定位到防火墙发送First packet isn’t SYN日志时间点对比&#x

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
抓包程序的代码如下: ``` package main import ( "fmt" "log" "net" "github.com/google/gopacket" "github.com/google/gopacket/pcap" "github.com/google/gopacket/layers" ) func main() { // 打开网卡 handle, err := pcap.OpenLive("eth0", 65535, true, pcap.BlockForever) if err != nil { log.Fatal(err) } defer handle.Close() // 设置过滤器 filter := "tcp[tcpflags] & (tcp-syn) != 0" err = handle.SetBPFFilter(filter) if err != nil { log.Fatal(err) } // 抓包 packetSource := gopacket.NewPacketSource(handle, handle.LinkType()) for packet := range packetSource.Packets() { // 解析TCP报文 tcpLayer := packet.Layer(layers.LayerTypeTCP) if tcpLayer != nil { tcp, _ := tcpLayer.(*layers.TCP) // 判断是否是SYN报文 if tcp.SYN { // 向源地址发送RST报文 ipLayer := packet.Layer(layers.LayerTypeIPv4) if ipLayer != nil { ip, _ := ipLayer.(*layers.IPv4) srcAddr := net.IP(ip.SrcIP) dstAddr := net.IP(ip.DstIP) // 构造TCPtcpHeader := layers.TCP{ SrcPort: tcp.DstPort, DstPort: tcp.SrcPort, Seq: tcp.Ack, RST: true, Window: tcp.Window, } tcpHeader.SetNetworkLayerForChecksum(ip) // 构造IP头 ipHeader := layers.IPv4{ Version: 4, SrcIP: ip.DstIP, DstIP: ip.SrcIP, Protocol: layers.IPProtocolTCP, TTL: 64, Id: ip.Id, Flags: ip.Flags, } // 发送RST报文 packetData := gopacket.NewSerializeBuffer() gopacket.SerializeLayers(packetData, gopacket.SerializeOptions{}, &ipHeader, &tcpHeader) packetBytes := packetData.Bytes() conn, err := net.DialIP("ip4:tcp", &net.IPAddr{IP: srcAddr}, &net.IPAddr{IP: dstAddr}) if err != nil { fmt.Println(err) } else { defer conn.Close() _, err := conn.Write(packetBytes) if err != nil { fmt.Println(err) } fmt.Printf("Sent RST to %s\n", srcAddr.String()) } } } } } } ``` 程序的主要逻辑是: 1. 打开网卡,设置过滤器,抓包; 2. 对每一个TCP报文进行判断,如果是SYN报文,就向源地址发送RST报文。 程序使用了Google的开源库gopacket来处理网络。首先打开网卡,设置过滤器,然后使用NewPacketSource函数生成一个PacketSource对象,用来读取网络PacketSource的Packets方法会返回一个管道,每次从管道中读取一个网络,直到管道关闭。 在处理每个网络时,先判断是否TCP层,如果是,再判断是否是SYN报文。如果是SYN报文,就从IPv4层中获取源地址和目的地址,然后构造RST报文并发送到源地址。构造RST报文时,需要先构造TCP头,再构造IPv4头。最后将TCP头和IPv4头序列化成字节流,并通过net的DialIP函数连接到源地址,并发送RST报文。如果发送成功,就打印一条消息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值