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.
    • mattundM Offline
      mattund @mattund
      last edited by mattund

      @mattund said in Playing with fq_codel in 2.4:

      I'm testing my patch, and I am seeing some unexpected behavior (maybe intentional).

      This stopped happening as soon as I enabled masks on the offending download queue correlating to the one ICMP traffic was being dropped on. Not sure why.

      1 Reply Last reply Reply Quote 0
      • C Offline
        cplmayo @mattund
        last edited by

        @mattund said in Playing with fq_codel in 2.4:

        @slowgrind said in Playing with fq_codel in 2.4:

        So after applying the patch do you just fill in the settings under limiters?

        Here's what I'm doing. This might be a little more than what you need, but I figure I would share my configuration in case others have a crazy Multi-WAN multi-LAN setup like I do. I've constructed a series of limiters, one for download and one for upload, each with its own associated queue (you can make the queue with the "+ Add new Queue" button on the bottom of a Limiter's settings page) :
        0_1529000895837_s1.PNG

        (I have more for my second ISP following that naming scheme: lINTERFACEDownload/lINTERFACEUpload and qINTRERFACEDownload/qINTERFACEUpload children)

        I'm assigning FQ_CoDel to the scheduler on the parent limiter and leaving everything else alone. You can either edit the parameters, or leave them at default if you have a typical connection (FQ_CoDel is supposed to be "knobless" after all).

        According to the following diagram, this is how the traffic will flow inside dummynet:

        			    (flow_mask|sched_mask)  sched_mask
        		    +---------+	  weight Wx  +-------------+
        		    |	      |->-[flow]-->--|		   |-+
        	       -->--| QUEUE x |	  ...	     |		   | |
        		    |	      |->-[flow]-->--| SCHEDuler N | |
        		    +---------+		     |		   | |
        			...		     |		   +--[LINK N]-->--
        		    +---------+	  weight Wy  |		   | +--[LINK N]-->--
        		    |	      |->-[flow]-->--|		   | |
        	       -->--| QUEUE y |	  ...	     |		   | |
        		    |	      |->-[flow]-->--|		   | |
        		    +---------+		     +-------------+ |
        					       +-------------+
        

        via: https://www.freebsd.org/cgi/man.cgi?query=ipfw&manpath=FreeBSD+9-current&format=html

        Dissection: firewall traffic is assigned to a queue, which then generates flows defined by the mask, which pipe into the scheduler (set to FQ_CoDel), which then outputs to the pipe/link at the specified max bitrate.

        To assign your traffic to queues, you could do something like I did, which is to use floating rules. I have two WANs, and I need independent shaping and all that, so if you're on a single WAN it may be different for you/you may have better options.

        0_1529001614927_s4.PNG

        How I set the rules up:

        • Interface: WAN A or B interface
        • Direction: out
        • Address Family: IPv4 or IPv6; I had to do two rules, one for each IP version
        • Gateway: Select the applicable IPv4 or IPv6 gateway consistent with how traffic should be routed on that IP stack
        • In / Out pipe: qCHARTERUpload / qCHARTERDownload

        I have some filtering rules in play here as you can see in my screenshot, but that's only since I'm testing some issues I mentioned previously. It's up to you if you want to match certain protocols/ports, etc.

        When I setup my floating rules I tried using the out direction a few times but have run into problems each and every time.

        For instance if I set the rule direction to "out" and then set the gateway I get what appears to be a routing loop. Traffic forwards find and I can hit external hosts however when I do a traceroute from an internal host I don't see the hop routers I just see the destination IP over and over. Are you seeing this or have you changed your setup?

        I have also been considering using the dynamic pipes. Anyone tried this with the fq_codel scheduler?

        mattundM 1 Reply Last reply Reply Quote 1
        • mattundM Offline
          mattund @cplmayo
          last edited by

          @cplmayo I also get a routing loop in traceroutes. Are you using the in direction?

          C 1 Reply Last reply Reply Quote 0
          • C Offline
            cplmayo @mattund
            last edited by cplmayo

            @mattund I have been, I would prefer to use out but it makes any troubleshooting I may need to do difficult. Not that I do traceroutes a lot but it annoyed me.

            I have wondered if this was due to how the rule is creating states. Like it is rerouting the packet once the rule is applied; very weird.

            There are two floating rules both in; one on WAN the other all of my vlans.

            I wish I could just apply them to the WAN with in & out as the directions.

            1 Reply Last reply Reply Quote 1
            • X Offline
              xRaisen
              last edited by

              Hello, I am new here. I have been following this thread since last week. Tried the new patch and it's working as intended just like the manual. I leave everything in default, I just add the Upload/Download bandwidth Queue Management Algorithm
              CoDel and FQ_Codel for Scheduler.

              I have tested it, hogging my connections doing 20 torrents and 1 download on IDM. Played Online game to see the ping and CMD ping www.google.com -t, I experienced 1 to 2 packet loss, and 3 to 5 ping dancing and I can still play like as if there were no downloads happening on the background.

              Some issues on the syslog, but fixed it by this command: ifconfig <nics> -promisc

              0_1529003640259_4f840f82-1253-4255-a783-eb3ad481a2d3-image.png

              Just a heads up! This one though, it's just showing on the syslogs everytime.

              0_1529003711093_e9ff68bc-48a9-450f-8db7-ed6bda851357-image.png

              By the way, I have Floating rules active and limiters(for LAN scheds, no queues).

              Overall, thank you. This helps me a lot.

              C mattundM 2 Replies Last reply Reply Quote 1
              • C Offline
                cplmayo @xRaisen
                last edited by cplmayo

                @xraisen Your nics shouldn't need to be in promiscuous mode. That is a message that I would ignore.

                Promiscuous mode is just going to have your NIC accept all packets.

                Non-Promiscuous mode will have you NIC drop packets not destined for it.

                Unless you are doing packet captures I can't think of a reason you would want to run in promiscuous mode.

                X 2 Replies Last reply Reply Quote 0
                • X Offline
                  xRaisen @cplmayo
                  last edited by

                  @cplmayo This was enabled default because I don't remember enabling this. But thanks for the info!

                  1 Reply Last reply Reply Quote 0
                  • mattundM Offline
                    mattund @xRaisen
                    last edited by mattund

                    @xraisen

                    I'm also seeing the flowset busy log entries occasionally, I think it has to do with the fact that the rules don't always get deleted (just reconfigured). However, I am not positive on that yet. Others may have gotten around this or have other ideas...

                    EDIT:

                    We're a lot like opnsense with this patch, because they are using this (dummynet - not my patch lol) for their shaping I think. Well, regardless, this ticket:

                    https://github.com/opnsense/core/issues/1279

                    Due to the fact that the internal variables of each AQM instance is allocated and freed dynamically, re-configuring AQM (e.g. select CoDel for a pipe that currently uses PIE)
                    can lead the AQM code to access unallocated memory (freed during AQM re-configuration) and kernel panic could happen.
                    Therefore, I tried to avoid any potential kernel panic by preventing re-configuring AQM for busy pipe/queue.

                    He suggests:

                    • Temporarily block the traffic (using IPFW rules) from passing through AQM PIE/queue until you finish your configuration.
                    • Delete the old pipes/queues that need to be re-configured with AQM and create them again with all the desired settings.
                    • Reboot the firewall

                    I think this really would need to be a code-level patch somehow. Somehow "unbusy" it, then apply

                    EDIT 2:

                    I find this kind of hilarious and coincidental, but I'm experiencing this right now. I'm going to screw around with my shaper.inc and see what it takes to shake this error.

                    EDIT 3:

                    Deleting and recreating the rules does nothing to alleviate the error, however setting the Queue Management Algorithm to on the Parent Limiter droptail worked to get it to stop throwing each apply for me.

                    C X S 4 Replies Last reply Reply Quote 0
                    • C Offline
                      cplmayo @mattund
                      last edited by

                      @mattund From my experience with limiters and floating rules; always apply after any single change to a limiter. Each time I make a change I save and apply. I ran into problems at first when I would save several changes and apply at once.

                      May help may not.

                      For floating rules always reset states after making a change. This is due to how pfSense handles floating rules. It just helps to ensure that your floating rules are being applied to all of your traffic. If you add a floating rule and do not reset states only new traffic will be evaluated against the rule.

                      1 Reply Last reply Reply Quote 0
                      • w0wW Away
                        w0w @mattund
                        last edited by

                        This post is deleted!
                        1 Reply Last reply Reply Quote 0
                        • X Offline
                          xRaisen @cplmayo
                          last edited by

                          @cplmayo said in Playing with fq_codel in 2.4:

                          @xraisen Your nics shouldn’t need to be in promiscuous mode. That is a message that I would ignore.
                          Promiscuous mode is just going to have your NIC accept all packets.
                          Non-Promiscuous mode will have you NIC drop packets not destined for it.
                          Unless you are doing packet captures I can’t think of a reason you would want to run in promiscuous mode.

                          I found out why it was enabled. Because I use the NTOPNG package. I have uninstalled it, now it's gone. The package turned on the promiscuous mode to monitor the packets.

                          1 Reply Last reply Reply Quote 0
                          • X Offline
                            xRaisen @mattund
                            last edited by xRaisen

                            @mattund said in Playing with fq_codel in 2.4:

                            He suggests:

                            Temporarily block the traffic (using IPFW rules) from passing through AQM PIE/queue until you finish your configuration.
                            Delete the old pipes/queues that need to be re-configured with AQM and create them again with all the desired settings.
                            Reboot the firewall

                            I have tried this method, but when doing "ipfw sched show" this will show up

                            0_1529008156466_c20bb1cc-e2f3-45d8-bce7-1d1bb14456d2-image.png

                            Notice the "Drop tail" cannot be changed to CoDel, PIE, RED and GRED and It's very persistent.

                            Please confirm this on your end.

                            EDIT 1:

                            Changing the Queue Management Algorithm to Tail Drop, the "config_aqm Unable to configure flowset, flowset busy!" was gone.

                            EDIT 2:

                            Trying Tail Drop + FQ_CODEL on scheds and CODEL on queues and use queues instead of scheds, gives me a better results without the syslog nagging. Hogging the bandwidth again for testing, I got zero packet loss and ping on www.google.com and CSGO are dancing to 0ms to 1ms swiftly like nothing happened. This is the best bandwidth management setup I have experienced so far on pfsense. Take note, I have an active traffic shaper (fairq+codel) on floating rules for voice, games and browsing priorities.

                            Z M 2 Replies Last reply Reply Quote 0
                            • Z Offline
                              zwck @xRaisen
                              last edited by

                              @xraisen Would you mind sharing some screenshots of your config :D

                              X 1 Reply Last reply Reply Quote 0
                              • X Offline
                                xRaisen @zwck
                                last edited by xRaisen

                                @zwck I have a 50Mbps Symmetrical connection. So, I will give 40Mbps to Wired, and 10Mbps to Wifi. What will happen, when the wired are full, it will not eat up all the bandwidth reserved for the wifi devices and vice versa. These are my config as follows.

                                STEP 1: Applied this patch for ez life.

                                @w0w said in Playing with fq_codel in 2.4:

                                Applied this diff https://github.com/pfsense/pfsense/compare/RELENG_2_4_3…mattund:RELENG_2_4_3.diff
                                Adding new queue by pressing button on limiter settings page opens new page and you can add new queue save and apply it, but it does not appear in the list and I don't see it anywhere. But it can be only in my case, just because I have some April version of 2.4.4, before PHP7 preparations were made.

                                STEP 2: I created Aliases to separate Wired and WiFi

                                0_1529100311903_2f2cfa70-2370-497c-9f49-92cb06060388-image.png

                                STEP 3: Create a limiters.

                                Download:

                                0_1529100579591_a5574ab7-a0d7-4839-9428-263538fa9491-image.png

                                Upload:

                                0_1529101177155_3b43d083-1c8b-4530-92be-bf4ded0d934e-image.png

                                Same to other limiters, just change the bandwidth.

                                STEP 5: Create child queues

                                Download queue:

                                0_1529101289108_65b4eee6-de8c-488b-938c-1f4c0bbaf52e-image.png

                                Upload queue:

                                0_1529101317562_0f22afa0-310c-4ca0-b598-50d994897354-image.png

                                STEP 4: Create LAN rules and assign the pipe in/out as queue I've created.

                                0_1529100866523_4c4975ba-2e78-48cd-8f1b-c3096e10c946-image.png

                                And so on...

                                My rules arrangements:

                                0_1529100976464_864e6b35-9eff-4506-8c8f-09d30d57eeed-image.png

                                Why I use queue than sched? I believe its a Flexible “fair use” bandwidth limiter

                                References:
                                #1 https://www.gridstorm.net/pfsense-traffic-limiting-fair-share/
                                #2 https://www.reddit.com/r/PFSENSE/comments/3e67dk/flexible_vs_fixed_limiters_troubleshooting_with/

                                My Traffic shaping rules for priorities. I am used to be a fan of HFSC, but I find this better than HFSC for my needs:

                                WAN: FAIRQ

                                0_1529101758938_347f8c13-8110-40ad-9c6c-61c72460b3bb-image.png

                                WAN Child example:

                                0_1529101807072_71653904-966c-4dca-8085-39984bcad870-image.png

                                The rest are self-intuitive.

                                My floating rules:

                                0_1529101956046_a2bfcf1d-6478-4a7e-ad2b-7e54f4e8f7d2-image.png

                                In my 4 years experience on pfsense, this is the best config I get so far for my requirements.

                                Many thanks to all members of this community. Ideas are from them, I just built it based from their brilliant minds. Credits and kudos to them!

                                EDIT 1:

                                I installed two packages only for my box. I have uninstalled squid and squidguard because it's not helping getting my desired QoS and I will stick to pfblockerng-devel by bbcan because it has a new feat that whatever squidguard had. I have installed FreeRadius for Captive Portal full control over it.

                                EDIT 2: Added this because it's really helpful.

                                0_1529138264469_db0ee699-8f0d-486d-b5e6-b7b7478d3891-image.png

                                S K 2 Replies Last reply Reply Quote 2
                                • C Offline
                                  cplmayo @mattund
                                  last edited by

                                  @mattund So I'm an idiot and just figured out a way around the apparent routing loop. I redid my floating rules; created two rules one in and one out. However, I set the protocol to TCP/UDP since that is all I really want to apply QoS to anyway. No, that ICMP is not having the rule applied to it when I run a traceroute from a vLAN I can see the correct information.

                                  So far for me, this has worked much better because I apply the rules directly to the WAN interface and not worry about creating extra rules to prevent shapping of local traffic.

                                  So obvious and I can't believe I just thought of it today.

                                  1 Reply Last reply Reply Quote 0
                                  • S Offline
                                    strangegopher @xRaisen
                                    last edited by

                                    @xraisen According to openwrt wiki (only firewall where I was able to get A+ bufferbloat with fq_codel) ecn should only be enabled on inbound packets.

                                    X Z 2 Replies Last reply Reply Quote 0
                                    • S Offline
                                      strangegopher @mattund
                                      last edited by strangegopher

                                      @mattund I still get those errors with Tail Drop as parent

                                      1 Reply Last reply Reply Quote 0
                                      • X Offline
                                        xRaisen @strangegopher
                                        last edited by

                                        @strangegopher said in Playing with fq_codel in 2.4:

                                        @xraisen According to openwrt wiki (only firewall where I was able to get A+ bufferbloat with fq_codel) ecn should only be enabled on inbound packets.

                                        Wow! Thanks man! It proves you are right about it. While my network is so busy right now (50Mbps total), I still got a+

                                        0_1529136224223_45ddfe44-265d-4e13-b296-3720e5072962-image.png

                                        1 Reply Last reply Reply Quote 1
                                        • S Offline
                                          strangegopher
                                          last edited by

                                          Also isn't fq_codel doing head drop, then why is parent selected as tail drop?

                                          mattundM 1 Reply Last reply Reply Quote 0
                                          • mattundM Offline
                                            mattund @strangegopher
                                            last edited by mattund

                                            @strangegopher I believe something has to be set there, otherwise it is is set "for you" (and in that case, I think it defaults to tail drop?). So, while you're absolutely right about the functionality of both, I think that at the greater level dummynet does need some sort of plan for packets that exceed the queue size. Whether or not that ever happens since FQ_CODEL is on, I can't really say for sure. You'd think that FQ_CODEL would ultimately be a gatekeeper and never let taildrop see an excess ... that's my guess.

                                            I'm actually really curious about the behavior now; I'll get back to you on what dummynet does without taildrop selected so we have some concrete evidence other than my assumption. Who knows, we might be able to add a "None" option?

                                            EDIT: Got the answer, check this out:

                                            	if (fs->flags & DN_IS_RED)	/* RED parameters */
                                            		sprintf(red,
                                            		    "\n\t %cRED w_q %f min_th %d max_th %d max_p %f",
                                            		    (fs->flags & DN_IS_GENTLE_RED) ? 'G' : ' ',
                                            		    1.0 * fs->w_q / (double)(1 << SCALE_RED),
                                            		    fs->min_th,
                                            		    fs->max_th,
                                            		    1.0 * fs->max_p / (double)(1 << SCALE_RED));
                                            	else
                                            		sprintf(red, "droptail");
                                            

                                            That is the dummynet code that is responsible constructing the output of the ipfw pipe show (etc) commands. It indicates that, if RED/GRED is off, then it's going to just say "droptail"/tail drop. Which, tells me that droptail is the fallback default behavior; FQ_CODEL must super-cede it in some way when it's enabled. In other words, if you don't specify Tail Drop, it'll default to it anyways, which would make a "None" option as I'd previously suggested unnecessary. But, if you think about it, it makes sense - we constrain these queues to some ultimate size - so we must have a way to enforce that. I think that Tail Drop is just dummynet's way of ensuring that promise, even if FQ_CODEL is really doing all the legwork.

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