* Single core gets pegged on multi-core PPTP server @ 2012-01-19 22:35 Bradley Peterson 2012-01-19 22:55 ` Emanuil Hristov 2012-01-20 6:16 ` Eric Dumazet 0 siblings, 2 replies; 5+ messages in thread From: Bradley Peterson @ 2012-01-19 22:35 UTC (permalink / raw) To: paulus, linux-ppp, netdev Hello, I am trying to test the capacity of a linux PPTP server, both in number of connections, and in packets per second. I am using kernel 2.6.38.8, with the ppp, pptp, and gre modules, and accel-pptp 0.8.3. I have RPS, RFS, and XPS enabled on the network devices for SMP support. But I'm seeing one CPU get pegged out with soft interrupt, while the others are almost completely idle. In my current test, I'm starting 250 pptp connections from another server, then running iperf across each connection. The client machine pegs out, sure, but I'm surprised the server pegs out a single CPU. With RPS, I would expect softirq's to be more balanced. Where could the bottleneck be? Do all ppp packets need to be processed serially? Brad ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Single core gets pegged on multi-core PPTP server 2012-01-19 22:35 Single core gets pegged on multi-core PPTP server Bradley Peterson @ 2012-01-19 22:55 ` Emanuil Hristov 2012-01-19 23:28 ` Alexey Osipov 2012-01-20 6:16 ` Eric Dumazet 1 sibling, 1 reply; 5+ messages in thread From: Emanuil Hristov @ 2012-01-19 22:55 UTC (permalink / raw) To: Bradley Peterson; +Cc: paulus, linux-ppp, netdev, int986 Hi, try with more recent version of accel-ppp (1.5 is lastest) and newer kernel - there are several critical bugs in older kernels P.S the project accel-pptp has changed its name to accel-ppp cheers On Fri, Jan 20, 2012 at 12:35 AM, Bradley Peterson <despite@gmail.com> wrote: > Hello, > > I am trying to test the capacity of a linux PPTP server, both in > number of connections, and in packets per second. I am using kernel > 2.6.38.8, with the ppp, pptp, and gre modules, and accel-pptp 0.8.3. > I have RPS, RFS, and XPS enabled on the network devices for SMP > support. > > But I'm seeing one CPU get pegged out with soft interrupt, while the > others are almost completely idle. > > In my current test, I'm starting 250 pptp connections from another > server, then running iperf across each connection. The client machine > pegs out, sure, but I'm surprised the server pegs out a single CPU. > With RPS, I would expect softirq's to be more balanced. > > Where could the bottleneck be? Do all ppp packets need to be > processed serially? > > Brad > -- > To unsubscribe from this list: send the line "unsubscribe netdev" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Single core gets pegged on multi-core PPTP server 2012-01-19 22:55 ` Emanuil Hristov @ 2012-01-19 23:28 ` Alexey Osipov 0 siblings, 0 replies; 5+ messages in thread From: Alexey Osipov @ 2012-01-19 23:28 UTC (permalink / raw) To: Emanuil Hristov; +Cc: paulus, linux-ppp, netdev, Bradley Peterson Hi, AFAIK, accel-ppp != accel-pptp. accel-pptp - kernel module for speed-up pptp processing done by pppd. accel-ppp - entirely new implementation of ppp written from scratch. No pppd is used in this case. So, if in your configuration, you need to use some other plugins for pppd, you can't just switch from accel-pptp to accel-ppp, because accel-ppp have it's own plugin API. Regards, Alexey. В Птн, 20/01/2012 в 00:55 +0200, Emanuil Hristov пишет: > Hi, > try with more recent version of accel-ppp (1.5 is lastest) and newer > kernel - there > are several critical bugs in older kernels > > > P.S the project accel-pptp has changed its name to accel-ppp > > cheers > > On Fri, Jan 20, 2012 at 12:35 AM, Bradley Peterson <despite@gmail.com> wrote: > > Hello, > > > > I am trying to test the capacity of a linux PPTP server, both in > > number of connections, and in packets per second. I am using kernel > > 2.6.38.8, with the ppp, pptp, and gre modules, and accel-pptp 0.8.3. > > I have RPS, RFS, and XPS enabled on the network devices for SMP > > support. > > > > But I'm seeing one CPU get pegged out with soft interrupt, while the > > others are almost completely idle. > > > > In my current test, I'm starting 250 pptp connections from another > > server, then running iperf across each connection. The client machine > > pegs out, sure, but I'm surprised the server pegs out a single CPU. > > With RPS, I would expect softirq's to be more balanced. > > > > Where could the bottleneck be? Do all ppp packets need to be > > processed serially? > > > > Brad > > -- > > To unsubscribe from this list: send the line "unsubscribe netdev" in > > the body of a message to majordomo@vger.kernel.org > > More majordomo info at http://vger.kernel.org/majordomo-info.html > -- > To unsubscribe from this list: send the line "unsubscribe linux-ppp" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Single core gets pegged on multi-core PPTP server 2012-01-19 22:35 Single core gets pegged on multi-core PPTP server Bradley Peterson 2012-01-19 22:55 ` Emanuil Hristov @ 2012-01-20 6:16 ` Eric Dumazet 2012-01-20 15:20 ` Bradley Peterson 1 sibling, 1 reply; 5+ messages in thread From: Eric Dumazet @ 2012-01-20 6:16 UTC (permalink / raw) To: Bradley Peterson; +Cc: paulus, linux-ppp, netdev Le jeudi 19 janvier 2012 à 16:35 -0600, Bradley Peterson a écrit : > Hello, > > I am trying to test the capacity of a linux PPTP server, both in > number of connections, and in packets per second. I am using kernel > 2.6.38.8, with the ppp, pptp, and gre modules, and accel-pptp 0.8.3. > I have RPS, RFS, and XPS enabled on the network devices for SMP > support. > > But I'm seeing one CPU get pegged out with soft interrupt, while the > others are almost completely idle. > > In my current test, I'm starting 250 pptp connections from another > server, then running iperf across each connection. The client machine > pegs out, sure, but I'm surprised the server pegs out a single CPU. > With RPS, I would expect softirq's to be more balanced. > > Where could the bottleneck be? Do all ppp packets need to be > processed serially? > Hmmm, you need a more recent kernel or backport commit c6865cb3cc6f3c2857fa4c6f5fda2945d70b1e84 rps: Inspect GRE encapsulated packets to get flow hash Crack open GRE packets in __skb_get_rxhash to compute 4-tuple hash on in encapsulated packet. Note that this is used only when the __skb_get_rxhash is taken, in particular only when the device does not compute provide the rxhash (ie. feature is disabled). This was tested by creating a single GRE tunnel between two 16 core AMD machines. 200 netperf TCP_RR streams were ran with 1 byte request and response size. Without patch: 157497 tps, 50/90/99% latencies 1250/1292/1364 usecs With patch: 325896 tps, 50/90/99% latencies 603/848/1169 Signed-off-by: Tom Herbert <therbert@google.com> Signed-off-by: David S. Miller <davem@davemloft.net> And make sure you disabled hardware rxhash (if your NIC provides it) ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Single core gets pegged on multi-core PPTP server 2012-01-20 6:16 ` Eric Dumazet @ 2012-01-20 15:20 ` Bradley Peterson 0 siblings, 0 replies; 5+ messages in thread From: Bradley Peterson @ 2012-01-20 15:20 UTC (permalink / raw) To: Eric Dumazet; +Cc: paulus, linux-ppp, netdev On Fri, Jan 20, 2012 at 12:16 AM, Eric Dumazet <eric.dumazet@gmail.com> wrote: > Le jeudi 19 janvier 2012 à 16:35 -0600, Bradley Peterson a écrit : >> Hello, >> >> I am trying to test the capacity of a linux PPTP server, both in >> number of connections, and in packets per second. I am using kernel >> 2.6.38.8, with the ppp, pptp, and gre modules, and accel-pptp 0.8.3. >> I have RPS, RFS, and XPS enabled on the network devices for SMP >> support. >> >> But I'm seeing one CPU get pegged out with soft interrupt, while the >> others are almost completely idle. >> >> In my current test, I'm starting 250 pptp connections from another >> server, then running iperf across each connection. The client machine >> pegs out, sure, but I'm surprised the server pegs out a single CPU. >> With RPS, I would expect softirq's to be more balanced. >> >> Where could the bottleneck be? Do all ppp packets need to be >> processed serially? >> > > Hmmm, you need a more recent kernel or backport commit > c6865cb3cc6f3c2857fa4c6f5fda2945d70b1e84 > rps: Inspect GRE encapsulated packets to get flow hash > > Crack open GRE packets in __skb_get_rxhash to compute 4-tuple hash on > in encapsulated packet. Note that this is used only when the > __skb_get_rxhash is taken, in particular only when the device does > not compute provide the rxhash (ie. feature is disabled). > > This was tested by creating a single GRE tunnel between two 16 core > AMD machines. 200 netperf TCP_RR streams were ran with 1 byte > request and response size. > > Without patch: 157497 tps, 50/90/99% latencies 1250/1292/1364 usecs > With patch: 325896 tps, 50/90/99% latencies 603/848/1169 > > Signed-off-by: Tom Herbert <therbert@google.com> > Signed-off-by: David S. Miller <davem@davemloft.net> > > > > And make sure you disabled hardware rxhash (if your NIC provides it) > > Thank you, I had missed the work on RPS with encapsulated packets. I will try a newer kernel. ^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2012-01-20 15:20 UTC | newest] Thread overview: 5+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2012-01-19 22:35 Single core gets pegged on multi-core PPTP server Bradley Peterson 2012-01-19 22:55 ` Emanuil Hristov 2012-01-19 23:28 ` Alexey Osipov 2012-01-20 6:16 ` Eric Dumazet 2012-01-20 15:20 ` Bradley Peterson
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox