Linux编程:嵌入式ARM平台Linux网络实时性能优化

文章目录

    • 0. 概要
    • 1. 时钟周期与网络性能的权衡
      • 时钟周期(ClockPeriod)
        • **优化策略:**
        • **副作用:**
    • 2. 网络中断优化
        • **问题:**
        • **优化策略:**
        • **副作用:**
    • 3. 网络协议栈优化
        • **优化策略:**
        • **副作用:**
    • 4. 禁用内存页面交换(禁用 Swap)
      • 为什么禁用 Swap?
      • **禁用 Swap 配置:**
      • **副作用:**
    • 5. 配置 `swappiness` 为 0
      • **如何设置 `swappiness` 为 0:**
      • **副作用:**
    • 6. 网络吞吐量与 CPU 调度
        • **优化策略:**
        • **副作用:**
    • 7. 使用硬件辅助优化
        • **优化策略:**
        • **副作用:**
    • 更多阅读

0. 概要

本文将通过优化时钟周期、网络中断处理、协议栈配置、CPU 调度等配置来提升网络吞吐量,尤其是 UDP 数据包的处理效率。同时也将分析这些优化措施可能带来的副作用和对系统资源的影响。

1. 时钟周期与网络性能的权衡

时钟周期(ClockPeriod)

优化策略:
  • 启用高分辨率定时器:对于实时性要求高的应用,建议配置内核,启用高分辨率定时器(CONFIG_HIGH_RES_TIMERS),以提高定时器精度。

    make menuconfig  # 打开Linux内核配置
    CONFIG_HIGH_RES_TIMERS=y
    
  • 合理选择时钟周期:选择适当的时钟周期,使其在精度和 CPU 负载之间找到平衡。可通过测试找到最适合的时钟周期。

副作用:
  • CPU 负担增加:高分辨率定时器提高了系统调度的精度,但也增加了频繁的上下文切换和时钟更新,可能会增加 CPU 资源的消耗,特别是在 CPU 负载本已较重的情况下。
  • 过短的时钟周期可能会导致 CPU 资源被频繁的中断处理占用,从而影响网络中断的响应,尤其是在高流量的 UDP 数据包处理中。

2. 网络中断优化

问题:
  • 中断过于频繁:默认情况下,网络驱动会为每个数据包触发一次中断,这在高流量场景下会大幅增加 CPU 的负载,降低 UDP 数据包的吞吐量。
  • 中断竞争:在多核系统中,多个中断可能争夺 CPU 资源,导致缓存失效和上下文切换开销,进一步影响性能。
优化策略:
  • 启用 NAPI:通过启用 NAPI(New API)合并中断,减少中断的频率,优化 CPU 的使用。
    ethtool -C eth0 rx-usecs 10
    
  • 中断优先级调整:调整网络中断的优先级,确保网络中断能在系统繁忙时优先处理。
    echo 1 > /proc/irq/<irq_number>/smp_affinity_list
    
  • 中断绑定(CPU 绑定):将网络中断绑定到特定的 CPU 核心,减少跨核上下文切换开销。
    echo 1 > /sys/class/net/eth0/queues/rx-0/rps_cpus
    
副作用:
  • 内存使用增加:NAPI 的合并中断可能会导致系统使用更多的内存来存储等待处理的数据包,特别是在大流量情况下。
  • 延迟增加:尽管中断频率减少,但合并中断和轮询可能会导致延迟略有增加,尤其是在低流量场景下。

3. 网络协议栈优化

在高吞吐量应用中,网络协议栈的一些默认配置可能成为性能瓶颈。

优化策略:
  • 调整缓冲区大小:合理调整 UDP 接收和发送缓冲区的大小,以优化吞吐量。
    sysctl -w net.core.rmem_max=16777216
    sysctl -w net.core.wmem_max=16777216
    
  • 禁用不必要的协议:如果系统不需要 IPv6 或其他协议,可以通过禁用这些协议来减少协议栈的负担。
    sysctl -w net.ipv6.conf.all.disable_ipv6=1
    
