documentation:technical_docs:performance
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
documentation:technical_docs:performance [2019/11/21 17:22] – [Choosing good Hardware] olivier | documentation:technical_docs:performance [2024/08/21 18:29] (current) – olivier | ||
---|---|---|---|
Line 27: | Line 27: | ||
* [[http:// | * [[http:// | ||
* [[http:// | * [[http:// | ||
+ | * [[https:// | ||
==== FreeBSD ==== | ==== FreeBSD ==== | ||
Line 86: | Line 87: | ||
Beware of configurations setup that prevent multi-queue, | Beware of configurations setup that prevent multi-queue, | ||
</ | </ | ||
- | ==== Choosing | + | ==== Choosing |
=== CPU === | === CPU === | ||
Line 104: | Line 105: | ||
==== Choosing good FreeBSD release ==== | ==== Choosing good FreeBSD release ==== | ||
- | Before tuning, you need to use the good FreeBSD version. | + | Before tuning, you need to use the good FreeBSD version... this mean a recent |
- | This mean a FreeBSD -head version older than r309257 (Andrey V. Elsukov 's improvement: | + | |
- | BSDRP since version 1.70 is using a FreeBSD | + | BSDRP is currently following |
+ | ==== Disabling Hyper Threading | ||
- | {{documentation: | + | By default |
- | + | But on some older CPU (like Xeon E5-2650 V1) those logical cores didn't help at all for managing interrupts generated by high speed NIC. | |
- | For better (and linear scale) performance there is the [[https:// | + | |
- | + | ||
- | ==== Disabling Hyper Threading ==== | + | |
- | + | ||
- | Disable Hyper Threading (HT): By default, lot's of multi-queue NIC drivers create one queue per core. | + | |
- | But "logical" | + | |
HT can be disabled with this command: | HT can be disabled with this command: | ||
Line 123: | Line 118: | ||
</ | </ | ||
- | Here is an example on a 8cores x hardware threads Intel CPU and 10G Chelsio NIC: | + | Here is an example on a Xeon E5 2650 (8c, |
< | < | ||
- | x HT-enabled-8rxq(default).packets-per-seconds | + | x HT-enabled-8rxq(default): inet packets-per-second forwarded |
- | + HT-enabled-16rxq.packets-per-seconds | + | + HT-enabled-16rxq: inet packets-per-second forwarded |
- | * HT-disabled.packets-per-seconds | + | * HT-disabled-8rxq: inet packets-per-seconds |
+--------------------------------------------------------------------------+ | +--------------------------------------------------------------------------+ | ||
| **| | | **| | ||
Line 150: | Line 145: | ||
</ | </ | ||
- | There is a benefit of about 24% to disable hyper threading. | + | There is a benefit of about 24% to disable hyper threading |
+ | |||
+ | But here is another example where there is a benefit to kept it enabled (and with the NIC configured to uses all the treads) on Xeon E5 2650L (10c, 20t): | ||
+ | |||
+ | < | ||
+ | x HT on, 8q (default): inet4 packets-per-second forwarded | ||
+ | + HT off, 8q: inet4 packets-per-second forwarded | ||
+ | * HT on, 16q: inet4 packets-per-second forwarded | ||
+ | +--------------------------------------------------------------------------+ | ||
+ | |x x ++ | ||
+ | |x xx +++ * * *| | ||
+ | ||AM| |A_| |_MA_|| | ||
+ | +--------------------------------------------------------------------------+ | ||
+ | N | ||
+ | x | ||
+ | + | ||
+ | Difference at 95.0% confidence | ||
+ | 1.01311e+06 +/- 113098 | ||
+ | 23.2388% +/- 2.94299% | ||
+ | (Student' | ||
+ | * | ||
+ | Difference at 95.0% confidence | ||
+ | 4.41004e+06 +/- 173536 | ||
+ | 101.157% +/- 5.21388% | ||
+ | (Student' | ||
+ | </ | ||
==== fastforwarding ==== | ==== fastforwarding ==== | ||
Line 235: | Line 255: | ||
{{documentation: | {{documentation: | ||
- | ==== Polling mode ==== | ||
- | |||
- | Polling can be used in 2 cases: | ||
- | * On **old hardware only** (where Ethernet card doesn' | ||
- | * When used [[http:// | ||
- | For enabling polling mode: | ||
- | - Edit / | ||
- | - Execute: service polling start | ||
- | |||
- | === NIC drivers compatibility matrix === | ||
- | |||
- | BSDRP can use some special features on somes NIC: | ||
- | * [[http:// | ||
- | * [[http:// | ||
- | |||
- | And only theses devices support these modes: | ||
- | |||
- | ^ name ^ Description | ||
- | | ae | Attansic/ | ||
- | | age | Attansic/ | ||
- | | alc | Atheros AR813x/ | ||
- | | ale | Atheros AR8121/ | ||
- | | bce | Broadcom NetXtreme II (BCM5706/ | ||
- | | bfe | Broadcom BCM4401 Ethernet Device Driver | no | yes | | ||
- | | bge | Broadcom BCM570x/ | ||
- | | cas | Sun Cassini/ | ||
- | | cxgbe | Chelsio T4 and T5 based 40Gb, 10Gb, and 1Gb Ethernet adapter driver | no | yes | | ||
- | | dc | DEC/Intel 21143 and clone 10/100 Ethernet driver | yes | yes | | ||
- | | de | DEC DC21x4x Ethernet device driver | no | yes | | ||
- | | ed | NE-2000 and WD-80x3 Ethernet driver | no | yes | | ||
- | | em | Intel(R) PRO/1000 Gigabit Ethernet adapter driver | yes | yes | | ||
- | | et | Agere ET1310 10/ | ||
- | | ep | Ethernet driver for 3Com Etherlink III (3c5x9) interfaces | no | yes | | ||
- | | fxp | Intel EtherExpress PRO/100 Ethernet device driver | yes | yes | | ||
- | | gem | ERI/ | ||
- | | hme | Sun Microelectronics STP2002-STQ Ethernet interfaces device driver | no | yes | | ||
- | | igb | Intel(R) PRO/1000 PCI Express Gigabit Ethernet adapter driver | yes | needs IGB_LEGACY_TX | | ||
- | | ixgb(e) | Intel(R) 10Gb Ethernet driver | yes | needs IGB_LEGACY_TX | | ||
- | | jme | JMicron Gigabit/ | ||
- | | le | AMD Am7900 LANCE and Am79C9xx ILACC/PCnet Ethernet interface driver | no | yes | | ||
- | | msk | Marvell/ | ||
- | | mxge | Myricom Myri10GE 10 Gigabit Ethernet adapter driver | no | yes | | ||
- | | my | Myson Technology Ethernet PCI driver | no | yes | | ||
- | | nfe | NVIDIA nForce MCP Ethernet driver | yes | yes | | ||
- | | nge | National Semiconductor PCI Gigabit Ethernet adapter driver | yes | no | | ||
- | | nve | NVIDIA nForce MCP Networking Adapter device driver | no | yes | | ||
- | | qlxgb | QLogic 10 Gigabit Ethernet & CNA Adapter Driver | no | yes | | ||
- | | re | RealTek 8139C+/ | ||
- | | rl | RealTek 8129/8139 Fast Ethernet device driver | yes | yes | | ||
- | | sf | Adaptec AIC‐6915 " | ||
- | | sge | Silicon Integrated Systems SiS190/191 Fast/ | ||
- | | sis | SiS 900, SiS 7016 and NS DP83815/ | ||
- | | sk | SysKonnect SK-984x and SK-982x PCI Gigabit Ethernet adapter driver | yes | yes | | ||
- | | ste | Sundance Technologies ST201 Fast Ethernet device driver | no | yes | | ||
- | | stge | Sundance/ | ||
- | | ti | Alteon Networks Tigon I and Tigon II Gigabit Ethernet driver | no | yes | | ||
- | | txp | 3Com 3XP Typhoon/ | ||
- | | vge | VIA Networking Technologies VT6122 PCI Gigabit Ethernet adapter driver | yes | yes | | ||
- | | vr | VIA Technologies Rhine I/II/III Ethernet device driver | yes | yes | | ||
- | | xl | 3Com Etherlink XL and Fast Etherlink XL Ethernet device driver | yes | yes | | ||
- | Using others NIC will works too :-) | ||
==== NIC drivers tuning ==== | ==== NIC drivers tuning ==== | ||
Line 694: | Line 653: | ||
Now you can display the most time consumed process with: | Now you can display the most time consumed process with: | ||
+ | * AMD: ls_not_halted_cyc | ||
+ | * Intel: cpu_clk_unhalted.thread_p | ||
+ | * ARM: | ||
< | < | ||
- | pmcstat -TS inst_retired.any_p -w1 | + | pmcstat -TS cpu_clk_unhalted.thread_p |
</ | </ | ||
documentation/technical_docs/performance.1574353323.txt.gz · Last modified: 2019/11/21 17:22 by olivier