CPU Usage when network used
- 
 Hmm, well it looks like if the restriction is anywhere it's on WAN. Were you able to test with just the igb NICs? Remove the 10G from the test? Steve 
- 
 ok so it took some changing things around a bit but I have now switched to using only 1G interfaces. Unfortunately I am not sure the results are much different. PID USERNAME PRI NICE SIZE RES STATE C TIME WCPU COMMAND 
 0 root -92 - 0K 688K CPU3 3 5:25 94.14% [kernel{igb0 que (qid 0)}]
 11 root 155 ki31 0K 64K CPU1 1 24.8H 58.08% [idle{idle: cpu1}]
 11 root 155 ki31 0K 64K CPU2 2 24.8H 55.88% [idle{idle: cpu2}]
 11 root 155 ki31 0K 64K RUN 0 24.8H 44.88% [idle{idle: cpu0}]
 12 root -92 - 0K 816K WAIT 0 1:15 36.41% [intr{irq287: igb3:que 0}]
 11 root 155 ki31 0K 64K RUN 3 24.8H 32.95% [idle{idle: cpu3}]
 12 root -92 - 0K 816K CPU1 1 1:15 30.30% [intr{irq288: igb3:que 1}]
 78054 root 34 0 266M 218M bpf 2 0:48 22.20% /usr/local/bin/ntopng -dFor reference the transfer was going about 40 megabytes/sec. Cheers! 
- 
 If you expand the window to get more output from top do you actually see more than one queue on igb0? You said you have mostly default settings, I assume you did not set the number of igb queues? Or any other loader tunable? Steve 