副作用:
  • 内存消耗增加:增大缓冲区大小会增加内存的消耗,特别是在高负载的情况下,可能导致系统内存紧张。

4. 禁用内存页面交换(禁用 Swap)

为什么禁用 Swap?

交换空间(swap)允许操作系统将不常用的数据页从内存移至硬盘,当系统内存不足时,避免直接崩溃。虽然这种机制有助于防止内存溢出,但当数据被交换到磁盘上时,每当需要访问这些数据时都会触发缺页中断,进而导致额外的延迟。

禁用 Swap 配置:

可以使用以下命令禁用当前的 swap 分区:

# 禁用 swap 分区
swapoff -a

# 永久禁用 swap,编辑 /etc/fstab 文件,注释掉 swap 行

副作用:

  • 内存压力增加:禁用 swap 后,如果系统内存不足,应用程序可能会因内存溢出而崩溃。需要确保系统有足够的物理内存来承载高负载。

5. 配置 swappiness 为 0

  • 禁用 Swap 是彻底关闭交换空间,不允许内存数据交换到磁盘。
  • 配置内核swappiness 为 0 是一种软性优化,它尽量避免使用交换空间,但不完全禁止。当系统内存极度紧张时,swappiness 为 0 不会阻止系统使用 swap

如何设置 swappiness 为 0:

  1. 临时修改: 临时修改 swappiness 的值,使其立即生效,但重启后会失效。

    sysctl vm.swappiness=0
    
  2. 永久修改: 修改 /etc/sysctl.conf 文件,使配置在系统重启后依然生效。

    echo "vm.swappiness = 0" >> /etc/sysctl.conf
    sysctl -p
    

副作用:

  • 内存压力增加:将 swappiness 设置为 0 后,如果系统内存不足,进程可能会因内存不足而崩溃。

6. 网络吞吐量与 CPU 调度

网络吞吐量不仅与中断处理有关,还与 CPU 调度效率和任务优先级密切相关。合理调度网络相关进程,确保它们能够高优先级地执行,可以有效提高 UDP 数据包的吞吐量。

优化策略:
  • CPU 亲和性:将 UDP 数据处理任务绑定到特定的 CPU 核心上,避免跨核任务迁移,减少缓存失效的概率。
    taskset -c 0-1 ./my_udp_task
    
  • 高优先级调度:使用实时调度策略(如 FIFO 或 RR)提高与 UDP 数据包处理相关进程的优先级,确保网络中断能够及时响应。
    chrt -f 99 my_udp_task
    
副作用:
  • CPU 负担不均:CPU 亲和性优化可能会导致某些 CPU 核心的负载过重,而其他核心处于闲置状态,因此需要仔细评估。

7. 使用硬件辅助优化

硬件时间戳可以提高网络吞吐量,减轻 CPU 的负担。

优化策略:
  • 启用硬件时间戳:如果网卡支持,启用硬件时间戳可以减轻 CPU 的负担。
    ethtool -T eth0
    ethtool -s eth0 time-stamping on
    
副作用:
  • 内存消耗:硬件时间戳等功能会占用一定的内存资源,特别是在需要精确时间同步的高流量环境中,可能导致内存消耗增加。

更多阅读

  • 针对ARM64嵌入式系统的Linux内核参数优化
  • tcp网络编程性能优化点
  • Linux操作系统的实时化-PREEMPT_RT

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/914730.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode 热题100 之 多维动态规划

1.不同路径 思路分析&#xff1a;动规五部曲 dp数组定义&#xff1a;dp[i][j]表示从起点&#xff08;0&#xff0c;0&#xff09;到位置(i,j)的路径数量递推公式&#xff1a;dp[i][j] dp[i-1][j] dp[i][j-1] 从 (i-1, j) 位置到 (i, j) 需要走一步向下的路径。从 (i, j-1) 位…

