chore(protocol): prioritize closing a connection (#9711)

The read/write loops may keep going for a while on a closing connection
with lots of read/write activity, as it's random which select case is
chosen. And if the connection is slow or even broken, a single
read/write
can take a long time/until timeout. Add initial non-blocking selects
with only the cases relevant to closing, to prioritize those.
This commit is contained in:
Simon Frei 2024-09-15 21:13:56 +02:00 committed by GitHub
parent 2238a288d9
commit 1f4fde9525
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -465,6 +465,11 @@ func (c *rawConnection) dispatcherLoop() (err error) {
var msg message var msg message
state := stateInitial state := stateInitial
for { for {
select {
case <-c.closed:
return ErrClosed
default:
}
select { select {
case msg = <-c.inbox: case msg = <-c.inbox:
case <-c.closed: case <-c.closed:
@ -758,6 +763,17 @@ func (c *rawConnection) writerLoop() {
return return
} }
for { for {
// When the connection is closing or closed, that should happen
// immediately, not compete with the (potentially very busy) outbox.
select {
case hm := <-c.closeBox:
_ = c.writeMessage(hm.msg)
close(hm.done)
return
case <-c.closed:
return
default:
}
select { select {
case cc := <-c.clusterConfigBox: case cc := <-c.clusterConfigBox:
err := c.writeMessage(cc) err := c.writeMessage(cc)