Junio C Hamano <junkio@xxxxxxx> wrote: > > This does not help for low timeouts with slow clients. If a client is > > slow enough so the server is blocked for more time than specified by > > timeout the connection will be closed too (e.g. 15kb/s with a timeout > > of 30 (git adds 10 extra) is not enough). > > Where do we add 10 extra? Oops, never mind, I misread the source. > > We should either add a > > warning to the man page or try to fix this. I don't know if this can > > be fixed not using non-blocking sockets. > > I think the intent of "timeout" was to protect us from funny > clients by avoiding talking with the ones that take too much > time doing something that should not take too long. When we are > in create_pack_file(), we are already committed to the heaviest > operation anyway, so one possibility might be to stop doing > timeout at that point. I am not sure if that is acceptable, > though -- it opens up the daemon to even easier DoS than it > currently is. > > My gut feeling is that your patch would be fine as is (have you > tried and confirmed that it helps cases other than slow > clients?) What else? The problem solved by this patch is the missing reset_timeout while downloading pack files and this affects all clients that are too slow (cannot download the packfile within --timeout seconds). I tried a server with --timeout=600 and a client that cannot download the whole pack file in 10 minutes. Without the patch the server closes the connection, with this patch it works. Additionally I tried it with a client reading so slow that the server was blocked for more than --timeout seconds, then the server closes the connection too (this is more or less the DoS case). > > Perhaps support for resume would be quite useful too but I've no idea > > how hard this is to implement. > > That would be _very_ hard. I don't know how much demand there is for resuming but there is always rsync (at least on kernel.org and other repositories that need it can install it too) to get the new objects with support for resuming. - : send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html