On Monday, October 26, 2015 02:58:03 PM Yuchung Cheng wrote: > On Mon, Oct 26, 2015 at 2:35 PM, Andreas Petlund <apetlund@xxxxxxxxx> wrote: > > > On 26 Oct 2015, at 15:50, Neal Cardwell <ncardwell@xxxxxxxxxx> wrote: > > > > > > On Fri, Oct 23, 2015 at 4:50 PM, Bendik Rønning Opstad > > > > > > <bro.devel@xxxxxxxxx> wrote: > > >> @@ -2409,6 +2412,15 @@ static int do_tcp_setsockopt(struct sock *sk, > > >> int level,> > > > > ... > > > > > >> + case TCP_RDB: > > >> + if (val < 0 || val > 1) { > > >> + err = -EINVAL; > > >> + } else { > > >> + tp->rdb = val; > > >> + tp->nonagle = val; > > > > > > The semantics of the tp->nonagle bits are already a bit complex. My > > > sense is that having a setsockopt of TCP_RDB transparently modify the > > > nagle behavior is going to add more extra complexity and unanticipated > > > behavior than is warranted given the slight possible gain in > > > convenience to the app writer. What about a model where the > > > application user just needs to remember to call > > > setsockopt(TCP_NODELAY) if they want the TCP_RDB behavior to be > > > sensible? I see your nice tests at > > > > > > https://github.com/bendikro/packetdrill/commit/9916b6c53e33dd04329d29b > > > 7d8baf703b2c2ac1b> > > > > are already doing that. And my sense is that likewise most > > > well-engineered "thin stream" apps will already be using > > > setsockopt(TCP_NODELAY). Is that workable? This is definitely workable. I agree that it may not be an ideal solution to have TCP_RDB disable Nagle, however, it would be useful with a way to easily enable RDB and disable Nagle. > > We have been discussing this a bit back and forth. Your suggestion would > > be the right thing to keep the nagle semantics less complex and to > > educate developers in the intrinsics of the transport. > > > > We ended up choosing to implicitly disable nagle since it > > 1) is incompatible with the logic of RDB. > > 2) leaving it up to the developer to read the documentation and register > > the line saying that "failing to set TCP_NODELAY will void the RDB > > latency gain" will increase the chance of misconfigurations leading to > > deployment with no effect. > > > > The hope was to help both the well-engineered thin-stream apps and the > > ones deployed by developers with less detailed knowledge of the > > transport. > but would RDB be voided if this developer turns on RDB then turns on > Nagle later? It would (to a large degree), but I believe that's ok? The intention with also disabling Nagle is not to remove control from the application writer, so if TCP_RDB disables Nagle, they should not be prevented from explicitly enabling Nagle after enabling RDB. The idea is to make it as easy as possible for the application writer, and since Nagle is on by default, it makes sense to change this behavior when the application has indicated that it values low latencies. Would a solution with multiple option values to TCP_RDB be acceptable? E.g. 0 = Disable 1 = Enable RDB 2 = Enable RDB and disable Nagle If the sysctl tcp_rdb accepts the same values, setting the sysctl to 2 would allow to use and test RDB (with Nagle off) on applications that haven't explicitly disabled Nagle, which would make the sysctl tcp_rdb even more useful. Instead of having TCP_RDB modify Nagle, would it be better/acceptable to have a separate socket option (e.g. TCP_THIN/TCP_THIN_LOW_LATENCY) that enables RDB and disables Nagle? e.g. 0 = Use default system options? 1 = Enable RDB and disable Nagle This would separate the modification of Nagle from the TCP_RDB socket option and make it cleaner? Such an option could also enable other latency-reducing options like TCP_THIN_LINEAR_TIMEOUTS and TCP_THIN_DUPACK: 2 = Enable RDB, TCP_THIN_LINEAR_TIMEOUTS, TCP_THIN_DUPACK, and disable Nagle Bendik -- To unsubscribe from this list: send the line "unsubscribe linux-api" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html