Cake - FQ_codel the next generation
 help / color / mirror / Atom feed
From: Dendari Marini <dendari92@gmail.com>
To: Andy Furniss <adf.lists@gmail.com>
Cc: Sebastian Moeller <moeller0@gmx.de>, cake@lists.bufferbloat.net
Subject: Re: [Cake] Getting Cake to work better with Steam and similar applications
Date: Tue, 25 Apr 2017 13:24:20 +0200	[thread overview]
Message-ID: <CANCX+3NPN7B-CGe2SmBJw1qJn7cdK11XC0mrWYNoQ8yf0e9vng@mail.gmail.com> (raw)
In-Reply-To: <c3ea2c3b-298c-b23a-c52a-1454ae323d79@gmail.com>

[-- Attachment #1: Type: text/plain, Size: 3821 bytes --]

Hello,

I think the easiest and most robust way to shape ingress traffic for you
> would be to do it on the LAN side.
> If you have multiple interfaces facing LAN then use ifb.
> I've never used it myself, but to mark multiple address ranges the
> easiest way would be to use iptables with ipset - there will be many
> examples to be found on the internet.
> Even if you do mark (well set dscp cs1) for steam servers you will still
> need to be backed off from your ingress rate enough or it still won't
> work as the queue will build up too much on the ISP side of the
> bottleneck. Shaping ingress is quite different to doing egress as you
> are at the wrong end of the bottleneck.


In my case switch0 should work for the LAN, just wondering if setting cake
on both pppoe0 (for outbound traffic) and switch0 (fro inbound traffic) at
the same time should work without issues? Hmm, probably gonna try it and
see if it does. I'm gonna look up iptables and ipset and see what I can
find, thanks for the help.

Also I have done some more testing, I was able to limit Steam connections
just to one thanks to some console commands ("@cMaxContentServersToRequest"
and "@cCSClientMaxNumSocketsPerHost") and while the situation improved (no
more packet loss, latency variation within 10ms, but still seeing ping
spikes of ~50ms) it's still not what I'd consider ideal, which would be
like with any other download. So my guess is there's something else going
on other than just the multiple connections, which are definitely big part
of the problem but not the only thing.

Anyway these are my current settings for Cake and I've been using them for
the last four days without issues:

*qdisc cake 8005: root refcnt 2 bandwidth 950Kbit diffserv3 triple-isolate
nat wash rtt 100.0ms atm overhead 40 via-ethernet*
*qdisc cake 8006: root refcnt 2 bandwidth 17500Kbit diffserv3
triple-isolate nat wash ingress rtt 100.0ms atm overhead 40 via-ethernet*

I will try Andy's suggestions and see what I can do.

@Sebastian No problem, I tested your updated script and it is indeed
reporting overhead 40.

On 25 April 2017 at 12:26, Andy Furniss <adf.lists@gmail.com> wrote:

> Dendari Marini wrote:
>
> FWIW here's a quick example on ingress ppp that I tested using
>>> connmark the connmarks (1 or 2 or unmarked) being set by iptables
>>> rules on outbound connections/traffic classes.
>>>
>>
>>
>> Unfortunately I'm really not sure how to apply those settings to my
>> case, it's something I've never done so some hand-holding is probably
>> needed, sorry. At the moment I've limited the Steam bandwidth using
>> the built-in Basic Queue and DPI features from the ER-X. They're easy
>> to set up but aren't really ideal, would rather prefer Cake would
>> take care about it more dynamically.
>>
>> Anyway about the Steam IP addresses I've noticed, in the almost three
>> weeks of testing, they're almost always the same IP blocks (most of
>> which can be found on the Steam Support website,
>> https://support.steampowered.com/kb_article.php?ref=8571-GLVN-8711).
>> I believe it would be a good starting point for limiting Steam, what
>> do you think?
>>
>
> I think the easiest and most robust way to shape ingress traffic for you
> would be to do it on the LAN side.
> If you have multiple interfaces facing LAN then use ifb.
> I've never used it myself, but to mark multiple address ranges the
> easiest way would be to use iptables with ipset - there will be many
> examples to be found on the internet.
> Even if you do mark (well set dscp cs1) for steam servers you will still
> need to be backed off from your ingress rate enough or it still won't
> work as the queue will build up too much on the ISP side of the
> bottleneck. Shaping ingress is quite different to doing egress as you
> are at the wrong end of the bottleneck.
>

[-- Attachment #2: Type: text/html, Size: 5409 bytes --]

  reply	other threads:[~2017-04-25 11:24 UTC|newest]

Thread overview: 63+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-04-20 13:39 Dendari Marini
2017-04-20 13:43 ` Sebastian Moeller
2017-04-20 15:23   ` Dendari Marini
2017-04-20 15:32     ` Jonathan Morton
2017-04-20 16:05       ` Dendari Marini
2017-04-20 17:12         ` Andy Furniss
2017-04-20 17:36         ` Jonathan Morton
2017-04-20 18:35         ` Sebastian Moeller
2017-04-20 18:36         ` Sebastian Moeller
2017-04-21  8:34           ` Dendari Marini
2017-04-21 13:25             ` Sebastian Moeller
2017-04-21 13:27             ` Dendari Marini
2017-04-22  8:25               ` Dendari Marini
2017-04-22  9:36                 ` Jonathan Morton
2017-04-22 12:50                   ` xnoreq
2017-04-22 13:41                   ` Tristan Seligmann
2017-04-22 13:51                   ` Andy Furniss
2017-04-22 14:03                     ` Andy Furniss
2017-04-22 16:38                       ` Andy Furniss
2017-04-22 16:45                         ` Dave Taht
2017-04-22 17:00                           ` Tristan Seligmann
2017-04-22 20:24                         ` Andy Furniss
2017-04-22 16:47                   ` Sebastian Moeller
2017-04-22 21:56                     ` Dendari Marini
2017-04-22 22:15                       ` Sebastian Moeller
2017-04-23 12:32                         ` David Lang
2017-04-24  7:55                           ` Sebastian Moeller
2017-04-24  8:41                             ` Dendari Marini
2017-04-24 11:34                               ` Sebastian Moeller
2017-04-24 12:08                                 ` Dendari Marini
2017-04-24 12:35                                   ` Sebastian Moeller
2017-04-24 13:49                                     ` Dendari Marini
2017-04-24 15:42                                       ` Sebastian Moeller
2017-04-24 17:32                                       ` Sebastian Moeller
2017-04-25 10:26                               ` Andy Furniss
2017-04-25 11:24                                 ` Dendari Marini [this message]
2017-04-25 12:58                                   ` Andy Furniss
2017-04-25 18:22                                     ` Dendari Marini
2017-04-25 19:10                                       ` Jonathan Morton
2017-04-25 20:44                                         ` Dendari Marini
2017-04-25 21:32                                           ` Andy Furniss
2017-04-25 22:33                                           ` Benjamin Cronce
2017-04-28 15:37                                             ` Dendari Marini
2017-04-29 15:11                                               ` Andy Furniss
2017-04-29 17:30                                                 ` Jonathan Morton
2017-04-29 18:29                                                   ` Andy Furniss
2017-04-30  0:05                                                     ` Andy Furniss
2017-05-01  5:50                                                       ` Jonathan Morton
2017-05-01 11:32                                               ` Andy Furniss
2017-05-01 12:08                                                 ` Jonathan Morton
2017-05-01 13:03                                                   ` Andy Furniss
2017-05-01 13:11                                                     ` Jonathan Morton
2017-05-01 14:46                                                       ` Andy Furniss
2017-04-25 21:06                                         ` Andy Furniss
2017-04-25 21:16                                           ` Neil Shepperd
2017-04-25 21:37                                             ` Andy Furniss
2017-04-25 21:43                                     ` Sebastian Moeller
2017-04-25 22:06                                       ` Andy Furniss
2017-04-25 22:29                                         ` Andy Furniss
2017-04-25 22:32                                           ` Andy Furniss
2017-04-22 22:35                       ` Andy Furniss
2017-04-22 14:12                 ` Sebastian Moeller
2017-04-20 18:16     ` Sebastian Moeller

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://lists.bufferbloat.net/postorius/lists/cake.lists.bufferbloat.net/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=CANCX+3NPN7B-CGe2SmBJw1qJn7cdK11XC0mrWYNoQ8yf0e9vng@mail.gmail.com \
    --to=dendari92@gmail.com \
    --cc=adf.lists@gmail.com \
    --cc=cake@lists.bufferbloat.net \
    --cc=moeller0@gmx.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox