【DevOps】Linux 内核网络子系统全面指南与性能调优
目录
一、Linux 内核网络子系统
1. Netfilter
主要特性
工作流程
2. Traffic Control (TC)
主要特性
工作流程
3. Socket
主要特性
工作流程
二、内核参数优化
1. net.ipv4.tcp_window_scaling
2. net.core.netdev_max_backlog
3. net.ipv4.tcp_rmem 和 net.ipv4.tcp_wmem
4. net.ipv4.tcp_fin_timeout
5. net.core.rmem_default 和 net.core.wmem_default
一、Linux 内核网络子系统
Linux 内核的网络子系统是其架构中非常复杂和强大的部分,负责处理所有网络相关的操作。这些操作包括数据包过滤、地址转换、流量控制、服务质量保证,以及为应用程序提供网络通信的接口。下面我们详细介绍几个关键的网络子系统:Netfilter、Traffic Control 和 Socket。
1. Netfilter
Netfilter 是 Linux 内核中一个非常重要的网络子系统,主要用于在内核中实现包过滤、网络地址转换 (NAT) 和其他网络相关的钩子功能。Netfilter 提供了一系列的钩子(hook),这些钩子位于网络协议栈的不同位置,可以捕获网络协议栈中的数据包,进行处理或决定数据包的去向。
主要特性
-
数据包过滤:Netfilter 通过与 iptables(在较新的内核中是 nftables)的配合,可以实现包括但不限于 IP 地址、端口号、协议类型等条件的数据包过滤。
-
网络地址转换 (NAT):Netfilter 支持源 NAT (SNAT)、目的 NAT (DNAT) 和端口映射,这对于路由器和防火墙的功能是非常关键的。
-
状态跟踪:Netfilter 可以跟踪每个网络连接的状态,这使得它可以识别和处理每个连接的数据包,如区分新连接、已建立的连接和结束的连接。
-
用户空间通信:Netfilter 可以通过
nfnetlink
与用户空间程序通信,允许用户空间程序动态地更改过滤规则或收集网络状态信息。
工作流程
Netfilter 提供了五个主要的钩子点,它们位于网络协议栈的不同层次:
NF_IP_PRE_ROUTING
:在路由决策之前,对进入的数据包进行处理。NF_IP_LOCAL_IN
:在确定数据包目的地为本机后进行处理。NF_IP_FORWARD
:在进行路由转发决策后,对需要转发的数据包进行处理。NF_IP_LOCAL_OUT
:在本机产生的数据包即将发送出去前进行处理。NF_IP_POST_ROUTING
:在数据包即将离开网卡前进行处理。
2. Traffic Control (TC)
Traffic Control (TC) 是 Linux 内核的另一个网络子系统,用于实现网络流量控制和服务质量(QoS)。TC 允许 Linux 内核对网络接口的数据包发送队列进行控制,包括带宽限制、延迟管理和数据包排队策略。
主要特性
-
带宽管理:通过诸如令牌桶过滤器 (TBF)、随机早期检测 (RED) 等机制,控制数据流的速率。
-
排队策略:包括 FIFO、Stochastic Fairness Queueing (SFQ)、Hierarchical Token Bucket (HTB) 等,用于控制数据包的发送顺序和方式。
-
分类:TC 使用分类器将数据包分流到不同的类和队列,允许对不同类型的流量实施不同的控制策略。
-
过滤:通过过滤器确定数据包属于哪个类,过滤器可以基于多种条件,如协议、端口号、IP 地址等。
工作流程
- 分类:数据包首先通过分类器进行分类,判定进入哪个类。
- 排队:每个类有自己的队列,数据包按照策略进入相应的队列。
- 调度:调度器根据策略从队列中取出数据包发送。
3. Socket
Socket 是 Linux 内核提供的用于网络通信的基本接口,属于网络子系统中的应用层接口部分。Socket 抽象了网络通信的细节,使应用程序可以通过标准的接口发送和接收数据,而无需关心底层网络协议的具体实现。
主要特性
-
多种类型:支持多种类型的 Socket,包括流式套接字 (SOCK_STREAM)、数据报套接字 (SOCK_DGRAM) 和原始套接字 (SOCK_RAW)。
-
多种协议:支持多种网络协议,如 IPv4、IPv6、TCP、UDP 等。
-
阻塞与非阻塞操作:Socket 可以在阻塞模式和非阻塞模式下工作,允许应用根据需要选择合适的工作方式。
-
安全特性:支持通过 SSL/TLS 等协议提供加密通信。
工作流程
- 创建 Socket:应用程序通过
socket()
系统调用创建一个 Socket。 - 配置 Socket:通过各种系统调用 (如
bind()
,listen()
,connect()
) 配置 Socket 的属性和行为。 - 数据传输:使用
send()
和recv()
(或write()
和read()
) 系统调用进行数据的发送和接收。 - 关闭 Socket:通过
close()
系统调用关闭 Socket。
这些子系统合作,形成了 Linux 内核中强大而灵活的网络功能,支持从简单的数据传输到复杂的网络应用。
二、内核参数优化
在 Linux 系统中,通过调整内核参数来优化网络性能是一种常见且有效的方法。内核参数可以控制 TCP/IP 栈和其他网络子系统的行为,从而改善网络吞吐量、降低延迟、增加连接的稳定性和响应速度。下面是对您提到的两个参数的详细介绍,以及其他一些常用的内核参数和它们的优化作用。
1. net.ipv4.tcp_window_scaling
-
参数说明:
net.ipv4.tcp_window_scaling
是一个布尔值参数,用于启用或禁用 TCP 窗口缩放功能。 -
作用:TCP 窗口缩放是一种机制,允许 TCP 连接动态调整其接收窗口大小,从而适应不同的网络延迟和带宽条件。这个功能在高延迟或高带宽的网络环境(如卫星通信、长距离光纤连接)中尤其重要,可以显著提高数据传输效率。
-
默认值:通常默认为
1
(启用)。 -
调整建议:
- 在网络环境稳定且网络延迟较低的局域网环境中,这个选项的效果不明显,但在宽带较大的网络中,启用窗口缩放可以提高传输性能。
- 如果要启用 TCP 窗口缩放,确保
sysctl
设置为net.ipv4.tcp_window_scaling = 1
。
2. net.core.netdev_max_backlog
-
参数说明:
net.core.netdev_max_backlog
设置了在内核处理之前,网络设备驱动能够队列的接收包的最大数量。 -
作用:这个参数决定了网络设备接收队列的最大长度,对于高速网络或是在突发大量网络请求时,增加这个参数的值可以减少因队列溢出而导致的丢包,从而提高网络性能。
-
默认值:默认值可能在 1000 左右,具体值依据不同的内核和系统配置而变化。
-
调整建议:
- 在高速网络环境中或大量并发连接的服务器上,可以适当增加这个值,例如设置为
2000
或更高,如3000
。 - 修改方式:
sysctl -w net.core.netdev_max_backlog=2000
或通过编辑/etc/sysctl.conf
文件添加net.core.netdev_max_backlog = 2000
并重新加载配置sysctl -p
。
- 在高速网络环境中或大量并发连接的服务器上,可以适当增加这个值,例如设置为
3. net.ipv4.tcp_rmem 和 net.ipv4.tcp_wmem
-
参数说明:
net.ipv4.tcp_rmem
:这个参数控制 TCP 接收缓冲区的最小值、默认值和最大值,单位是字节。net.ipv4.tcp_wmem
:这个参数控制 TCP 发送缓冲区的最小值、默认值和最大值,单位是字节。
-
作用:调整这些参数可以优化 TCP 的缓冲区大小,适应不同的网络环境,特别是在高带宽和高延迟的网络中,增大这些值可以提高网络性能。
-
默认值:通常形式为
4096 87380 6291456
。 -
调整建议:
- 对于高性能服务器,可以将这些值调整为更大,例如
4096 65536 16777216
(对应最小、默认、最大)。 - 修改方式:
sysctl -w net.ipv4.tcp_rmem="4096 65536 16777216" sysctl -w net.ipv4.tcp_wmem="4096 65536 16777216"
- 对于高性能服务器,可以将这些值调整为更大,例如
4. net.ipv4.tcp_fin_timeout
-
参数说明:
net.ipv4.tcp_fin_timeout
指定了等待一个 TCP 连接完全终止前的超时时间,单位是秒。 -
作用:这个参数影响 TIME-WAIT 状态的持续时间。减少这个值可以快速回收套接字,但是太小可能导致旧的重复数据段出现在新的连接中。
-
默认值:通常默认为
60
秒。 -
调整建议:
- 对于处理大量短连接的服务器,可以适当减少这个值,例如设置为
30
或更低,如15
。 - 修改方式:
sysctl -w net.ipv4.tcp_fin_timeout=30
- 对于处理大量短连接的服务器,可以适当减少这个值,例如设置为
5. net.core.rmem_default 和 net.core.wmem_default
-
参数说明:
net.core.rmem_default
:指定接收套接字缓冲区的默认大小(字节)。net.core.wmem_default
:指定发送套接字缓冲区的默认大小(字节)。
-
作用:这些参数控制非 TCP 套接字的默认缓冲区大小,对于 UDP 通信等场景下,增大这些值可以提高性能。
-
默认值:通常为
212992
。 -
调整建议:
- 对于需要大量 UDP 通信的应用,可以增加这些值,如设置为
262144
或更大。 - 修改方式:
sysctl -w net.core.rmem_default=262144 sysctl -w net.core.wmem_default=262144
- 对于需要大量 UDP 通信的应用,可以增加这些值,如设置为
通过合理调整这些参数,可以显著提高 Linux 系统的网络性能,尤其是在高负载、高并发的网络服务器环境中。每一次调整后,都应该进行充分的测试,以确保新的配置不仅提升了性能,而且保持了系统的稳定性和可靠性。
相关文章:
【DevOps】Linux 内核网络子系统全面指南与性能调优
目录 一、Linux 内核网络子系统 1. Netfilter 主要特性 工作流程 2. Traffic Control (TC) 主要特性 工作流程 3. Socket 主要特性 工作流程 二、内核参数优化 1. net.ipv4.tcp_window_scaling 2. net.core.netdev_max_backlog 3. net.ipv4.tcp_rmem 和 net.ipv4…...