文件操作(3)

前言&#xff0c;在上篇博客介绍了如何正确的打开一个文件和关闭一个文件&#xff0c;今天我们来学习如何在文件中输出和输入数据。 对文件数据的读写可以分为顺序读写和随机读写。顺序读写&#xff0c;即挨着顺序对文件中的数据进行输入或输出。 在这片博客中&#xff0c;我们…

Openstack7--安装消息队列服务RabbitMQ

只需要在控制节点安装 安装RabbitMQ yum -y install rabbitmq-server 启动RabbitMQ并设置开机自启 systemctl start rabbitmq-server;systemctl enable rabbitmq-server 创建 rabbitmq 用户 并设置密码为 000000 rabbitmqctl add_user rabbitmq 000000 如果你不慎创错了…

Unity图形学之Shader2.0 模板测试

1.模版测试&#xff1a;符合条件的 通过 不符合条件的 像素 丢弃 比较公式&#xff1a; if&#xff08;&#xff08;referenceValue&readMask&#xff09; comparisonFunction &#xff08;stencilBufferValue&readMask&#xff09;&#xff09; 通过像素 else 抛弃…

020_Servlet_Mysql学生选课系统(新版)_lwplus87

摘 要 随着在校大学生人数的不断增加&#xff0c;教务系统的数据量也不断的上涨。针对学生选课这一环节&#xff0c;本系统从学生网上自主选课以及课程发布两个大方面进行了设计&#xff0c;基本实现了学生的在线信息查询、选课功能以及教师对课程信息发布的管理等功能&…

SpringBoot教程(二十五) | SpringBoot配置多个数据源

SpringBoot教程&#xff08;二十五&#xff09; | SpringBoot配置多个数据源 前言方式一&#xff1a;使用dynamic-datasource-spring-boot-starter引入maven依赖配置数据源动态切换数据源实战 方式二&#xff1a;使用AbstractRoutingDataSource1. 创建数据源枚举类2. 创建数据源…

Python 正则表达式进阶用法:分组与引用详解

Python 正则表达式进阶用法&#xff1a;分组与引用详解 正则表达式是一种用于字符串匹配和处理的强大工具。它不仅能识别简单的文本模式&#xff0c;还能通过更高级的特性来完成复杂的文本处理任务。本文将深入探讨 Python 正则表达式中的“分组”和“引用”——两个在高级匹配…

米家通过HomeAssistant控制笔记本电脑开关机

米家通过HomeAssistant控制笔记本电脑开关机 配置HomeAssistant配置EMQX mqtt自动化配置电脑关机实现电脑开机实现&#xff08;网络唤醒WOL包&#xff09; 环境准备&#xff1a; HomeAssistant&#xff1a;能配置接入米家的设备&#xff0c;我这里采用fnos安装MQTT服务器&…

前端环境配置

对于换公司的小伙伴来讲&#xff0c;重新安装环境&#xff0c;百度或许稍微有点麻烦&#xff0c;本文章让你无脑式直接操作&#xff0c;保证环境畅通无阻。 1.安装nvm-setup 该插件是一款管理nodeJs的包&#xff0c;无需你单独下载nodeJs去安装&#xff0c;只需要下载安装此…

[CKS] K8S AppArmor Set Up

最近准备花一周的时间准备CKS考试&#xff0c;在准备考试中发现有一个题目关于AppArmor Pod操作权限的问题。 ​ 专栏其他文章: [CKS] Create/Read/Mount a Secret in K8S-CSDN博客[CKS] Audit Log Policy-CSDN博客 -[CKS] 利用falco进行容器日志捕捉和安全监控-CSDN博客[CKS] …

提升自然排名的有效策略与方法

