linux内核tcp syn seq读取

2024-01-04 05:04
文章标签 linux 读取 tcp 内核 seq syn

本文主要是介绍linux内核tcp syn seq读取,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一 书上讲tcp 连接初始seq是随机取的,这里分析一下流程。

二 代码流程梳理

want_cookie 不在本文讨论范围,洪泛攻击的情况这里就不做分析了。

linux内核通过tcp_conn_request 完成握手动作。

初始syn的seq分为两种情况。

2.1 复用之前的timewait端口连接的最后一次的序列号。

__u32 isn = TCP_SKB_CB(skb)->tcp_tw_isn;

这样在接受连接一端,就会判断seq是符合递增的逻辑的,不会拒绝这次syn请求。

2.2 之前没有过连接的端口

isn = af_ops->init_seq(skb);

.init_seq  =   tcp_v4_init_seq,

分析一下tcp_v4_init_seq 函数。

static u32 tcp_v4_init_seq(const struct sk_buff *skb)

{

    return secure_tcp_seq(ip_hdr(skb)->daddr,

                  ip_hdr(skb)->saddr,

                  tcp_hdr(skb)->dest,

                  tcp_hdr(skb)->source);

}

tcp_v4_init_seq 参数是链接四元组

u32 secure_tcp_seq(__be32 saddr, __be32 daddr,

           __be16 sport, __be16 dport)

{

    u32 hash;

    net_secret_init(); // 获取随机数,用随机数生成密钥,存入net_secret

    hash = siphash_3u32((__force u32)saddr, (__force u32)daddr,

                (__force u32)sport << 16 | (__force u32)dport,

                &net_secret);//全局变量 net_secret 

//通过net_secret 得到一个hash值

    return seq_scale(hash); 

}

static u32 seq_scale(u32 seq)

{

    /*

     *  As close as possible to RFC 793, which

     *  suggests using a 250 kHz clock.

     *  Further reading shows this assumes 2 Mb/s networks.

     *  For 10 Mb/s Ethernet, a 1 MHz clock is appropriate.

     *  For 10 Gb/s Ethernet, a 1 GHz clock should be ok, but

     *  we also need to limit the resolution so that the u32 seq

     *  overlaps less than one time per MSL (2 minutes).

     *  Choosing a clock of 64 ns period is OK. (period of 274 s)

     */

    return seq + (ktime_get_real_ns() >> 6);

}

尽可能接近RFC 793

*建议使用250 kHz时钟。

*进一步的阅读表明,这是假设2 Mb/s的网络。

*对于10 Mb/s以太网,1 MHz时钟是合适的。

*对于10 Gb/s以太网,1 GHz时钟应该可以,但是

*我们还需要限制分辨率,以便u32-seq

*每个MSL重叠少于一次(2分钟)。

*选择64 ns周期的时钟是可以的。(274 s周期)

通过上面的seq_scale 生成最终的随机数seq

这篇关于linux内核tcp syn seq读取的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/568241

相关文章

ubuntu16.04如何部署dify? 在Linux上安装部署Dify的技巧

《ubuntu16.04如何部署dify?在Linux上安装部署Dify的技巧》随着云计算和容器技术的快速发展,Docker已经成为现代软件开发和部署的重要工具之一,Dify作为一款优秀的云原生应用... Dify 是一个基于 docker 的工作流管理工具,旨在简化机器学习和数据科学领域的多步骤工作流。它

SpringBoot快速搭建TCP服务端和客户端全过程

《SpringBoot快速搭建TCP服务端和客户端全过程》:本文主要介绍SpringBoot快速搭建TCP服务端和客户端全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录TCPServerTCPClient总结由于工作需要,研究了SpringBoot搭建TCP通信的过程

Linux高并发场景下的网络参数调优实战指南

《Linux高并发场景下的网络参数调优实战指南》在高并发网络服务场景中,Linux内核的默认网络参数往往无法满足需求,导致性能瓶颈、连接超时甚至服务崩溃,本文基于真实案例分析,从参数解读、问题诊断到优... 目录一、问题背景:当并发连接遇上性能瓶颈1.1 案例环境1.2 初始参数分析二、深度诊断:连接状态与

Linux系统调试之ltrace工具使用与调试过程

《Linux系统调试之ltrace工具使用与调试过程》:本文主要介绍Linux系统调试之ltrace工具使用与调试过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、ltrace 定义与作用二、ltrace 工作原理1. 劫持进程的 PLT/GOT 表2. 重定

Linux区分SSD和机械硬盘的方法总结

《Linux区分SSD和机械硬盘的方法总结》在Linux系统管理中,了解存储设备的类型和特性是至关重要的,不同的存储介质(如固态硬盘SSD和机械硬盘HDD)在性能、可靠性和适用场景上有着显著差异,本文... 目录一、lsblk 命令简介基本用法二、识别磁盘类型的关键参数:ROTA查询 ROTA 参数ROTA

嵌入式Linux之使用设备树驱动GPIO的实现方式

《嵌入式Linux之使用设备树驱动GPIO的实现方式》:本文主要介绍嵌入式Linux之使用设备树驱动GPIO的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、设备树配置1.1 添加 pinctrl 节点1.2 添加 LED 设备节点二、编写驱动程序2.1

嵌入式Linux驱动中的异步通知机制详解

《嵌入式Linux驱动中的异步通知机制详解》:本文主要介绍嵌入式Linux驱动中的异步通知机制,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、异步通知的核心概念1. 什么是异步通知2. 异步通知的关键组件二、异步通知的实现原理三、代码示例分析1. 设备结构

Linux搭建单机MySQL8.0.26版本的操作方法

《Linux搭建单机MySQL8.0.26版本的操作方法》:本文主要介绍Linux搭建单机MySQL8.0.26版本的操作方法,本文通过图文并茂的形式给大家讲解的非常详细,感兴趣的朋友一起看看吧... 目录概述环境信息数据库服务安装步骤下载前置依赖服务下载方式一:进入官网下载,并上传到宿主机中,适合离线环境

windows和Linux使用命令行计算文件的MD5值

《windows和Linux使用命令行计算文件的MD5值》在Windows和Linux系统中,您可以使用命令行(终端或命令提示符)来计算文件的MD5值,文章介绍了在Windows和Linux/macO... 目录在Windows上:在linux或MACOS上:总结在Windows上:可以使用certuti

Linux之systemV共享内存方式

《Linux之systemV共享内存方式》:本文主要介绍Linux之systemV共享内存方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、工作原理二、系统调用接口1、申请共享内存(一)key的获取(二)共享内存的申请2、将共享内存段连接到进程地址空间3、将