mybatis-plus-ui代码生成器
mybatis-plus-generator-ui 提供交互式的Web UI用于生成兼容mybatis-plus框架的相关功能代码,包括Entity,Mapper,Mapper.xml,Service,Controller等 ,可以自定义模板以及各类输出参数,也可通过SQL查询语句直接生成代码。 使用方法 引入mave…...
项目进度总结
完成了签到,老师发布签到并设置持续的时间,学生在规定的时间内可用签到码进行签到,超过时间将不在允许签到...

CheckStyle静态样式之道
优质博文:IT-BLOG-CN 在标准化的统一样式检查规范里,最为常用的统一样式工具是checkstyle插件,而不是国内阿里的代码规约插件。 【1】下载插件 【2】配置生效 配置生效及告警设置 【3】配置checkstyle.xml 官网地址 官网最新Releases 下面…...
2024中国振威化工装备展
2024上海国际化工设备展览会 第十六届上海国际化工装备博览会将于2024年11月19-21日在国家会展中心(上海)举办,预计参展企业1000多家,展览面积7万平方米,观众突破10万人次。展会设置石化装备、化工单元设备、化工环保…...
Docker操作之启动多个相同容器实例并nginx负载均衡
文章目录 前言 一、一些概念 1.Docker 2.nginx 二、操作步骤 1.构建compose.yaml 2.nginx配置 3.Docker compose命令 4.问题与解决 总结 前言 Docker对于开发、运维人员来说都很熟悉,但是对于开发人员来说,多数时候只需一个容器实例运行即可。…...

