TCP连接建立之后的SACK选项解析

2023-12-19 09:48

本文主要是介绍TCP连接建立之后的SACK选项解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这几天有点犯糊涂,搞不清楚连接建立之后,SACK选项的解析在什么地方处理。内核中唯一能解析SACK选项的函数就是tcp_parse_options,但是就找不到tcp_rcv_established函数在哪里调用它。这里犯了一个错误,一直以为tcp_validate_incoming函数仅是验证报文,其中的tcp_fast_parse_options只是快速解析timestamps选项。

static bool tcp_validate_incoming(struct sock *sk, struct sk_buff *skb,const struct tcphdr *th, int syn_inerr)
{struct tcp_sock *tp = tcp_sk(sk);bool rst_seq_match = false;/* RFC1323: H1. Apply PAWS check first. */if (tcp_fast_parse_options(sock_net(sk), skb, th, tp) &&tp->rx_opt.saw_tstamp &&tcp_paws_discard(sk, skb)) {if (!th->rst) {NET_INC_STATS(sock_net(sk), LINUX_MIB_PAWSESTABREJECTED);if (!tcp_oow_rate_limited(sock_net(sk), skb,LINUX_MIB_TCPACKSKIPPEDPAWS,&tp->last_oow_ack_time))tcp_send_dupack(sk, skb);goto discard;}/* Reset is accepted even if it did not pass PAWS. */

然而,在tcp_fast_parse_options函数的处理中,如果报文存在SACK选项数据,timestamps选项的快速解析必然失败。快速解析是建立在TCP选项数据中仅有timestamps一个选项的基础上的。当有SACK选项时,必须执行后面的正常选项解析函数tcp_parse_options,其将解析所有的选项数据,包括SACK选项。

static bool tcp_fast_parse_options(const struct net *net,const struct sk_buff *skb, const struct tcphdr *th, struct tcp_sock *tp)
{/* In the spirit of fast parsing, compare doff directly to constant* values.  Because equality is used, short doff can be ignored here.*/if (th->doff == (sizeof(*th) / 4)) {tp->rx_opt.saw_tstamp = 0;return false;} else if (tp->rx_opt.tstamp_ok &&th->doff == ((sizeof(*th) + TCPOLEN_TSTAMP_ALIGNED) / 4)) {if (tcp_parse_aligned_timestamp(tp, th))return true;}tcp_parse_options(net, skb, &tp->rx_opt, 1, NULL);if (tp->rx_opt.saw_tstamp && tp->rx_opt.rcv_tsecr)tp->rx_opt.rcv_tsecr -= tp->tsoffset;return true;

内核版本 5.0

这篇关于TCP连接建立之后的SACK选项解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

java如何通过Kerberos认证方式连接hive

《java如何通过Kerberos认证方式连接hive》该文主要介绍了如何在数据源管理功能中适配不同数据源(如MySQL、PostgreSQL和Hive),特别是如何在SpringBoot3框架下通过... 目录Java实现Kerberos认证主要方法依赖示例续期连接hive遇到的问题分析解决方式扩展思考总

C语言中自动与强制转换全解析

《C语言中自动与强制转换全解析》在编写C程序时,类型转换是确保数据正确性和一致性的关键环节,无论是隐式转换还是显式转换,都各有特点和应用场景,本文将详细探讨C语言中的类型转换机制,帮助您更好地理解并在... 目录类型转换的重要性自动类型转换(隐式转换)强制类型转换(显式转换)常见错误与注意事项总结与建议类型

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查

在Rust中要用Struct和Enum组织数据的原因解析

《在Rust中要用Struct和Enum组织数据的原因解析》在Rust中,Struct和Enum是组织数据的核心工具,Struct用于将相关字段封装为单一实体,便于管理和扩展,Enum用于明确定义所有... 目录为什么在Rust中要用Struct和Enum组织数据?一、使用struct组织数据:将相关字段绑

使用Java实现一个解析CURL脚本小工具

《使用Java实现一个解析CURL脚本小工具》文章介绍了如何使用Java实现一个解析CURL脚本的工具,该工具可以将CURL脚本中的Header解析为KVMap结构,获取URL路径、请求类型,解析UR... 目录使用示例实现原理具体实现CurlParserUtilCurlEntityICurlHandler

Python中连接不同数据库的方法总结

《Python中连接不同数据库的方法总结》在数据驱动的现代应用开发中,Python凭借其丰富的库和强大的生态系统,成为连接各种数据库的理想编程语言,下面我们就来看看如何使用Python实现连接常用的几... 目录一、连接mysql数据库二、连接PostgreSQL数据库三、连接SQLite数据库四、连接Mo

oracle如何连接登陆SYS账号

《oracle如何连接登陆SYS账号》在Navicat12中连接Oracle11g的SYS用户时,如果设置了新密码但连接失败,可能是因为需要以SYSDBA或SYSOPER角色连接,解决方法是确保在连接... 目录oracle连接登陆NmOtMSYS账号工具问题解决SYS用户总结oracle连接登陆SYS账号

深入解析Spring TransactionTemplate 高级用法(示例代码)

《深入解析SpringTransactionTemplate高级用法(示例代码)》TransactionTemplate是Spring框架中一个强大的工具,它允许开发者以编程方式控制事务,通过... 目录1. TransactionTemplate 的核心概念2. 核心接口和类3. TransactionT