LibreQoS/src
2023-01-10 14:12:50 +00:00
..
bin Add example systemctl .service files 2023-01-10 14:12:50 +00:00
rust Throughput graph is responsive, doesn't fill to zero on unshaped, and has an X-axis label. 2023-01-10 14:12:50 +00:00
testdata Major move around of every thing 2022-12-07 11:04:54 -08:00
build_rust.sh Add example systemctl .service files 2023-01-10 14:12:50 +00:00
graphInfluxDB.py Add build script and associated path changes 2023-01-10 14:12:50 +00:00
influxDBdashboardTemplate_v2.5.1.json Major move around of every thing 2022-12-07 11:04:54 -08:00
influxDBdashboardTemplate.json Major move around of every thing 2022-12-07 11:04:54 -08:00
INTEGRATION_HOWTO.md Major move around of every thing 2022-12-07 11:04:54 -08:00
integrationCommon.py Major move around of every thing 2022-12-07 11:04:54 -08:00
integrationSplynx.py Major move around of every thing 2022-12-07 11:04:54 -08:00
integrationUISP.py Do not permit duplicate IP addresses for device 2022-12-17 08:16:35 -06:00
ispConfig.example.py Patch LibreQoS.py and ispConfig.example.py for Rust Integration 2023-01-10 14:12:44 +00:00
LibreQoS.py First iteration of a Python module for direct bus interaction 2023-01-10 14:12:50 +00:00
lqos.example Update lqos.example to more sane defaults, and add a TESTING-1.4.md document to provide some temporary instructions for testing this release. 2023-01-10 14:12:50 +00:00
mikrotikDHCPRouterList.csv Major move around of every thing 2022-12-07 11:04:54 -08:00
mikrotikFindIPv6.py Major move around of every thing 2022-12-07 11:04:54 -08:00
network.example.json Major move around of every thing 2022-12-07 11:04:54 -08:00
README.md Fix typos 2023-01-07 08:50:28 +01:00
scheduler.py Major move around of every thing 2022-12-07 11:04:54 -08:00
ShapedDevices.example.csv Major move around of every thing 2022-12-07 11:04:54 -08:00
testGraph.py Change path to network.example.json. 2022-12-17 08:09:50 -06:00
TESTING-1.4.md Update test instructions to include how to update. 2023-01-10 14:12:50 +00:00
testIP.py Major move around of every thing 2022-12-07 11:04:54 -08:00

v1.3 (IPv4 + IPv6)

image

Features

Fast TCP Latency Tracking

@thebracket has created cpumap-pping which merges the functionality of the xdp-cpumap-tc and ePPing projects, while keeping CPU use within ~1% of xdp-cpumap-tc.

Integrations

Partial Queue Reload

In v1.2 and prior, the the entire queue structure had to be reloaded to make any changes. This led to a few milliseconds of packet loss for some clients each time that reload happened. The scheduled.py was set to reload all queues each morning at 4AM to avoid any potential disruptions that could theoretically cause.

Starting with v1.3 - LibreQoS tracks the state of the queues, and can do incremental changes without a full reload of all queues. Every 30 minutes - scheduler.py runs the CRM import, and runs a partial reload affecting just the queues that have changed. It still runs a full reload at 4AM.

v1.3 Improvements to help scale

HTB major:minor handle

HTB uses a hex handle for classes. It is two 16-bit hex values joined by a colon - major:minor (:). In LibreQoS, each CPU core uses a different major handle.

In v1.2 and prior, the minor handle was unique across all CPUs, meaning only 30k subscribers could be added total.

Starting with LibreQoS v1.3 - minor handles are counted independently by CPU core. With this change, the maximum possible subscriber qdiscs/classes goes from a hard limit of 30k to instead be 30k x CPU core count. So for a higher end system with a 64 core processor such as the AMD EPYC™ 7713P, that would mean ~1.9 million possible subscriber classes. Of course CPU use will be the bottleneck well before class handles are in that scenario. But at least we have that arbitrary 30k limit out of the way.

"Circuit ID" Unique Identifier

In order to improve queue reload time in v1.3, it was necessary to use a unique identifier for each circuit. We went with Circuit ID. It can be a number or string, it just needs to be unique between circuits, and the same for multiple devices in the same circuit. This allows us to avoid costly lookups when sorting through the queue structure.

If you have your own script creating ShapedDevices.csv - you could use your CRM's unique identifier for customer services / circuits to serve as this Circuit ID. The UISP and Splynx integrations already do this automatically.

Compatibility Notes

The most major changes are the renaming of the fqorCake variable to "sqm", and the addition of the Circuit identifier field.

Also after upgrading to LibreQos v1.3, a reboot is required to clear out the old ebpf code.