本地的git仓库和远程仓库
文章目录 1. 远程创建仓库2. 关联远程和本地代码3. 推送本地分支到远程4. 删除远程分支5. 分支重命名6. git pull rebase7. git merge master把本地文件删除了 1. 远程创建仓库 2. 关联远程和本地代码 上面创建完后会得到一个git仓库的链接,有SSH或者http的 http:…...

Google I/O 2024 干货全解读:Gemini AI 横空出世,智能未来触手可及!
Google I/O 2024 干货全解读:Gemini AI 横空出世,智能未来触手可及! 博主猫头虎的技术世界 🌟 欢迎来到猫头虎的博客 — 探索技术的无限可能! 专栏链接: 🔗 精选专栏: 《面试题大全》…...
深入理解JVM:介绍JVM的工作原理,包括类加载机制,内存模型,垃圾回收机制等
类加载机制: JVM的类加载机制主要包括加载、连接(验证、准备和解析)、初始化、使用和卸载五个阶段。第一个阶段是加载需求的.class文件到内存中。第二个阶段是完成对字节码的验证,为类变量分配内存并初始化为对应类型默认值。第三…...

Springboot+Vue项目-基于Java+MySQL的民族婚纱预定系统(附源码+演示视频+LW)
大家好!我是程序猿老A,感谢您阅读本文,欢迎一键三连哦。 💞当前专栏:Java毕业设计 精彩专栏推荐👇🏻👇🏻👇🏻 🎀 Python毕业设计 &…...
Java面经学习2
来源 https://www.nowcoder.com/discuss/619573767051800576 1.一面内容 RocketMQ延时消息(项目用到了)底层怎么实现的(不会) 消息量太大导致读消息延迟时间很长怎么办 redis为什么快(说了内存、数据结构优化、单线…...
Java bin目录中的文件如何执行?
在 Java 项目中,bin 目录通常用于存放编译后的 .class 文件。如果你将编译后的 .class 文件放在 bin 目录中,需要确保在运行 Java 程序时指定正确的类路径。下面是一个简单的例子说明如何执行 bin 目录中的文件。 假设你的项目结构如下: pr…...

