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

    Playing with fq_codel in 2.4

    Scheduled Pinned Locked Moved Traffic Shaping
    1.1k Posts 123 Posters 1.9m Views 74 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.
    • R Offline
      Ricardox @mikekoke
      last edited by Ricardox

      @mikekoke Follow this tutorial that works great!Imagem-2.jpg Imagem-1.jpg

      1 Reply Last reply Reply Quote 0
      • F Offline
        fiddlybytes @mikekoke
        last edited by fiddlybytes

        @mikekoke

        Have you tried changing the quantum to < 536 or 300?, I have had better success at these packet size quantums.
        Albeit TCP suffers a bit with a 300 quantum.

        Also had more success with fq_pie with 300 quantum.

        @ dev - fq_pie needs an area in the gui to change the quantum ,pls .

        I also run fq_pie lan parents for voip and gaming with greater weights given to the udp in addition to the wan
        pipes.

        I still cant figure out why pfsense wont perform as well with udp packets as a linux router does with QOS/cake on
        without quantum changes ?.

        Edit ;
        In testing I have found layer 3 tunnel,gre or openvpn works much better and avoids the tcp overhead,you wont notice as much fluctuation,even with the wan pipes setup as standard for voip and udp games.During full saturation of the pipe the voip and game jitter hardly varies from a no tcp load scenario. This shoudlnt have to be done but works better than cake,pie or fq_codel.

        Note ;If you try the openvpn method you will need to change the nat and firewall rules for udp to point through the vpn gateway.

        1 Reply Last reply Reply Quote 0
        • timtraceT Offline
          timtrace @uptownVagrant
          last edited by timtrace

          Assume that I've correctly implemented everything in @uptownVagrant's post #815. It works (splendidly). Thanks for the good instructions, man.

          Then, because I have a second physical WAN interface and public IP for my captive portal (working perfectly for several months), let's say I do everything again in parallel - unique limiters, unique queues, and unique rules #3 & 4, setting rule #4's gateway to the captive portal WAN interface.

          The LAN still works, but when tested, the captive portal won't do more than 1/4 of the available upload bandwidth.

          Anyone feel like helping a brother out with a W.A.G. as to why this might be happening?

          1 Reply Last reply Reply Quote 0
          • O Offline
            OffstageRoller
            last edited by OffstageRoller

            Thank you so much to everyone in this thread who has helped in testing, and especially to @uptownVagrant for putting in as much time as they have to help the all of us. This has been working well on my network and I'm very much appreciate this massive thread.

            I would like to take this one step further and tie this into bandwidth limits for certain VLAN's of mine. Specifically, I'd like to limit bandwidth in both my IoT network and my guest network.

            In an ideal scenario, this FQ CoDel rule would cover the entire WAN interface including the Guest and IoT VLAN (which it already does), but then I can set a second child limiter that only limits the bandwidth for specific interfaces. This way there's a single up queue and a single down queue for the entire WAN, but certain VLAN's have an additional restriction on their bandwidth.

            What would be the best way to have a single queue as discussed here, but also have bandwidth limits on specific interfaces/VLAN's?

            1 Reply Last reply Reply Quote 0
            • Q Offline
              q54e3w
              last edited by q54e3w

              Ive noticed my internally hosted services (matrix synapse, seafile etc) that sit behind Traffic reverse proxy have stopped working since implementing traffic shaping as per the recommendations in this thread.
              I narrowed the cause down to the application of queues to my inbound WAN port forwards
              Clients connecting inbound via Cloudflare report a '522' error (unable to reach the origin web server and the request times out).
              I've checked the in/out limiters are applied to the relevant in/out pipe and they appear correct, as in a mirror of the regular outbound rules on internal subnets
              The only noticeable difference is my firewall rule is applied on the WAN interface, not the floating rules as per @uptownVagrant
              Would be happy to receive guidance on how to debug this issue.

              EDIT: With no limiters applied I see traffic hitting my Traefik proxy

              176.126.xxx.xxx - - [28/May/2020:14:07:06 +0000] "PUT /_matrix/federation/v1/send/159066 HTTP/1.1" 200 12 "-" "-" 33895 "matrix@file" "http://192.168.90.20:80" 19ms
              

              with limiters applied, these accesses aren't visible so it appears that pfSense isn't actually forwarding the request.

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

                Following the steps below I have a question!

                1. Whats the difference between Queue Management Algorithm = Tail Drop vs CoDel?
                2. Even though on the limiter with "Tail Drop" its allowed to have active ECN. On the queue with Tail Drop its not allowed to use ECN. Is generally Tail Drop better? With or without ENC? I could not find anything in the pfsense book.

                Thanks!

                1.) Create "Out" limiter
                
                Tick "Enable"
                Name: FQ_CODEL_OUT
                Bandwidth: 96907 Kbit/s
                Mask: None
                Queue Management Algorithm: Tail Drop
                Scheduler: FQ_CODEL
                target: 5
                interval: 100
                quantum: 300
                limit: 10240
                flows: 20480 
                Click Save/Apply Changes
                2.) Add "Out" queue
                
                Tick "Enable"
                Name: fq_codel_out_q
                Mask: None
                Queue Management Algorithm: Tail Drop
                Click Save/Apply Changes
                3.) Create "In" limiter
                
                Tick "Enable"
                Name: FQ_CODEL_IN
                Bandwidth: 83886 Kbit/s
                Mask: None
                Queue Management Algorithm: Tail Drop
                Scheduler: FQ_CODEL
                target: 5
                interval: 100
                quantum: 300
                limit: 10240
                flows: 20480 
                Click Save/Apply Changes
                4.) Add "In" queue
                
                Tick "Enable"
                Name: fq_codel_in_q
                Mask: None
                Queue Management Algorithm: Tail Drop
                Click Save/Apply Changes
                
                provelsP 1 Reply Last reply Reply Quote 0
                • provelsP Offline
                  provels @daemonix
                  last edited by

                  @daemonix I don't really know but I tried both and neither helped me any so I gave up. So just try and test and try again.

                  Peder

                  MAIN - pfSense+ 25.07.1-RELEASE - Adlink MXE-5401, i7, 16 GB RAM, 64 GB SSD. 500 GB HDD for SyslogNG
                  BACKUP - pfSense+ 23.01-RELEASE - Hyper-V Virtual Machine, Gen 1, 2 v-CPUs, 3 GB RAM, 8GB VHDX (Dynamic)

                  D 1 Reply Last reply Reply Quote 0
                  • D Offline
                    daemonix @provels
                    last edited by daemonix

                    @provels for me tail drop seems to give me stable low RRT.... CoDel is a bit erratic... this is weird as reading this paper makes me think different. Evaluation of the Impact of Packet Drops due to AQM over Capacity Limited Paths

                    Any ideas from the experts?

                    B 1 Reply Last reply Reply Quote 0
                    • B Offline
                      bobbenheim @daemonix
                      last edited by

                      @daemonix that paper has no relation to queue management with fq-codel in Pfsense, it compares different algorithms.
                      I have no clue what codel does if chosen as queue management under fq-codel, but i would just use drop tail as that is how fq-codel should react when latency increases, i.e. it should drop packets in large queues to keep latency low.

                      D 1 Reply Last reply Reply Quote 1
                      • D Offline
                        daemonix @bobbenheim
                        last edited by

                        @bobbenheim fair enough :) that indeed keeps the RRT from moving... so Im happy :)

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

                          is there a reason why a basic fq_codel is behaving perfect with 20 parallel iperf uploads another 20 down (all together)... but then a "speedtest.net" test or google test sends the RTT up?!
                          Or a full torrent ubuntu alternative. Full download... no problem.

                          Is like some packets dont follow the rules...

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

                            Hi, I have the floating rule and quick but Im getting problems with traceroute from Lan (not from the pfsense box). Am I missing something in my rules?!

                            5f123352-ab82-41cc-89ba-561290f487e1-Screenshot 2020-06-13 09.27.31.png

                            traceroute www.ntua.gr
                            traceroute to www.ntua.gr (147.102.224.101), 64 hops max, 52 byte packets
                             1  XX (X)  4.054 ms  1.243 ms  1.275 ms
                             2  www.ntua.gr (147.102.224.101)  8.807 ms  9.811 ms  10.076 ms
                             3  www.ntua.gr (147.102.224.101)  15.286 ms  9.946 ms  9.692 ms
                             4  * * *
                             5  www.ntua.gr (147.102.224.101)  14.548 ms  13.996 ms  13.006 ms
                             6  www.ntua.gr (147.102.224.101)  13.220 ms  15.703 ms  13.044 ms
                             7  * www.ntua.gr (147.102.224.101)  45.182 ms  43.441 ms
                             8  www.ntua.gr (147.102.224.101)  44.675 ms  44.498 ms  47.619 ms
                            
                            B uptownVagrantU 2 Replies Last reply Reply Quote 0
                            • B Offline
                              bobbenheim @daemonix
                              last edited by

                              @daemonix what settings have you made within the floating rule?

                              D 1 Reply Last reply Reply Quote 0
                              • uptownVagrantU Offline
                                uptownVagrant @daemonix
                                last edited by

                                @daemonix keep in mind that the traceroute program is likely using UDP unless you are instructing it to use ICMP.

                                1 Reply Last reply Reply Quote 0
                                • D Offline
                                  daemonix @bobbenheim
                                  last edited by

                                  @bobbenheim @uptownVagrant

                                  I updated the rule to take all ICMP. I dont have any block rule for UDP or TCP from LAN.
                                  One thing I see in my WAN CODEL IN/OUT rule is that is "matching" very little numbers of packages or data. On the LAN site the main pass rule has gigabytes.
                                  Maybe my problems start elsewhere?

                                  Are floating matching rules for CODEL mirroring the LAN stats?

                                  Screenshot 2020-06-15 10.21.47.png

                                  B 1 Reply Last reply Reply Quote 0
                                  • B Offline
                                    bobbenheim @daemonix
                                    last edited by

                                    @daemonix have you set anything under in/out pipe in advanced options within your ICMP rule?

                                    D 1 Reply Last reply Reply Quote 0
                                    • D Offline
                                      daemonix @bobbenheim
                                      last edited by

                                      @bobbenheim no no, only the gateway as I have a VPN out for some clients.

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

                                        I read this thread and still I am not sure if floating rule for limiters shoud be "quick pass" or "match". Could someone explain which one is correct or if there is difference in use? Thanks

                                        B 1 Reply Last reply Reply Quote 0
                                        • B Offline
                                          bobbenheim @sikita
                                          last edited by

                                          @sikita pass rule is first match wins, match rules is last match wins, other than that you get the same result with both if setup correctly :)

                                          1 Reply Last reply Reply Quote 1
                                          • D Offline
                                            daemonix
                                            last edited by

                                            the weird thing is that with huge uploads or download (and torrents, iperf, rsync... for example) everything seems ok. RTT etc.

                                            When Mac/Apple processes try to upload photos for example... then RTT goes way up. As if some packets dont go through the pipe.

                                            How can I debug it better?

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