首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >QoS实现算法

QoS实现算法
EN

Software Engineering用户
提问于 2012-08-14 11:54:56
回答 1查看 1.2K关注 0票数 6

我正在开发一个应用程序,它可以实现IP路由和QoS。现在我们已经实现了QoS,它有3个优先级(低优先级、正常优先级和高优先级),并且为每个级别创建一个队列,一旦包排队,我们就以FIFO的方式发送它(调度器花费60%的时间处理高队列,30%的时间用于正常的时间,10%的时间用于低队列)。它可以工作,但是作为FIFO,它有一些缺点,比如:

  • 一个具有攻击性的流量将填充队列,所有具有相同优先级的其他流都将被塞进队列中。
  • 在高使用率下,TCP会慢下来,UDP会继续淹没我们的队列。这意味着最终UDP流将比TCP流具有更好的优先级。

我正在考虑一种改进它的方法,我的想法是用以下算法实现一个SFQ

  • 保持高,正常,低,但它们不只是3个队列,而是一个(见过)协议
  • 调度程序仍然将60%的时间用于处理高队列,30%的时间用于正常队列,10%的时间用于低队列。但是现在,它以同样的优先级在队列之间做了一个循环。选择的队列,仍将以FIFO方式转发数据包。

这种实现的缺点:

  • 它对CPU来说更昂贵。

我是不是遗漏了什么?有什么建议吗?

EN

回答 1

Software Engineering用户

发布于 2012-08-14 13:18:26

看看与长期相关的网络流量,例如本论文。如果这是您的问题,那么您就不能使用排队策略减少长期依赖的通信量。

票数 1
EN
页面原文内容由Software Engineering提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://softwareengineering.stackexchange.com/questions/160789

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档