Kafka和Spark Streaming的组合使用学习笔记(Spark 3.5.1)
一、安装Kafka 1.执行以下命令完成Kafka的安装: cd ~ //默认压缩包放在根目录 sudo tar -zxf kafka_2.12-2.6.0.tgz -C /usr/local cd /usr/local sudo mv kafka_2.12-2.6.0 kafka-2.6.0 sudo chown -R qiangzi ./kafka-2.6.0 二、启动Kafaka 1.首先需要启动K…...

5.9网络协议
由网卡发送数据通过网线进行发送,当网卡接收到信号以后将数据传给内核数据区,然后由操作系统交给相应的进程。 将数据进行发送的时候需要借助于网线实现,这个时候会出现当传输的数据比较远的时候就借助于中继器将信号进行再生扩大࿰…...

QT客户端开发的注意事项
QT客户端开发是一个涉及图形用户界面(GUI)设计、网络编程、数据库交互等多个方面的复杂过程。以下是在进行QT客户端开发时应注意的一些关键事项,通过关注这些事项,可以提高QT客户端应用的质量和开发效率。北京木奇移动技术有限公司…...
k8s源码编译失败:Makefile:1: *** 缺失分隔符。 停止。
目录 问题解决 更换Arch或系统 问题解决 编译k8s源码的kubelet时执行make失败:Makefile:1: *** 缺失分隔符。 停止。 首先,查看文件内容 # cat Makefile build/root/Makefile 修改Makefile,给第一行前增加include,如下&…...

服务器数据恢复—拯救raid5阵列数据行动,raid5数据恢复案例分享
Raid5数据恢复算法原理: 分布式奇偶校验的独立磁盘结构(被称之为raid5)的数据恢复有一个“奇偶校验”的概念。可以简单的理解为二进制运算中的“异或运算”,通常使用的标识是xor。运算规则:若二者值相同则结果为0&…...

旅游集市数仓建设
旅游集市数仓建设 小白如何从0到1成为大数据工程师 目录 旅游集市数仓建设 1.上传数据 2.可能用到的UDF函数 3.创建所需数据库及表 1)ODS层 ①ods_oidd ②ods_wcdr ③ods_ddr ④ods_dpi 2)DWD层 ①dwd_res_regn_mergelocation_msk_d ②dwm_s…...
vue实现点击高亮效果
<view class"tabs"><textv-for"(item, index) in subTypes":key"item.id"class"text":class"{ active: index activeIndex }"//动态绑定高亮类:判断下标是否等于当前下标tap"activeIndex index&…...

uniapp 配置请求代理+请求封装
uniapp官网提供了三种方式:什么是跨域 | uni-app官网 1. 通过uniapp自带浏览器 打开项目是不存在跨域的 第二种方式: "h5" : {"template" : "static/index.html","devServer": {"proxy": {&quo…...
可靠性+灵活性:电力载波技术在楼宇自控中的核心价值
可靠性灵活性:电力载波技术在楼宇自控中的核心价值 在智能楼宇的自动化控制中,电力载波技术(PLC)凭借其独特的优势,正成为构建高效、稳定、灵活系统的核心解决方案。它利用现有电力线路传输数据,无需额外布…...

【项目实战】通过多模态+LangGraph实现PPT生成助手
PPT自动生成系统 基于LangGraph的PPT自动生成系统,可以将Markdown文档自动转换为PPT演示文稿。 功能特点 Markdown解析:自动解析Markdown文档结构PPT模板分析:分析PPT模板的布局和风格智能布局决策:匹配内容与合适的PPT布局自动…...
oracle与MySQL数据库之间数据同步的技术要点
Oracle与MySQL数据库之间的数据同步是一个涉及多个技术要点的复杂任务。由于Oracle和MySQL的架构差异,它们的数据同步要求既要保持数据的准确性和一致性,又要处理好性能问题。以下是一些主要的技术要点: 数据结构差异 数据类型差异ÿ…...
使用Matplotlib创建炫酷的3D散点图:数据可视化的新维度
文章目录 基础实现代码代码解析进阶技巧1. 自定义点的大小和颜色2. 添加图例和样式美化3. 真实数据应用示例实用技巧与注意事项完整示例(带样式)应用场景在数据科学和可视化领域,三维图形能为我们提供更丰富的数据洞察。本文将手把手教你如何使用Python的Matplotlib库创建引…...

华为OD机考-机房布局
import java.util.*;public class DemoTest5 {public static void main(String[] args) {Scanner in new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别while (in.hasNextLine()) { // 注意 while 处理多个 caseSystem.out.println(solve(in.nextLine()));}}priv…...
比较数据迁移后MySQL数据库和OceanBase数据仓库中的表
设计一个MySQL数据库和OceanBase数据仓库的表数据比较的详细程序流程,两张表是相同的结构,都有整型主键id字段,需要每次从数据库分批取得2000条数据,用于比较,比较操作的同时可以再取2000条数据,等上一次比较完成之后,开始比较,直到比较完所有的数据。比较操作需要比较…...
C语言中提供的第三方库之哈希表实现
一. 简介 前面一篇文章简单学习了C语言中第三方库(uthash库)提供对哈希表的操作,文章如下: C语言中提供的第三方库uthash常用接口-CSDN博客 本文简单学习一下第三方库 uthash库对哈希表的操作。 二. uthash库哈希表操作示例 u…...

给网站添加live2d看板娘
给网站添加live2d看板娘 参考文献: stevenjoezhang/live2d-widget: 把萌萌哒的看板娘抱回家 (ノ≧∇≦)ノ | Live2D widget for web platformEikanya/Live2d-model: Live2d model collectionzenghongtu/live2d-model-assets 前言 网站环境如下,文章也主…...

【深度学习新浪潮】什么是credit assignment problem?
Credit Assignment Problem(信用分配问题) 是机器学习,尤其是强化学习(RL)中的核心挑战之一,指的是如何将最终的奖励或惩罚准确地分配给导致该结果的各个中间动作或决策。在序列决策任务中,智能体执行一系列动作后获得一个最终奖励,但每个动作对最终结果的贡献程度往往…...

设计模式域——软件设计模式全集
摘要 软件设计模式是软件工程领域中经过验证的、可复用的解决方案,旨在解决常见的软件设计问题。它们是软件开发经验的总结,能够帮助开发人员在设计阶段快速找到合适的解决方案,提高代码的可维护性、可扩展性和可复用性。设计模式主要分为三…...