networking:buffer_bloat
Differences
This shows you the differences between two versions of the page.
Next revision | Previous revision | ||
networking:buffer_bloat [2020/07/15 10:11] – created 192.168.1.69 | networking:buffer_bloat [2020/07/15 10:14] (current) – 192.168.1.69 | ||
---|---|---|---|
Line 33: | Line 33: | ||
---- | ---- | ||
- | ===== Change the Q size ===== | + | ===== Things To Do To Prevent Buffer Bloat ===== |
- | + | ||
- | + | ||
- | <WRAP important> | + | |
- | **IMPORTANT: | + | |
- | + | ||
- | It is important to keep in mind that what you are doing in pfSense is setting up a rate limiter. | + | |
- | + | ||
- | If you set the numbers lower than your connection will allow, you'll get a great buffer bloat score but you'll slow your network throughput to whatever value you chose. | + | |
- | + | ||
- | If you set the number too high, the rate limiter wont come into play and you'll be subjected to the same performance and buffer bloat you had prior to making the changes. | + | |
- | + | ||
- | The idea is to let pfSense do the rate limiting closer to home. | + | |
- | + | ||
- | Letting your provider do it for you increases latency... and that's what we are really trying to avoid. | + | |
- | + | ||
- | So to minimize latency, a recommendation is to first do a speed test to find out what your connection is capable of, then set the bandwidth of the limiters in pfSense to those numbers. | + | |
- | + | ||
- | Adjust the queue size adds another dimension to the optimizations. | + | |
- | + | ||
- | Someday your connection might receive a speed upgrade and you may forgot to adjust the limiter to make use of it! | + | |
- | </ | + | |
- | + | ||
- | ---- | + | |
- | + | ||
- | ===== Instructions ===== | + | |
- | + | ||
- | ==== Create Limiters ==== | + | |
- | + | ||
- | Navigate to **Firewall -> Traffic Shaper -> Limiters**. | + | |
- | + | ||
- | < | + | |
- | 1.) Create " | + | |
- | + | ||
- | Tick " | + | |
- | 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 " | + | |
- | + | ||
- | Tick " | + | |
- | Name: fq_codel_out_q | + | |
- | Mask: None | + | |
- | Queue Management Algorithm: Tail Drop | + | |
- | Click Save/Apply Changes | + | |
- | + | ||
- | 3.) Create " | + | |
- | + | ||
- | Tick " | + | |
- | 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 " | + | |
- | + | ||
- | Tick " | + | |
- | Name: fq_codel_in_q | + | |
- | Mask: None | + | |
- | Queue Management Algorithm: Tail Drop | + | |
- | Click Save/Apply Changes | + | |
- | </ | + | |
- | + | ||
- | ---- | + | |
- | + | ||
- | ==== Create Floating Rules ==== | + | |
- | + | ||
- | < | + | |
- | Add quick pass floating rule to handle ICMP traceroute. This rule matches ICMP traceroute packets so that they are not matched by the WAN-Out limiter rule that utilizes policy routing. Policy routing breaks traceroute. | + | |
- | + | ||
- | Action: Pass | + | |
- | Quick: Tick Apply the action immediately on match. | + | |
- | Interface: WAN | + | |
- | Direction: out | + | |
- | Address Family: IPv4 | + | |
- | Protocol: ICMP | + | |
- | ICMP subtypes: Traceroute | + | |
- | Source: any | + | |
- | Destination: | + | |
- | Description: | + | |
- | Click Save | + | |
- | + | ||
- | 2.) Add quick pass floating rule to handle ICMP echo-request and echo-reply. This rule matches ping packets so that they are not matched by the limiter rules. See bug 9024 for more info. | + | |
- | + | ||
- | Action: Pass | + | |
- | Quick: Tick Apply the action immediately on match. | + | |
- | Interface: WAN | + | |
- | Direction: any | + | |
- | Address Family: IPv4 | + | |
- | Protocol: ICMP | + | |
- | ICMP subtypes: Echo reply, Echo Request | + | |
- | Source: any | + | |
- | Destination: | + | |
- | Description: | + | |
- | Click Save | + | |
- | + | ||
- | 3.) Add a match rule for incoming state flows so that they' | + | |
- | + | ||
- | Action: Match | + | |
- | Interface: WAN | + | |
- | Direction: in | + | |
- | Address Family: IPv4 | + | |
- | Protocol: Any | + | |
- | Source: any | + | |
- | Destination: | + | |
- | Description: | + | |
- | Gateway: Default | + | |
- | In / Out pipe: fq_codel_in_q / fq_codel_out_q | + | |
- | Click Save | + | |
- | + | ||
- | 4.) Add a match rule for outgoing state flows so that they' | + | |
- | + | ||
- | Action: Match | + | |
- | Interface: WAN | + | |
- | Direction: out | + | |
- | Address Family: IPv4 | + | |
- | Protocol: Any | + | |
- | Source: any | + | |
- | Destination: | + | |
- | Description: | + | |
- | Gateway: WAN_DHCP | + | |
- | In / Out pipe: fq_codel_out_q / fq_codel_in_q | + | |
- | Click Save/Apply Changes | + | |
- | </ | + | |
- | + | ||
- | + | ||
- | ---- | + | |
- | + | ||
- | ===== Troubleshooting ===== | + | |
- | + | ||
- | https:// | + | |
- | + | ||
- | https:// | + | |
- | + | ||
- | https:// | + | |
+ | * Change the Q size. | ||
---- | ---- |
networking/buffer_bloat.1594807900.txt.gz · Last modified: 2020/07/15 10:11 by 192.168.1.69