Page MenuHomePhabricator

[tunnelbroker] Implement lazy AMQP channel wrapper
ClosedPublic

Authored by bartek on Oct 6 2024, 11:51 PM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Dec 18, 11:25 AM
Unknown Object (File)
Wed, Dec 18, 11:25 AM
Unknown Object (File)
Wed, Dec 18, 11:24 AM
Unknown Object (File)
Wed, Dec 18, 11:24 AM
Unknown Object (File)
Mon, Dec 9, 1:45 PM
Unknown Object (File)
Nov 25 2024, 2:07 AM
Unknown Object (File)
Nov 21 2024, 11:54 PM
Unknown Object (File)
Nov 21 2024, 5:15 PM
Subscribers

Details

Summary

This cancels minor quality regression introduced earlier in D13604.

  • For websocket, we store the channel in the WebsocketSession struct and reuse it unless it's broken
  • However for gRPC, after opted out of channel pool, a new short-lived channel is created for every single call, which is against what RabbitMQ recommends.

Created a simple wrapper that lazily-initializes the channel upon first use, and creates a new one only if the previous was closed.

Depends on D13611

Test Plan

Added some additional logging and ran Commtest

Diff Detail

Repository
rCOMM Comm
Lint
No Lint Coverage
Unit
No Test Coverage