码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • vpp hqos分析


    vpp支持两套qos实现,一套是基于policer实现的qos,另外一套是基于dpdk的qos套件实现的hqos。

    (免费订阅,永久学习)学习地址: Dpdk/网络协议栈/vpp/OvS/DDos/NFV/虚拟化/高性能专家-学习视频教程-腾讯课堂

    更多DPDK相关学习资料有需要的可以自行报名学习,免费订阅,永久学习,或点击这里加qun免费
    领取,关注我持续更新哦! ! 

    基本流程图

     

    如上图所示,worker线程从nic中读取报文进行处理,调用dpdk设备发送函数时,如果配置了hqos,那么设置hqos相关参数,将其送入swq队列(swq队列与worker线程是1:1的关系),worker线程处理结束,hqos线程(根据配置决定个数)轮询从swq中读取报文进行qos处理,qos使用的是dpdk qos套件。

    HQOS配置解析

    dpdk配置

    dpdk {
      socket-mem 16384,16384
    
      dev 0000:02:00.0 {
        num-rx-queues 2
        hqos #使能网卡hqos
      }
      dev 0000:06:00.0 {
        num-rx-queues 2
        hqos #使能网卡hqos
      }
    
      num-mbufs 1000000
    }

    cpu配置

    cpu {
      main-core 0
      corelist-workers  1, 2, 3, 4
      corelist-hqos-threads  5, 6  #启动两个hqos线程,分别使用cpu5和6
    }

    通过上面两步配置即可开启hqos配置,会使用默认的hqos配置。

    dpdk qos相关参数配置

    • port configuration
    port {
      rate 1250000000           /* Assuming 10GbE port */
      frame_overhead 24         /* Overhead fields per Ethernet frame:
                                 * 7B (Preamble) +
                                 * 1B (Start of Frame Delimiter (SFD)) + 
                                 * 4B (Frame Check Sequence (FCS)) +
                                 * 12B (Inter Frame Gap (IFG))
                                 */
      mtu 1522                  /* Assuming Ethernet/IPv4 pkt (FCS not included) */
      n_subports_per_port 1     /* Number of subports per output interface */
      n_pipes_per_subport 4096  /* Number of pipes (users/subscribers) */
      queue_sizes 64 64 64 64   /* Packet queue size for each traffic class.
                                 * All queues within the same pipe traffic class
                                 * have the same size. Queues from different
                                 * pipes serving the same traffic class have
                                 * the same size. */
    }
    • subport configuration
    subport 0 {
      tb_rate 1250000000        /* Subport level token bucket rate (bytes per second) */
      tb_size 1000000           /* Subport level token bucket size (bytes) */
      tc0_rate 1250000000       /* Subport level token bucket rate for traffic class 0 (bytes per s
  • 相关阅读:
    部署高校房屋管理系统可以实现哪些目标?
    ##51单片机实验之简易验证码发生器
    Java 项目防止 SQL 注入的四种方案
    操作系统第二章王道习题_进程与线程_总结易错知识点
    CentOS8编译安装curl 7.84.0
    辐射骚扰整改思路及方法:对共模电流的影响?|深圳比创达电子EMC
    ORA-55610: Invalid DDL statement on history-tracked table
    【P60】JMeter Jtl 文件的 html 格式输出
    SpringBoot前后端分离整合cas(客户端)
    linux系统查看bash的history
  • 原文地址:https://blog.csdn.net/lingshengxiyou/article/details/128114277
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号