Netgate Discussion Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Search
    • Register
    • Login

    CoDel - How to use

    Scheduled Pinned Locked Moved Traffic Shaping
    206 Posts 30 Posters 134.6k Views 1 Watching
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • DerelictD Offline
      Derelict LAYER 8 Netgate
      last edited by

      You have to pay for support.

      I see you were unsatisfied with the answers here and have now gone to the mailing list too.

      Do you really want someone to spend their time rewriting the bufferbloat.net site just for you.

      You just enable codel.  That's it.  What's so hard to understand?

      Chattanooga, Tennessee, USA
      A comprehensive network diagram is worth 10,000 words and 15 conference calls.
      DO NOT set a source address/port in a port forward or firewall rule unless you KNOW you need it!
      Do Not Chat For Help! NO_WAN_EGRESS(TM)

      1 Reply Last reply Reply Quote 0
      • W Offline
        webdawg
        last edited by

        The only reason that I am perusing the issue is because there are conflicting views of how the webui implements the settings put in along with it.  I see when I do implement it that it only enables one scheduler so I will have to assume that putting anything in along with the codel setting for the traffic shaper for just an interface does nothing.

        Just because bufferbloat says that it is parameterless does not mean that the parameters do nothing in the pfsense webui.

        This is the only question I have. If it follows what bufferbloat says then nothing on a Traffic Shaper interface page should matter if I select CoDel.

        I suppose instead of asking in this forum, irc, and a mailing list I will just look at the web form code and dig into it myself.

        Thanks for the help, but even this forum post shows people are confused on how it works in pfsense.

        The point is, I have to assume.  I have spent many hours asking around if anyone knows how that single page works because I did not assume that it works someway.

        Maybe I should get a gold subscription but you know what:  The guide does not say much about it either.

        1 Reply Last reply Reply Quote 0
        • D Offline
          doktornotor Banned
          last edited by

          OMG.

          1/ Go to Firewall - Traffic Shaper - By Interface
          2/ Click your WAN
          3/ Check Enable/disable discipline and its children, select CODELQ from Scheduler Type dropdown.
          4/ Click Save.
          5/ Click Apply.

          What guide you need for this?

          1 Reply Last reply Reply Quote 0
          • H Offline
            Harvy66
            last edited by

            He's talking about it is of my opinion that CoDel won't be as effective if you don't set your interface bandwidth. It is logically impossible for CoDel or other forms of traffic shaping or queue management to work without having some means of knowing how quickly the queue should be drained. This is easy for a synchronous interface like plugging a 1Gb WAN into a 1Gb internet connection, but it is not so simple when you plug a 1Gb wan into a 30Mb internet connection. If your upstream does something like sending back pause frames, the WAN port can know to back off, allowing packets to buffer and CoDel to do its magic. Pause frames still mean that buffering is happening on the receiving interface, which is not desirable because you cannot control buffers in other systems.

            CoDel doesn't need to know the bandwidth because it's the interface's job to know how fast it's allowed to dequeue. CoDel just monitors the delays on the packets. Without something to limit CoDel, it will dequeue at full interface rate.

            1 Reply Last reply Reply Quote 1
            • D Offline
              doktornotor Banned
              last edited by

              This thing is "no knobs" by design. https://tools.ietf.org/html/draft-ietf-aqm-codel-00#section-4.2

              1 Reply Last reply Reply Quote 0
              • H Offline
                Harvy66
                last edited by

                But many think "no knobs" or needing to tell CoDel about your bandwidth means you don't need to rate limit your interface so your interface doesn't attempt to dequeue packets at line rate. CoDel tells your interface which packet to dequeue next, not how fast to dequeue them.

                1 Reply Last reply Reply Quote 1
                • T Offline
                  tuffcalc
                  last edited by

                  @Harvy66:

                  But many think "no knobs" or needing to tell CoDel about your bandwidth means you don't need to rate limit your interface so your interface doesn't attempt to dequeue packets at line rate. CoDel tells your interface which packet to dequeue next, not how fast to dequeue them.

                  I'm using CoDel and see no difference setting my line rate or leaving it blank.  On a 30/5 Mbps connection.  Love it so far, even with VoIP.

                  1 Reply Last reply Reply Quote 0
                  • H Offline
                    Harvy66
                    last edited by

                    What happens when you completely max out your upload? If CoDel is fully working, your latency should barely budge, maybe an increase of 10-15 ms, but minor packet loss.

                    1 Reply Last reply Reply Quote 0
                    • T Offline
                      tuffcalc
                      last edited by

                      @Harvy66:

                      What happens when you completely max out your upload? If CoDel is fully working, your latency should barely budge, maybe an increase of 10-15 ms, but minor packet loss.

                      That's exactly what is happening.

                      My main issue was maxing out my download connection (newsgroups) causing latency on my home network.  Now it doesn't matter how bad I saturate upload/download, VoIP works and web browsing (latency) is snappy.  Very impressed.

                      1 Reply Last reply Reply Quote 0
                      • DerelictD Offline
                        Derelict LAYER 8 Netgate
                        last edited by

                        Strange since codel works on the sending interface.  Hard to believe your bottleneck was LAN, but glad it's working for you.

                        Chattanooga, Tennessee, USA
                        A comprehensive network diagram is worth 10,000 words and 15 conference calls.
                        DO NOT set a source address/port in a port forward or firewall rule unless you KNOW you need it!
                        Do Not Chat For Help! NO_WAN_EGRESS(TM)

                        1 Reply Last reply Reply Quote 0
                        • S Offline
                          switchman
                          last edited by

                          You apply codel to both lan and wan.  That way it shapes traffic both directions.  Even though logic says that if the packet has already made it to you, you should keep it.  But if you drop it, that causes a resend which in turn causes the remote end to slow down the sending which then allows packets from other flows to traverse the queue faster.

                          Admittedly, as the lan is typically faster than the wan, there should not be any slow down or drops.  But I applied codel to both lan and wan.

                          1 Reply Last reply Reply Quote 0
                          • T Offline
                            tuffcalc
                            last edited by

                            @Derelict:

                            Strange since codel works on the sending interface.  Hard to believe your bottleneck was LAN, but glad it's working for you.

                            The heavy downloading (30 simultaneous newsgroup connections) lagged my home network web browsing likely because of the uplink ack packets it needed to send to sustain the speed.

                            In any event, I've enabled codel on both my wan/lan and it has totally changed the experience.

                            1 Reply Last reply Reply Quote 0
                            • S Offline
                              switchman
                              last edited by

                              @ tuffcalc,

                              You might want to drop the number of newsgroup connections in half.  Depending on you newsgroup provider, they may be able to fill a smaller number of streams at a higher rate.

                              1 Reply Last reply Reply Quote 0
                              • T Offline
                                tuffcalc
                                last edited by

                                @switchman:

                                You apply codel to both lan and wan.  That way it shapes traffic both directions.  Even though logic says that if the packet has already made it to you, you should keep it.  But if you drop it, that causes a resend which in turn causes the remote end to slow down the sending which then allows packets from other flows to traverse the queue faster.

                                Admittedly, as the lan is typically faster than the wan, there should not be any slow down or drops.  But I applied codel to both lan and wan.

                                I turned codel off on the LAN side and notice no difference.

                                I'm running an SG300-50P switch with 3 Engenius EAP1750 AP's for wireless clients, so admittedly a pretty fast LAN.  I'm just going to leave it off for the LAN side - intuitively it makes more sense to me.

                                1 Reply Last reply Reply Quote 0
                                • DerelictD Offline
                                  Derelict LAYER 8 Netgate
                                  last edited by

                                  I removed all my shapers and applied only codel.  My downloads were as fast as I've ever seen them and simultaneous pings to my ISP's first hop were unaffected.  Uploads, however, resulted in ping latency going from about 12ms to about 175ms.  HFSC completely cures that at the expense of a little top-end speed.  I did leave the codel checkboxes checked on all my queues though.

                                  Chattanooga, Tennessee, USA
                                  A comprehensive network diagram is worth 10,000 words and 15 conference calls.
                                  DO NOT set a source address/port in a port forward or firewall rule unless you KNOW you need it!
                                  Do Not Chat For Help! NO_WAN_EGRESS(TM)

                                  1 Reply Last reply Reply Quote 0
                                  • H Offline
                                    Harvy66
                                    last edited by

                                    @tuffcalc:

                                    @Derelict:

                                    Strange since codel works on the sending interface.  Hard to believe your bottleneck was LAN, but glad it's working for you.

                                    The heavy downloading (30 simultaneous newsgroup connections) lagged my home network web browsing likely because of the uplink ack packets it needed to send to sustain the speed.

                                    In any event, I've enabled codel on both my wan/lan and it has totally changed the experience.

                                    I don't doubt that it has helped, but I wonder by how much in actual numbers. If you could find an IP that returns table pings, get maybe 30 seconds of samples, then start downloading and get another 30 seconds of samples.

                                    Unfortunately, I cannot do any sort of tests on my network because my ISP has designed their network to have no buffer bloat and stable bandwidth. If I had my old ISP, I could have done such tests. While they were pretty good, they had classical issues of buffer bloat and bandwidth could briefly drop upwards of 30% during peak hours. Nothing horrible, but not "perfect".

                                    I recently watched an interview from one of the CoDel people showing a reduced number of pause frames when using CoDel, but unfortunately did not show his exact network setup or where CoDel was applied, so I made some assumptions that sound as if they are a bit incorrect. The difference between theory and practice, implementation details. Perhaps pause frames are sent some time prior to full buffer.

                                    Thanks for everyone helping to fix some of my false assumptions. There is obviously something more at play that I am missing. I love learning and I apologize for spreading somewhat false information.

                                    1 Reply Last reply Reply Quote 0
                                    • DerelictD Offline
                                      Derelict LAYER 8 Netgate
                                      last edited by

                                      I use some stuff out of a youtube video.

                                      You run one process that pings 5 per second and outputs to a file.

                                      You run another that plots it with gnuplot.

                                      The video (which includes the very short scripts) is here:  https://www.youtube.com/watch?v=EfXImr5q-sw

                                      ![Screen Shot 2015-02-07 at 10.44.39 AM.png](/public/imported_attachments/1/Screen Shot 2015-02-07 at 10.44.39 AM.png)
                                      ![Screen Shot 2015-02-07 at 10.44.39 AM.png_thumb](/public/imported_attachments/1/Screen Shot 2015-02-07 at 10.44.39 AM.png_thumb)

                                      Chattanooga, Tennessee, USA
                                      A comprehensive network diagram is worth 10,000 words and 15 conference calls.
                                      DO NOT set a source address/port in a port forward or firewall rule unless you KNOW you need it!
                                      Do Not Chat For Help! NO_WAN_EGRESS(TM)

                                      1 Reply Last reply Reply Quote 0
                                      • H Offline
                                        Harvy66
                                        last edited by

                                        I wonder if my ISP uses fq_CoDel. This was taken during my recent issue with BitTorrent flooding my connection with up to 103Mb/s, yet my average was 98.6Mb/s as reported by RRD.

                                        Even then, my pings remained low. I cannot think of a way that my pings could remain so low while still maintaining large enough buffers to be practical. Packet loss indicates a full buffer, yet the pings do not reflect such a thing. fq_CoDel is the only algorithm that comes to mind. It was not this way prior to their recent upgrades. Packet loss was typically accompanied by latency, albeit 10-20ms.


                                        edit: Seems Cisco used the idea of CoDel and made PIE. Both are similar. Cisco even has fq_PIE. I assume this is why I see stable latency from my ISP.

                                        1 Reply Last reply Reply Quote 0
                                        • H Offline
                                          Harvy66
                                          last edited by

                                          @Derelict:

                                          I removed all my shapers and applied only codel.  My downloads were as fast as I've ever seen them and simultaneous pings to my ISP's first hop were unaffected.  Uploads, however, resulted in ping latency going from about 12ms to about 175ms.  HFSC completely cures that at the expense of a little top-end speed.  I did leave the codel checkboxes checked on all my queues though.

                                          While not perfect, it seems CoDel and make things a lot better without any configuration. I would love to see this same test with fq_codel, if we remember by then.  ;D

                                          1 Reply Last reply Reply Quote 0
                                          • W Offline
                                            webdawg
                                            last edited by

                                            @Harvy66:

                                            He's talking about it is of my opinion that CoDel won't be as effective if you don't set your interface bandwidth. It is logically impossible for CoDel or other forms of traffic shaping or queue management to work without having some means of knowing how quickly the queue should be drained. This is easy for a synchronous interface like plugging a 1Gb WAN into a 1Gb internet connection, but it is not so simple when you plug a 1Gb wan into a 30Mb internet connection. If your upstream does something like sending back pause frames, the WAN port can know to back off, allowing packets to buffer and CoDel to do its magic. Pause frames still mean that buffering is happening on the receiving interface, which is not desirable because you cannot control buffers in other systems.

                                            CoDel doesn't need to know the bandwidth because it's the interface's job to know how fast it's allowed to dequeue. CoDel just monitors the delays on the packets. Without something to limit CoDel, it will dequeue at full interface rate.

                                            I just wondered if inputing a number in the Bandwidth box would actually do anything because CoDel is knobless.  It does do something.  It does limit the connection.  (I tested it by limiting my connection severely)  The only reason I wondered if this knob/setting would work is because everything describes CoDel as knobless.  But I also understood that it was an evolution of RED.  RED having all the settings it did I could see that knobless in relation to CoDel ment, no settings but still takes a Bandwidth setting.

                                            This has, at least, turned into an interesting post with all these result studies.  I may mirror some of the methods and post my results just to compare.

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post
                                            Copyright 2025 Rubicon Communications LLC (Netgate). All rights reserved.