内容概要 在数字营销的快速发展背景下&#xff0c;自然排名的提升日益显得重要。自然排名不仅影响网站的流量&#xff0c;同时也直接关系到品牌的曝光度和市场竞争力。针对这个主题&#xff0c;我们将探讨多个关键因素&#xff0c;帮助读者更好地理解自然排名的重要性及其影响…

golang go语言 组建微服务架构详解 - 代码基于开源框架grpc+nacos服务管理配置平台

整体介绍&#xff1a; 本文主要介绍如何用go语言 来组建微服务的框架&#xff0c;grpc服务管理 示例框架 代码由grpcnacos go sdk 组成。 grpc负责将调用序列化并传递到远端&#xff0c;nacos负责服务发现和服务管理。 grpc和nacos都是开源产品。代码复制下来就能跑。 微服…

软件测试项目实战

软件测试是使用人工或者自动的手段来运行或者测定某个软件系统的过程&#xff0c;其目的在于检验它是否满足规定的需求或弄清预期结果与实际结果之间的差别。 在软件投入使用前&#xff0c;要经过一系列的严格测试&#xff0c;才能保证交付质量。 一、引言 1.编写目的 本文档…

基于百度飞桨paddle的paddlepaddle2.4.2等系列项目的运行

PPASR 必看&#xff01;&#xff01;&#xff01; PaddleSpeech develop --> PaddlePaddle 2.5.0/2.5.1 PaddleSpeech < 1.4.1 --> PaddlePaddle < 2.4.2 1.创建虚拟环境 conda create --name test python3.10 2.激活环境&#xff0c;安装ppasr的paddlepaddl…

MySQL数据库专栏(四)MySQL数据库链接操作C#篇

摘要 本篇文章主要介绍C#链接MySQL数据库的接口介绍&#xff0c;使用实例及注意事项&#xff0c;辅助类的封装及调用实例&#xff0c;可以直接移植到项目里面使用。 目录 1、添加引用 2、接口介绍 2.1、MySqlConnection 2.2、MySqlCommand 2.3、MySqlDataReader…

【Pikachu】File Inclusion文件包含实战

永远也不要忘记能够笑的坚强&#xff0c;就算受伤&#xff0c;我也从不彷徨。 1.File Inclusion(文件包含漏洞)概述 File Inclusion(文件包含漏洞)概述 文件包含&#xff0c;是一个功能。在各种开发语言中都提供了内置的文件包含函数&#xff0c;其可以使开发人员在一个代码…

计算机网络基本概念总结

IP地址 概念 使网络中的设备都有唯一的地址标识&#xff0c;用于表示其在网络中的位置。 格式 IP地址是一个32位的二进制数&#xff0c;通常被分割为4个8位二进制数&#xff08;也就是4个字节&#xff09;&#xff0c;如&#xff1a;01100100.00001000.00001010.00000110。通常…

CSS回顾-基础知识详解

一、引言 在前端开发领域&#xff0c;CSS 曾是构建网页视觉效果的关键&#xff0c;与 HTML、JavaScript 一起打造精彩的网络世界。但随着组件库的大量涌现&#xff0c;我们亲手书写 CSS 样式的情况越来越少&#xff0c;CSS 基础知识也逐渐被我们遗忘。 现在&#xff0c;这种遗…

RabbitMq项目实战--延迟队列实现超时订单处理

简单实现版 RabbitMq创建队列绑定交换机_rabbitmq 绑定交换机-CSDN博客 Configuration public class RabbitmqConfig {Value("${rabbitmq.exchange}")private String exchange;Value("${rabbitmq.host}")private String host;Value("${rabbitmq.por…

Vivado+Vscode联合打造verilog环境

一、Vivado下载安装 详细参考我另一篇文章&#xff1a; Vivado2022.2下载安装_fpga vivado下载-CSDN博客https://blog.csdn.net/weixin_61081689/article/details/143460790?spm1001.2014.3001.5501 二、Vscode下载安装 详细参考我另一篇文章&#xff1a; VscodeAnacond…