首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux 内核 TCP MSS 机制详细分析

所以本文将通过Linux内核源码对TCP的MSS机制进行详细分析。 测试环境 1....generic-dbgsym $ ls /usr/lib/debug/boot/vmlinux-4.15.0-20-generic 关闭内核地址随机化(KALSR): # 内核是通过grup启动的,所以在grup配置文件中...攻击机器 自己日常使用的Linux设备就好了 地址:192.168.11.111 日常习惯使用Python的,需要装个scapy构造自定义TCP包 自定义SYN的MSS选项 有三种方法可以设置TCP SYN...靶机接收到请求后,首先计算出tcp_header_len,默认等于20字节,在内核配置sysctl_tcp_timestamps开启的情况下,增加12字节,如果编译内核的时候选择了CONFIG_TCP_MD5SIG...随后我对Linux 2.6.29至今的内核进行审计,mss_now的计算公式都一样,tcp_header_len长度也只会加上时间戳的12字节和md5值的18字节。

1.8K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Linux 内核 TCP MSS 机制详细分析

    前言 上周Linux内核修复了4个CVE漏洞[1],其中的CVE-2019-11477感觉是一个很厉害的Dos漏洞,不过因为有其他事打断,所以进展的速度比较慢,这期间网上已经有相关的分析文章了。...所以本文将通过Linux内核源码对TCP的MSS机制进行详细分析。...generic-dbgsym $ ls /usr/lib/debug/boot/vmlinux-4.15.0-20-generic 关闭内核地址随机化(KALSR): # 内核是通过grup启动的,所以在grup配置文件中...靶机接收到请求后,首先计算出tcp_header_len,默认等于20字节,在内核配置sysctl_tcp_timestamps开启的情况下,增加12字节,如果编译内核的时候选择了CONFIG_TCP_MD5SIG...随后我对Linux 2.6.29至今的内核进行审计,mss_now的计算公式都一样,tcp_header_len长度也只会加上时间戳的12字节和md5值的18字节。

    1.8K20

    learning:tcp mss clamp

    MSS选项修改:系统收到建立TCP连接的SYN报文时会检查设备上是否配置MSS选项值,如果配置则检查SYN报文是否携带MSS选项,如果携带则与设备上配置MSS选项进行对比,如果报文携带的MSS选项值大于设备上配置的值则修改报文携带的...MSS选项值为设备上配置MSS选项值,如果小于则不修改报文携带的MSS选项值。...MSS选项插入:系统收到建立TCP连接的SYN报文时会检查该流是否有配置MSS选项,如果配置则检查SYN报文是否携带MSS选项,如果报文未携带MSS选项则增加用户配置MSS选项值到报文字段中。...# 在HTS实例视图下配置TCP报文MSS值为1000。...2、MSS配置支持单方向设置,但是只能生效一个方向,需要注意。

    1.9K42

    细说TCP的MSS选项(2)

    在上一篇细说TCP的MSS选项(1)中给出的了影响MSS的因素:一般都是由出口路由的MTU决定。但这只是TCP的syn报文的情况,今天就要分析syn+ack报文中的MSS的情况。...从这个测试结果看,syn+ack报文的MSS值还要受到syn报文的MSS值影响,可能会取本地计算结果的MSS值和syn报文中的MSS值中的较小值。...tcp_mss_clamp用于获得syn+ack报文的mss值。 ? 而tcp_mss_clamp仅是使用user_mss(该TCP套接字配置MSS选项)与抽口dst的MSS进行对比。...只有设置了user_mss,且其值又小于dst的MSS时,才会使用user_mss,否则syn+ack报文就是dst的MSS值——也就是前文中所述,出口路由的MTU-40。...总结一下: 标准的内核syn+ack报文中的MSS也是由出口路由的MTU-40; 目前百度公司对syn+ack的MSS做了自己的修改,会取syn报文的MSS和其实际MSS的较小值;BAT中只有百度做了这个修改

    2.6K21

    TCP的MTU Probe和MSS(2)

    在上一篇《TCP的MTU Probe和MSS(1)》介绍了TCP使用MTU Probe来避免PMTU变小而导致发送失败的方法。...其主要思想是在TCP发送失败时,发送方会不断尝试降低MSS的大小,直至满足PMTU的限制,成功发送数据。...还有一种情况:TCP报文丢失而重传时,MTU probe功能会自动减小MSS。 如果探测成功会怎么样?...如果前面计算探测报文的大小probe_size超过了当前search_high计算的MSS值(前面的探测成功,探测报文逐渐增大)或者上限与下限的间隔已经小于配置的阀值,则进入tcp_mtu_check_reprobe...探测报文的发送时间间隔超过配置值,则更新探测上限为可能MTU的最大值(MSS上限+TCP首部+IP报文首部),下限为根据当前MSS计算的MTU值。

    2.8K20

    通过案例来学习TCP的MSS、MTU

    奇怪的问题是图中橙色框中看到的,网络这时候是联通的,客户端跟服务端在这个会话中依然有些包能顺利到达(Keep-Alive包) 同时注意到重传的包长是1442,包比较大了,看了一下tcp建立连接的时候MSS...是1500,应该没有问题 查看了scp的两个容器的网卡mtu都是1500,正常 基本上看到这里,能想到是因为丢包导致的scp卡死,因为两个容器mtu都正常,包也小于mss,那只能是网络路由上某个环节mtu...最后的总结 因为这是客户给的同一批宿主机默认想当然的认为他们的配置到一样,尤其是mtu这种值,只要不是故意捣乱就不应该乱修改才对,我只检查了两个容器的mtu,没看宿主机的mtu,导致诊断中走了一些弯路...通过这个案例对mtu/mss等有了进一步的了解 从这个案例也理解了vlan模式下容器、宿主机、交换机之间的网络传输链路 其实抓包还发现了比1500大得多的包顺利通过,反而更小的包无法通过,这是因为网卡基本都有拆包的功能了

    1.6K70

    linux rsyslog配置_syslog配置

    直接兼容syslogd的syslog.conf配置文件 在同一台机器上支持多个rsyslogd进程 丰富的过滤功能,可将消息过滤后再转发 灵活的配置选项,配置文件中可以写简单的逻辑判断 增加了重要的功能.../etc/sysconfig/rsyslog文件用于配置守护进程的运行参数,/etc/rsyslog.conf是rsyslog的主配置文件。...#配置客户端rsyslog发送tcp端口日志,通过修改配置文件/etc/rsyslog.config上指定tcp传输的日志 echo ‘mail.info @@172.31.101.52:514’>>.../var/log/anaconda.log — 在安装Linux时,所有安装信息都储存在这个文件中。 /var/log/yum.log — 包含使用yum安装的软件包信息。.../var/log/audit/ — 包含被 Linux audit daemon储存的信息。 /var/log/samba/ – 包含由samba存储的信息。

    11.2K20

    Linux配置HDCP

    配置说明 在Linux配置HDCP(High-bandwidth Digital Content Protection)是针对显示器和显卡之间的数字版权保护协议。...然而,HDCP配置通常是由硬件和显卡驱动程序支持的,而不是由操作系统配置。因此,在Linux配置HDCP可能会有一些限制。...更新显卡驱动程序:确保您的Linux系统上安装了最新的显卡驱动程序。您可以查找并下载适用于您的显卡型号的最新驱动程序,然后按照厂商提供的说明进行安装。...配置HDCP选项:某些显卡驱动程序可能提供了配置HDCP选项的界面或命令行工具。您可以尝试在显卡控制面板或使用特定的命令行工具来查看和配置HDCP设置。...使用DRM(Direct Rendering Manager):Linux使用DRM来管理和控制显示器和显卡之间的通信。确保您的系统已启用DRM,并根据需要进行相应的配置

    57730

    Linux入门】Linux环境配置

    前言:本篇内容讲解Linux环境的配置,云服务器和虚拟机的配置、如何多用户使用一个云服务器。关于选择哪一种还是依情况而定。...1、搭建 Linux 环境 Linux 环境的搭建方式 1、直接安装在物理机上....使用 XShell 远程登陆到 Linux 关于 Linux 桌面 Linux 启动进入图形化的桌面. 以后的工作中 没有机会 使用图形界面. 为什么不使用图形界面?...云服务器的配置: 获得root权限进行登录 ssh root@公网ip 分享账号: 多用户管理操作: # adduser 新用户名--------创建用户 # passwd 新用户名----...-----输入密码,密码设置时不显示 # user -r 用户名 ------------删除用户 登录分享的账号: ssh 用户名@ip地址 输入密码 虚拟机的配置配置的是权限,这里的指令只需要按顺序操作即可

    66331

    linux安全配置

    给大家分享两个可以搞定的大招: hosts.allow和hosts.deny /etc/hosts.allow和/etc/hosts.deny两个文件是控制远程访问设置的,通过他可以允许或者拒绝某个ip或者ip段的客户访问linux...然后再次回到linux系统,登录后一次输入如下: #mkdir /root/.ssh    创建一个.ssh的隐藏文件夹 #chmod 700 /root/.ssh   给.ssh的文件夹授权 #vi...6、然后再次使用  #vi /root/.ssh/authorized_keys 并把Xshell的公钥复制到另起一行,以#号开头的在linux当中是标注的意思! ?...10、然后最后一步,我们配置的防火墙只是暂时的关闭,重启电脑后就会失效,所以我需要永久的关闭它 #vi /etc/selinux/config        #修改selinux的配置文件 更改“SELINUX...基于密钥认证的配置 # vi /etc/ssh/sshd_config   PasswordAuthentication no      //禁止使用基于口令认证的方式登陆 PubkeyAuthentication

    8.1K50

    Linux 网络配置

    # Linux 网络配置 # 画出原理图,帮助理解 # 查看网络IP和网关 # 查看虚拟网络编辑器和修改IP地址 # 查看网关 # 查看windows环境中VMnet8网络配置 指令:ipconfig...ipconfig # 查看Linux的网络配置 指令:ifconfig ifconfig # ping测试主机之间网络连通性 # 基本语法 ping 目的主机 (功能描述:测试当前服务器是否可以连接目的主机...) # 应用实例 测试当前服务器是否可以连接百度 ping www.baidu.com # Linux网络配置环境 # 第一种方法(自动获取) 说明:登陆后,通过界面的来设置自动获取ip,特点:linux...=192.168.197.2 重启网络服务或者重启系统生效 service network restart 或者 reboot # 设置主机名和hosts映射 # 设置主机名 为了方便记忆,可以给linux...hostname :查看主机名 修改文件在/etc/hostname指定 vim /etc/hostname 修改后,重启生效 # 设置hosts映射 思考:如何通过主机名能够找到(比如ping)某个linux

    7.6K20
    领券