- 
 Hi Steve, I still had the shell open from the same transfer. Here is a more complete view. 
 I am not clear if
 kernel{igb0 que (qid 0)} is different than intr{irq269: igb0:que 0} however for igb3 I see [intr{irq288: igb3:que 1}] and [intr{irq287: igb3:que 0}] which still seems low given I have 4 cores no? I have not adjusted anything manually like this.PID USERNAME PRI NICE SIZE RES STATE C TIME WCPU COMMAND 
 11 root 155 ki31 0K 64K CPU3 3 25.4H 74.96% [idle{idle: cpu3}]
 11 root 155 ki31 0K 64K RUN 1 25.4H 54.03% [idle{idle: cpu1}]
 11 root 155 ki31 0K 64K RUN 0 25.3H 41.49% [idle{idle: cpu0}]
 0 root -92 - 0K 688K CPU2 2 10:46 35.19% [kernel{igb0 que (qid 0)}]
 11 root 155 ki31 0K 64K RUN 2 25.3H 33.86% [idle{idle: cpu2}]
 12 root -92 - 0K 816K CPU1 1 3:36 31.32% [intr{irq288: igb3:que 1}]
 12 root -92 - 0K 816K WAIT 0 3:40 29.27% [intr{irq287: igb3:que 0}]
 12 root -92 - 0K 816K WAIT 0 5:50 17.34% [intr{irq269: igb0:que 0}]
 78054 root 30 0 266M 221M RUN 1 2:13 16.83% /usr/local/bin/ntopng -d /v
 78054 root 22 0 266M 221M uwait 3 0:12 9.10% /usr/local/bin/ntopng -d /v
 78054 root 25 0 266M 221M uwait 0 0:11 7.71% /usr/local/bin/ntopng -d /v
 78054 root 23 0 266M 221M uwait 3 0:11 7.62% /usr/local/bin/ntopng -d /v
 78054 root 23 0 266M 221M nanslp 3 1:31 4.48% /usr/local/bin/ntopng -d /v
 78054 root 21 0 266M 221M nanslp 1 0:48 4.16% /usr/local/bin/ntopng -d /v
 78054 root 20 0 266M 221M nanslp 0 0:39 1.45% /usr/local/bin/ntopng -d /v
 41253 unbound 20 0 65412K 44220K kqread 0 0:01 0.67% /usr/local/sbin/unbound -c
 36170 root 21 0 98680K 39040K accept 3 0:06 0.62% php-fpm: pool nginx (php-fp
 20 root -16 - 0K 16K - 0 0:37 0.57% [rand_harvestq]
 0 root -92 - 0K 688K - 1 0:04 0.42% [kernel{igb3 que (qid 0)}]
 12 root -92 - 0K 816K WAIT 3 0:34 0.34% [intr{irq290: igb3:que 3}]
 78054 root 20 0 266M 221M bpf 1 0:03 0.25% /usr/local/bin/ntopng -d /v
 198 root 20 0 9860K 4776K CPU0 0 0:07 0.25% top -aSH
 75724 root 20 0 8428K 4984K kqread 0 0:04 0.21% redis-server: /usr/local/bi
 23537 root 20 0 12912K 13032K usem 0 0:00 0.16% /usr/local/sbin/ntpd -g -c
 12 root -72 - 0K 816K WAIT 3 0:14 0.14% [intr{swi1: netisr 0}]
 50030 root 20 0 9464K 5868K select 3 0:10 0.14% /usr/local/sbin/miniupnpd -
 22585 root 20 0 23592K 8804K kqread 3 0:01 0.12% nginx: worker process (ngin
 12 root -60 - 0K 816K WAIT 0 1:21 0.11% [intr{swi4: clock (0)}]
 65534 root 20 0 6600K 2356K bpf 3 0:07 0.08% /usr/local/sbin/filterlog -
 0 root -92 - 0K 688K - 2 0:00 0.07% [kernel{igb3 que (qid 1)}]
 339 root 36 0 98552K 39340K accept 1 0:13 0.07% php-fpm: pool nginx (php-fp
 74721 root 20 0 50888K 35668K nanslp 3 0:02 0.07% /usr/local/bin/php -f /usr/
 81162 root 20 0 6392K 2540K select 1 0:04 0.06% /usr/sbin/syslogd -s -c -c
 78054 root 20 0 266M 221M nanslp 0 0:00 0.05% /usr/local/bin/ntopng -d /v
 49333 dhcpd 20 0 12576K 7924K select 3 0:01 0.05% /usr/local/sbin/dhcpd -user
 12 root -92 - 0K 816K RUN 2 0:20 0.04% [intr{irq289: igb3:que 2}]
 78054 root 20 0 266M 221M select 0 0:00 0.04% /usr/local/bin/ntopng -d /v
 19 root -16 - 0K 16K pftm 0 0:22 0.03% [pf purge]
 44931 root 20 0 12904K 8152K select 0 0:01 0.03% sshd: root@pts/0 (sshd)
 23537 root 20 0 12912K 13032K select 0 0:08 0.03% /usr/local/sbin/ntpd -g -c
 36968 root 20 0 6900K 2444K nanslp 1 0:00 0.02% [dpinger{dpinger}]
 36442 root 20 0 6900K 2444K nanslp 1 0:00 0.02% [dpinger{dpinger}]
 12 root -88 - 0K 816K WAIT 0 0:06 0.01% [intr{irq257: xhci0}]
 37136 root 20 0 6900K 2444K nanslp 1 0:00 0.01% [dpinger{dpinger}]
 15 root -68 - 0K 80K - 3 0:05 0.01% [usb{usbus0}]
 78054 root 20 0 266M 221M nanslp 0 0:00 0.01% /usr/local/bin/ntopng -d /v
 15 root -68 - 0K 80K - 2 0:05 0.01% [usb{usbus0}]Cheers! 
- 
 @qwaven said in CPU Usage when network used: [intr{irq290: igb3:que 3}] It looks like you have 4 queues for igb3 which is what I expect for a 4 core CPU but I only see one for igb0. 
 You might try runningvmstat -ito confirm you do have the expected queues for each NIC. I thought they were all on-chip in that CPU but maybe igb0 is different in which case you might try using igb3, or one of the others, as WAN.Steve 
- 
 So with vmstat I see the correct number: irq269: igb0:que 0 57225866 135 
 irq270: igb0:que 1 421673 1
 irq271: igb0:que 2 425910 1
 irq272: igb0:que 3 421212 1
 irq273: igb0:link 11 0irq287: igb3:que 0 94141932 223 
 irq288: igb3:que 1 45221540 107
 irq289: igb3:que 2 27199303 64
 irq290: igb3:que 3 35826209 85
 irq291: igb3:link 5 0Cheers! 
- 
 Mmm, but all the interrupt loading is on one queue. Do you have a PPPoE WAN? The single thread performance of the N3700 is... not good. And potentially much worse if turbo/burst is not working. Do you see any significant improvement if you disable ntop-ng? Steve 
- 
 yes the WAN is PPPoE. Would there be something I can do to use more queues properly? I can try and turn ntop off later to see what happens. Cheers! 
- 
 Ah! OK then, currently, you are limited to a single queue on the PPPoE interface and hence a single core. See: https://redmine.pfsense.org/issues/4821 And the upstream: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=203856 You can probably get some performance by setting the sysctl net.isr.dispatchtodeferredin Sys > Adv > System Tunables. That will require a reboot.https://docs.netgate.com/pfsense/en/latest/hardware/tuning-and-troubleshooting-network-cards.html#pppoe-with-multi-queue-nics Steve 
- 
 tried the dispatch 
 sysctl net.isr.dispatch
 net.isr.dispatch: deferredcpu seemed to about 50% utilization. interrupt total rate 
 cpu0:timer 122117 254
 cpu2:timer 121707 253
 cpu3:timer 116674 243
 cpu1:timer 115728 241
 irq256: ahci0 11720 24
 irq257: xhci0 2850 6
 irq258: hdac0 2 0
 irq260: t5nex0:evt 2 0
 irq269: igb0:que 0 659069 1372
 irq270: igb0:que 1 1457 3
 irq271: igb0:que 2 516 1
 irq272: igb0:que 3 515 1
 irq273: igb0:link 3 0
 irq274: pcib5 1 0
 irq280: pcib6 1 0
 irq286: pcib7 1 0
 irq287: igb3:que 0 453042 943
 irq288: igb3:que 1 573830 1194
 irq289: igb3:que 2 755133 1572
 irq290: igb3:que 3 438318 912
 irq291: igb3:link 3 0
 irq292: pcib8 1 0
 Total 3372690 7020
- 
 Also now tried disabling ntop cpu usage looks to be maybe 8-10% less. 
- 
 Is that total CPU was 50%? Did throughput increase? Steve 
- 
 That would be what was shown on the dashboard for cpu performance. If utilization is stuck on 1 core I am not sure if there would be anything else we can do. As for throughput, it was about the same but I am not worrying about that as the source for the transfer may impact this as well. Ideally it would be great to see it closer to my actual speed but I'm not sure about testing it reliably. Cheers! 
- 
 Hi again, I'm assuming we've exhausted trying to improve the cpu utilization with this but I just wanted to say thanks for the help/efforts with this. I am still open to try anything though. Cheers! 
- 
 I suspect it might be. The single thread performance of that CPU is about equal to that of the Pentium M I used to run and that was good fpr ~650Mbps. At least according to this: 
 https://www.cpubenchmark.net/compare/Intel-Core2-Duo-E4500-vs-Intel-Pentium-N3700-vs-Intel-Pentium-M-1.73GHz/936vs2513vs1160
 Obviously that's synthetic and there are many variable etc. No PPPoE overhead in that test either.
 The E4500 can pass Gigabit, just. (at full size TCP packets...many variables etc!).If that is to be believed then it probably is running burst mode and I'm not sure there's much we can do before RSS is re-written in FreeBSD to allow multiple cores. You probably could see better performance off-loading the PPPoE to another device. That would probably mean a double NAT scenario unfortunately. Steve 
- 
 Hi Steve, It's unfortunate about this RSS issue. I have another board that I plan to try out, however its quite overkill especially if only 1 core is going to be used for pppoe. However it does have some better on board hardware that may help overall. It is however still just 2ghz/core. https://www.supermicro.com/products/motherboard/atom/A2SDi-H-TP4F.cfm Cheers! 
- 
 Yes. I have a PPPoE WAN but fortunately/unfortunately it's no where near fast enough to worry about this.  No benchmarks for the C3958 but if we assume it's the same as the C3858 but with 4 more cores then it should make about ~40% better single thread performance. It does seem like a waste of cores unless you virtualise it. Steve 
- 
 Hi Steve, So I flipped it over. Performance so far looks drastically better. CPU in the gui was about 5-6% while transferring over pppoe. I believe still just the 1 core. PID USERNAME PRI NICE SIZE RES STATE C TIME WCPU COMMAND 
 11 root 155 ki31 0K 256K CPU1 1 7:39 97.26% [idle{idle: cpu1}]
 11 root 155 ki31 0K 256K CPU10 10 7:41 97.12% [idle{idle: cpu10}]
 11 root 155 ki31 0K 256K CPU13 13 7:33 96.96% [idle{idle: cpu13}]
 11 root 155 ki31 0K 256K CPU7 7 7:45 96.85% [idle{idle: cpu7}]
 11 root 155 ki31 0K 256K CPU11 11 7:38 96.51% [idle{idle: cpu11}]
 11 root 155 ki31 0K 256K RUN 4 7:43 96.46% [idle{idle: cpu4}]
 11 root 155 ki31 0K 256K CPU3 3 7:44 96.46% [idle{idle: cpu3}]
 11 root 155 ki31 0K 256K CPU9 9 7:36 96.26% [idle{idle: cpu9}]
 11 root 155 ki31 0K 256K CPU5 5 7:42 95.99% [idle{idle: cpu5}]
 11 root 155 ki31 0K 256K RUN 8 7:19 95.56% [idle{idle: cpu8}]
 11 root 155 ki31 0K 256K CPU6 6 7:42 95.12% [idle{idle: cpu6}]
 11 root 155 ki31 0K 256K CPU2 2 7:42 94.98% [idle{idle: cpu2}]
 11 root 155 ki31 0K 256K CPU12 12 7:40 93.93% [idle{idle: cpu12}]
 11 root 155 ki31 0K 256K RUN 15 7:35 87.04% [idle{idle: cpu15}]
 11 root 155 ki31 0K 256K CPU14 14 7:31 82.95% [idle{idle: cpu14}]
 11 root 155 ki31 0K 256K RUN 0 7:24 79.60% [idle{idle: cpu0}]irq298: ix0:q0 2716423 6058 
 irq299: ix0:q1 244578 545
 irq300: ix0:q2 461159 1029
 irq301: ix0:q3 243416 543
 irq302: ix0:q4 378891 845
 irq303: ix0:q5 124788 278
 irq304: ix0:q6 478729 1068
 irq305: ix0:q7 125913 281
 irq306: ix0:link 1 0
 irq307: ix1:q0 326596 728
 irq308: ix1:q1 254938 569
 irq309: ix1:q2 614196 1370
 irq310: ix1:q3 250402 558
 irq311: ix1:q4 388996 868
 irq312: ix1:q5 128709 287
 irq313: ix1:q6 492403 1098
 irq314: ix1:q7 130143 290
 irq315: ix1:link 1 0ix0 is pppoe and ix1 is internal lans. I was thinking about virtualizing. However I've seen so many talks about people suggesting this is not a great choice for a firewall. However I'm open to exploring this more. Do you have any thoughts? Proxmox was my first choice. Cheers! 
- 
 Nice, what sort of throughput were you seeing at that point? I can't really advise on hypervisors, I'm not using anything right now. A lot of people here are using Proxmox though. ESXi is also popular. Steve 
- 
 Same throughput but I believe this is more because of the source. I have not had a chance to test internally the network to see if anything there is improved. Will update once I have. 
