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

    Per IP traffic shaping–share bandwith evenly between IP addresses??

    Scheduled Pinned Locked Moved Traffic Shaping
    172 Posts 75 Posters 153.6k Views 11 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.
    • A Offline
      Ashfaq
      last edited by

      Screen shots are attached.

      its important to mention that i initially tried to use the queue based setup discussed earlier in this thread and u can see my earlier posts with screen-shots for that setup as well.  but since i failed to achieve the desired outcome i am now trying to apply a simple limiter to get this torrent thing resolved first.  and the screen-shots with this message are for this simple setup.

      if u like i can post the speed-test and torrent screenshots separately as well with traffic graph n all.

      limiter-down.jpg
      limiter-down.jpg_thumb
      limiter-up.jpg
      limiter-up.jpg_thumb
      rule-list-lan.jpg
      rule-list-lan.jpg_thumb
      rule-lan.jpg
      rule-lan.jpg_thumb
      graph.jpg
      graph.jpg_thumb

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

        Hmm.  Are there any queues defined?  What you have should work.

        One thing I see is the pass any to !LAN net rule with the limiters on it is unnecessary.  I'd just put the limiters on the pass any any rule.  If it's being processed by the LAN router interface, it's by default !LAN Net.

        And the traffic out WAN is mirroring the traffic into LAN right (2.0Mbps when bittorrent is cranking away)?

        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
        • DerelictD Offline
          Derelict LAYER 8 Netgate
          last edited by

          Actually, the way you have it, each destination IP will get 512 down and each source IP 128 up, so two downloaders can eat 1Mbit, 3 1.5Mbit, etc.

          What are those other queues?

          Are you sure there's not some other rules somewhere setting limiters, queues, etc?

          Here's a sample that will evenly share 10Mbit down 3Mbit up among IPs

          ![Screen Shot 2014-09-10 at 6.55.14 PM.png](/public/imported_attachments/1/Screen Shot 2014-09-10 at 6.55.14 PM.png)
          ![Screen Shot 2014-09-10 at 6.55.14 PM.png_thumb](/public/imported_attachments/1/Screen Shot 2014-09-10 at 6.55.14 PM.png_thumb)
          ![Screen Shot 2014-09-10 at 6.55.23 PM.png](/public/imported_attachments/1/Screen Shot 2014-09-10 at 6.55.23 PM.png)
          ![Screen Shot 2014-09-10 at 6.55.23 PM.png_thumb](/public/imported_attachments/1/Screen Shot 2014-09-10 at 6.55.23 PM.png_thumb)
          ![Screen Shot 2014-09-10 at 6.55.31 PM.png](/public/imported_attachments/1/Screen Shot 2014-09-10 at 6.55.31 PM.png)
          ![Screen Shot 2014-09-10 at 6.55.31 PM.png_thumb](/public/imported_attachments/1/Screen Shot 2014-09-10 at 6.55.31 PM.png_thumb)
          ![Screen Shot 2014-09-10 at 6.55.39 PM.png](/public/imported_attachments/1/Screen Shot 2014-09-10 at 6.55.39 PM.png)
          ![Screen Shot 2014-09-10 at 6.55.39 PM.png_thumb](/public/imported_attachments/1/Screen Shot 2014-09-10 at 6.55.39 PM.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
          • DerelictD Offline
            Derelict LAYER 8 Netgate
            last edited by

            Hmm… This isn't working for me either.  I currently have a limiter at 1Mbit / 1Mbit with rules on LAN for my desktop and phone.  Speed tests reflect this but I'm downloading torrents at about 10Mbits.  I applied the limiter, killed transmission, cleared all states, and restarted transmission.

            Do you have an inbound rule on WAN forwarding your bittorrent listener port to your host?

            I did.

            I disabled that rule and am now getting better limiter results.  Seems like a limiter on the WAN rule should do the trick but I did try that and it didn't for me.

            Now my speed test on the phone that's put in the same limiter gets about 512Kbit down and almost the full 1Mbit up, which is exactly what I would expect.

            Anyone know the trick for throttling bittorrent using the limiter?

            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
            • A Offline
              Ashfaq
              last edited by

              wow so many messages :-) …. Thanks Derelict for the efforts, i really appreciate that.
              now to answer ur queries one by one:

              *) no other queues are defined, only limiters and no other rules are defined in firewall. 
              *) the LAN to !LAN is there to copy the setup defined in this thread earlier... so just to make sure i am not doing what other are not doing to simplify the debugging of this issue. u r right we dont need that and i have tried the setup without it as well... no diff in result :-( .... one question though... what if i am transferring data from my LAN to PUBLIC (another LAN) ? putting the limiter in default rule might limit that to 2mbps as well.. just a thought.
              *)those other queues are related to the equal sharing of 2mbps that i tried earlier based on this thread messages and did not succeed.  they are there and not actually used as of now in any rule.
              *)YES ! i have UPNP turned on in pfsense and using a pre-defined-port in torrent application.  although i have not made any specific rule in firewall for this to work.  i even tried turning the UPNP off but didnt help either.

              now let me tell u something new i tried....
              *)yesterday i reverted back to the OTHER RULES u see on the screen-shots that are there to sharing the 2mbps connection using child queues, i attached those queues to the firewall rule of LAN to !LAN and
              *)also created shapper-queues with help of wizard and it made a few floating rules with http(s), smtp, pop as HighPriority and rest as lowpriority.  and
              *)then i manually attached the limiter-queues in those torrent related floating-rules and
              *)tested again using two windows PC on torrents and an android with regular video streaming and browsing etc.

              to my surprise it DID started to share bandwidth b/w the three devices :-)
              if i disable those floating-rules, i end up like before... torrents take away ALL the bandwidth and no browsing is possible on android, as soon as i enable those rules i get the sharing working.
              i cannot make out why its working but may be u can, so please try that.

              Thanks again for all the help.
              Regards

              1 Reply Last reply Reply Quote 0
              • Z Offline
                zang3tsu
                last edited by

                @Ashfaq Could you post your final settings again as I 'm hoping to replicate your setup. Thanks!

                1 Reply Last reply Reply Quote 0
                • A Offline
                  Ashfaq
                  last edited by

                  Check my previous posts in this thread for limiter setup screen-shots.
                  attached are the screen-shots for floating rules added by wizard and the 2 amendment i made in the p2p rule ONLY:

                  1. added in/out limiters values
                  2. changed port range to include ports used by my torrent client.

                  another observation with this setup is that sometimes my torrents dont get the FULL speed even if they are the ONLY thing running the network.  disabling the floating rules gives it the complete bandwidth.

                  Ashfaq

                  floating_rules.jpg
                  floating_rules.jpg_thumb
                  p2p_rule.jpg
                  p2p_rule.jpg_thumb

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

                    Dear all,

                    I'm a first time poster here - these forums have been tremendously useful just from reading them. Sorry for my phraseology, the terms are still difficult to grasp. We have a college in a developing country - using desktop grade hardware to share 10Mbps synchronous connection among all users. It's slow but it works. We see 100 simultaneous network users regularly, and 300 at peak times. Firewall is pfsense 2.1.5.

                    Obviously traffic shaping is very important for us. The details given in this thread have been very useful in getting things started. I have also noticed, as some users above, that a one-click rule for this important feature (dynamic per-IP traffic shaping) would be really helpful.

                    The shaping using limiters described here is a great starting point. It does 'break' occasionally in ways that amateurs will probably never be able to figure out, least of all me. Also, it doesn't 'share' or 'throttle' the bandwidth from hogs (downloaders, with sustained bandwidth usage) to 'new comers' (i.e. someone just trying to load a single webpage) fast enough. Any ideas on this?

                    In the above scenarios, I'm wondering if this 'burst' feature that's there with limiters might work. However, you have to set that at the parent level. Does that somehow also get shared among dynamic child pipes? Anyone figure out what the units for that are (bytes, kb, mb), or if it always matches the units of the bandwidth specified. I know it's supposed to be an amount/size, not a rate, but I haven't figured out the units of it, or like I said, if it gets divided equally into the child pipes.

                    1 Reply Last reply Reply Quote 0
                    • B Offline
                      Basi
                      last edited by

                      Are there any news this will be an official feature? Maybe in 2.2?

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

                        @ssp:

                        Dear all,

                        I'm a first time poster here - these forums have been tremendously useful just from reading them. Sorry for my phraseology, the terms are still difficult to grasp. We have a college in a developing country - using desktop grade hardware to share 10Mbps synchronous connection among all users. It's slow but it works. We see 100 simultaneous network users regularly, and 300 at peak times. Firewall is pfsense 2.1.5.

                        Obviously traffic shaping is very important for us. The details given in this thread have been very useful in getting things started. I have also noticed, as some users above, that a one-click rule for this important feature (dynamic per-IP traffic shaping) would be really helpful.

                        The shaping using limiters described here is a great starting point. It does 'break' occasionally in ways that amateurs will probably never be able to figure out, least of all me. Also, it doesn't 'share' or 'throttle' the bandwidth from hogs (downloaders, with sustained bandwidth usage) to 'new comers' (i.e. someone just trying to load a single webpage) fast enough. Any ideas on this?

                        In the above scenarios, I'm wondering if this 'burst' feature that's there with limiters might work. However, you have to set that at the parent level. Does that somehow also get shared among dynamic child pipes? Anyone figure out what the units for that are (bytes, kb, mb), or if it always matches the units of the bandwidth specified. I know it's supposed to be an amount/size, not a rate, but I haven't figured out the units of it, or like I said, if it gets divided equally into the child pipes.

                        If you have 300 people sharing only 10mb of bandwidth during peak hours, you might just be best off using the regular traffic shaper, set up just a few rules like

                        Interface rate: 9.8Mb
                        –Traffic Link Share: 95%
                        ----UDP Link Share 50% CODEL
                        ----TCP Link Share 50% CODEL
                        --Important Protocols Link Share 5%
                        ----DNS Link Share: 50%
                        ----ICMP Link Share: 50%

                        From what I've read, CODEL is quite nice for fighting buffer bloat, which may or may not be an issue.

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

                          @Harvy66,

                          Are you suggesting the user build 4 queues and then run codel on two them.  The reason I ask is I am a new user trying to get handle on traffic shaping for my application.  I am trying to understand the best way to use codel with pfSense.  There does not appear to be much information on the way to use it.

                          In my case it is for a home router replacement, a RT-N16 running tomato with QoS.  The recent TWC upgrade to 100/5 Mb/s service has caused me to outgrow the the N16 router.

                          Edit:
                          Note, I just created some queues via the wizzard and saved them as a test.  When you try an apply codel, the previous queues are erased.

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

                            @switchman:

                            @Harvy66,

                            Are you suggesting the user build 4 queues and then run codel on two them.  The reason I ask is I am a new user trying to get handle on traffic shaping for my application.  I am trying to understand the best way to use codel with pfSense.  There does not appear to be much information on the way to use it.

                            In my case it is for a home router replacement, a RT-N16 running tomato with QoS.  The recent TWC upgrade to 100/5 Mb/s service has caused me to outgrow the the N16 router.

                            Edit:
                            Note, I just created some queues via the wizzard and saved them as a test.  When you try an apply codel, the previous queues are erased.

                            I don't have anything to back this up, but codel is an algorithm to combat buffer bloat, so it drops packets. I didn't recommend codel on the DNS and ICMP queues because those types of traffic tend to not be high bandwidth in the first place, so a bit of bufferbloat may be less detrimental than dropped packets.

                            I personally set my packet buffers high for low/fixed bandwidth queues that do no react to dropped packets. Dropping packets is supposed to be a signal to back-off for protocols that implement congestion control.

                            My logic could be wrong or real world practice may have an interesting interaction, such that non-tail drop tightly smaller queues are always best, but I see no harm in my setup since it only affects me.

                            P.S. I forgot to include the ACK queue in my example. It should always exist.

                            Since you're a home user, this is what I use and it seems to work well for me. Mind you, I have a symmetrical pseudo-dedicated connection, so you may need to tweak your upload ACK queue allocation.

                            https://forum.pfsense.org/index.php?topic=86347.msg474756#msg474756

                            1 Reply Last reply Reply Quote 0
                            • M Offline
                              M-runner
                              last edited by

                              @Ashfaq:

                              Has anybody been successful in equally dividing the bandwidth b/w a pc with torrent download and one with simple browsing?
                              or a mobile device against with simple data usage and a torrent downloading pc ?

                              with me the torrent download PC always gets almost all of the bandwidth all the time !

                              Ashfaq

                              Hi!

                              I got this working with torrents. First, configure as foxale08, reply #9-#12. (The only difference is that I used a floating rule instead of a LAN rule, but it should work anyhow.)

                              Next step: Use the limiters Upload_LAN and Download_LAN again on the bittorrent portforward rule, but use Download_LAN on In and Upload_LAN on Out, because this is a WAN rule.

                              I tested this and if I limit Download to 10Mb/s and start a torrent, the torrent gets no more than 10Mb/s and then if I try to download from another IP adress, I get 5Mb/s from that client and 5Mb/s to the torrent client even if the bittorrent client has many more connections.

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

                                I have implemented the solution provided by foxale08 and it works very well.

                                But if someone used VPN to connect to the network and tried to copy something from the NAS located on the network to their own drive on their homework network - would they be treated just like any other user and they get a fair share?

                                1 Reply Last reply Reply Quote 0
                                • C Offline
                                  cmutwiwa
                                  last edited by

                                  I applied foxale08 method for the limiter and it kills internet connection (but I can ping websites), if I disable the limiters internet works fine. I'm also using squid proxy in transparent mode, I haven't tried to uninstall squid but could it be the issue?

                                  1 Reply Last reply Reply Quote 0
                                  • P Offline
                                    paulsgrigg
                                    last edited by

                                    Been struggling getting this to work all day but got it working now :)

                                    Just in case anyone has problems, what fixed it for me is to set the bandwidth a few megabits below what is actually available. We get around 17 mbit over ADSL but the limiter wouldn't work until I set it at 15 (or lower).

                                    I've also had the weird side effect that port reflection seems to have stopped working when accessing from our LAN, NAT rules which forward to our DMZ. Not a big deal at the moment but does anyone know why? The port reflection still seems to work for rules that point to our LAN.

                                    Paul

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

                                      Hi there guys.. i did foxale08's post and it worked very well. our gaming ping is very low for online games such as lol, hon and dota2, however, whenever the lan rule is enabled, all clients seem to have a very hard time browsing the internet, any idea how to solve this issue?

                                      our broadband is 10mbps (yes its quite low) for download and around 600 kbps for upload so i set the limiter at 6mbps download and 512 kbps upload

                                      1 Reply Last reply Reply Quote 0
                                      • V Offline
                                        velzyboard
                                        last edited by

                                        Thank you foxale08 for your documentation on this solution.  I have run this for over week a week now on our private network.  My colleagues are coming up and saying … "did something happen to the internet?  It is running faster and more reliable."  I removed all the traffic shaping and your limiter setup is perfect for us.

                                        I'd like to do the same for our public network.  However, I have one last question.  Are there resources that I need to make sure we have enough before doing that like  handles, file limits etc?

                                        My box is a Pentium R 3.4 Ghz with 2 CPU x 2 Cores and 4G of memory and 64G hard drive.   
                                        2 WANs (50mbps/5mbps;  24mbps/5mbps)
                                        1 for private interface and 1 for public. 
                                        Private only has 15 users.  Public can have 0-peak 120 general users (mail & browsing)

                                        Thanks!
                                        Rob

                                        1 Reply Last reply Reply Quote 0
                                        • J Offline
                                          jiunnyik
                                          last edited by

                                          @cmutwiwa:

                                          I applied foxale08 method for the limiter and it kills internet connection (but I can ping websites), if I disable the limiters internet works fine. I'm also using squid proxy in transparent mode, I haven't tried to uninstall squid but could it be the issue?

                                          I have the same issue.

                                          Disable the transparent proxy and the limiter will works

                                          1 Reply Last reply Reply Quote 0
                                          • J Offline
                                            jiunnyik
                                            last edited by

                                            I tested foxale08's method on 2.2.2

                                            I found that sometimes it not really share bandwidth evenly.

                                            Anyone same issue ?

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