On 05/02/2014 03:13 PM, Butler, Peter wrote: > Recall that the issue here isn't that TCP outperforms SCTP - i.e. that it has higher throughput overall - but that TCP (and UDP) scale up when more connections are added, whereas SCTP does not. So while changing the message size (say, from 1000 bytes to 1452 bytes) and modifying the GSO/TSO/GRO/LRO NIC settings does indeed change the overall SCTP and TCP throughput (and closes the throughput gap between these protocols), the fact remains that I can still then double the overall TCP system throughput by adding in a second TCP connection, whereas I cannot double the SCTP throughput by adding in a second SCTP association. (Again, in the latter case the overall throughput remains constant with the two associations now carrying half the traffic as the lone association did in the former case.) > Right, I understand. However, TCP will end up sending less packets then SCTP due to the stream nature of TCP. So, you may not be hitting a netem drop limitation with TCP. This would be an interesting data point. Run a 2 stream TCP perf session with default netem settings and see if you have qdisc drops. Then run a 2 stream SCTP perf session and check for drops. -vlad > > > -----Original Message----- > From: Vlad Yasevich [mailto:vyasevich@xxxxxxxxx] > Sent: May-02-14 1:34 PM > To: Butler, Peter; Neil Horman > Cc: linux-sctp@xxxxxxxxxxxxxxx > Subject: Re: SCTP throughput does not scale > > On 05/02/2014 01:10 PM, Butler, Peter wrote: >> [root@slot2 ~]# tc -s qdisc show >> qdisc netem 8002: dev p19p2 root refcnt 65 limit 1000 delay 25.0ms >> Sent 590200 bytes 7204 pkt (dropped 0, overlimits 0 requeues 0) >> backlog 0b 0p requeues 0 qdisc netem 8001: dev p19p1 root refcnt 65 >> limit 1000 delay 25.0ms Sent 997332352 bytes 946411 pkt (dropped 478, >> overlimits 0 requeues 1) backlog 114b 1p requeues 1 >> > > Thanks. The above shows a drop of 478 packets. You might try growing you queue size. Remember that SCTP is very much packet oriented and with your size of 1000 bytes, each message ends up taking up > 1 under-utilized packet. > > Meanwhile TCP will coalesce your 1000 byte writes into full mss sized writes (plug GSO/TSO if you are still using it). That allows TCP to much more effectively utilized the packets. > > -vlad > >> >> [root@slot3 ~]# tc -s qdisc show >> qdisc netem 8002: dev p19p2 root refcnt 65 limit 1000 delay 25.0ms >> Sent 90352 bytes 1666 pkt (dropped 0, overlimits 0 requeues 0) >> backlog 0b 0p requeues 0 qdisc netem 8001: dev p19p1 root refcnt 65 >> limit 1000 delay 25.0ms Sent 29544962 bytes 475167 pkt (dropped 0, >> overlimits 0 requeues 2) backlog 130b 1p requeues 2 >> >> >> >> >> -----Original Message----- >> From: Vlad Yasevich [mailto:vyasevich@xxxxxxxxx] >> Sent: May-02-14 1:07 PM >> To: Butler, Peter; Neil Horman >> Cc: linux-sctp@xxxxxxxxxxxxxxx >> Subject: Re: SCTP throughput does not scale >> >> On 05/02/2014 12:33 PM, Butler, Peter wrote: >>> The only entries from "tc qdisc show" are the ones used to implement the 50 ms RTT, which applies to all packet types (not just SCTP). >>> >> >> I am assuming that you are using netem. What is the queue length? >> What is the output of >> # tc -s qdisc show >> >> look like. >> >> Thanks >> -vlad >> >>> As for dropped frames, are you referring to SctpInPktDiscards? SctpInPktDiscards is zero or very small (compared to the total number of transmitted packets). For example, starting with all stats in /proc/net/sctp/snmp zeroed out, and then running one minute's worth of traffic with the same setup (50 ms RTT, 1000-byte messages, 2 MB tx/rx buffer size) I get the following data in /proc/net/sctp/snmp when running two parallel associations (only relevant lines shown here): >>> >>> client side (sending DATA): >>> SctpOutSCTPPacks 938945 >>> SctpInSCTPPacks 473209 >>> SctpInPktDiscards 0 >>> SctpInDataChunkDiscards 0 >>> >>> >>> server side (receiving DATA): >>> SctpOutSCTPPacks 473209 >>> SctpInSCTPPacks 938457 >>> SctpInPktDiscards 0 >>> SctpInDataChunkDiscards 0 >>> >>> >>> >>> -----Original Message----- >>> From: linux-sctp-owner@xxxxxxxxxxxxxxx >>> [mailto:linux-sctp-owner@xxxxxxxxxxxxxxx] On Behalf Of Neil Horman >>> Sent: May-02-14 9:36 AM >>> To: Butler, Peter >>> Cc: linux-sctp@xxxxxxxxxxxxxxx >>> Subject: Re: SCTP throughput does not scale >>> >>> On Fri, May 02, 2014 at 11:45:00AM +0000, Butler, Peter wrote: >>>> I have tested with /proc/sys/net/sctp/[snd|rcv]buf_policy set to 0 and to 1. I get the same behaviour both ways. Note that my associations are all TCP-style SOCK_DGRAM associations, and not UDP-style SOCK_SEQPACKET associations. As such, each association has its own socket - rather than all the associations sharing a single socket - and thus, to my understanding, the parameters in question will have no effect (as my testing has shown). >>>> >>> You're correct, if you're using TCP style associations, the above policies won't change much. >>> >>> Such consistent throughput sharing though still seems odd. You don't have any traffic shaping or policing implimented on your network devices do you? Either on your sending or receiving system? tc qdisc show would be able to tell you. >>> Such low throughput on a 10G interface seems like it could not be much other than that. Are you seeing any droped frames in /proc/net/sctp/snmp or in /proc/net/snmp[6]? >>> >>> Neil >>> >>> -- >>> To unsubscribe from this list: send the line "unsubscribe linux-sctp" >>> in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo >>> info at http://vger.kernel.org/majordomo-info.html >>> -- >>> To unsubscribe from this list: send the line "unsubscribe linux-sctp" >>> in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo >>> info at http://vger.kernel.org/majordomo-info.html >>> >> > -- To unsubscribe from this list: send the line "unsubscribe linux-sctp" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html