Hi, Christopher Baines <m...@cbaines.net> skribis:
> Mathieu Othacehe <othac...@gnu.org> writes: [...] >> Stracing this publish server shows that connection reuse seems to be >> broken: >> >> --8<---------------cut here---------------start------------->8--- >> accept4(9, {sa_family=AF_INET, sin_port=htons(41742), >> sin_addr=inet_addr("141.80.167.185")}, [112->16], 0) = 21 >> accept4(9, {sa_family=AF_INET, sin_port=htons(41744), >> sin_addr=inet_addr("141.80.167.185")}, [112->16], 0) = 21 >> accept4(9, {sa_family=AF_INET, sin_port=htons(41746), >> sin_addr=inet_addr("141.80.167.185")}, [112->16], 0) = 25 >> accept4(9, {sa_family=AF_INET, sin_port=htons(41748), >> sin_addr=inet_addr("141.80.167.185")}, [112->16], 0) = 24 >> accept4(9, {sa_family=AF_INET, sin_port=htons(41750), >> sin_addr=inet_addr("141.80.167.185")}, [112->16], 0) = 21 Ouch. >> Investigating it, I found that the connection is closed and opened >> multiple times in the call-with-cached-connection procedure of the (guix >> script substitute) module. >> >> It looks like its because a 'bad-headers exception is raised when trying >> to parse an eof object: >> >> --8<---------------cut here---------------start------------->8--- >> ;;; (error bad-header (read-header-line #<eof>)) >> --8<---------------cut here---------------end--------------->8--- >> >> I'm not sure where this eof comes from. There is this comment in the >> http-multiple-get procedure in (guix http-client): >> >> --8<---------------cut here---------------start------------->8--- >> ;; Swallow networking errors that could occur due to connection reuse >> ;; and the like; they will be handled down the road when trying to >> ;; read responses. >> (false-if-networking-error >> (begin >> (for-each (cut write-request <> buffer) batch) >> (put-bytevector p (get)) >> (force-output p)))) >> --8<---------------cut here---------------end--------------->8--- >> >> which would suggest that connection reuse could cause networking errors? [...] > That's on the server side, the actual problem is probably on the client > side, as I guess there are possibly places where closed connections > aren't handled properly. D’oh. So we should be able to use it by talking to a bare ‘guix publish’? I tried and failed to reproduce it, but that’s probably not deterministic. > This reminds me I sent some patches relating to closing connections, > this could well be related [1]. > > 1: https://issues.guix.gnu.org/47174 This one will properly close connections when the servers asks for it, but would that make a difference? Thanks, Ludo’.