首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何区分QoS在OpenWRT (和其他系统)中的SSH和SCP?

如何区分QoS在OpenWRT (和其他系统)中的SSH和SCP?
EN

Unix & Linux用户
提问于 2015-06-26 23:05:20
回答 1查看 2.9K关注 0票数 2

我经常通过我的DSL上行连接上传大量数据,该连接限制在1kbit/s。虽然我真的希望交互式SSH会话具有最高的优先级,但简单地将SSH设置为最高优先级会使SCP上传过程中的连接无法使用。

如何区分SSH和SCP的服务质量设置,特别是在OpenWRT中?

EN

回答 1

Unix & Linux用户

回答已采纳

发布于 2015-06-26 23:05:20

至少OpenSSH设置不同的TOS位(0x16用于交互会话,0x08用于批量传输),如浅谈quora

使用匹配这些位的规则可以很容易地利用这一点。似乎最高匹配的QoS生效了,请确保在端口22/SSH周围没有一个通用规则: OpenWRT默认将匹配SSH和DNS的规则一起发布。对于这里的规则,我使用了上面链接的quora中提出的0x040x02的重叠DSCP值。

代码语言:javascript
运行
复制
config classify                                          
        option target           "Priority"                   
        option ports            "22"                     
        option dscp             0x04                     
        option comment          "ssh"      
config classify                                          
        option target           "Bulk"                   
        option ports            "22"                     
        option dscp             0x02                     
        option comment          "scp"                    

对于“裸”iptables设置,这些规则( -m dscp --dscp 0x04-m dscp --dscp 0x02参数是最有趣的部分):

代码语言:javascript
运行
复制
-A qos_Default_ct -p tcp -m mark --mark 0x0/0xf -m tcp -m multiport --ports 22 -m dscp --dscp 0x04 -m comment --comment ssh -j MARK --set-xmark 0x11/0xff
-A qos_Default_ct -p tcp -m mark --mark 0x0/0xf -m tcp -m multiport --ports 22 -m dscp --dscp 0x02 -m comment --comment scp -j MARK --set-xmark 0x44/0xff

确保在使用QoS __重新加载/etc/init.d/qos restart设置后重新启动SCP传输。QoS设置仅应用于新的流。

在应用这些规则之前(使用一个SSH“优先级”规则),在SCP上载期间,我的ping值约为200 an;在应用该规则时,它下降到了70-100 an(相比之下,通过空闲行的时间为30 an)。

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

https://unix.stackexchange.com/questions/212503

复制
相关文章

相似问题

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