Explain why Listener connections cannot be pooled

Restoring an old comment to the code that explains why the RabbitMQ
driver provides a dedicated connection for each listener.

Change-Id: If833d41d78444cc26535cb165ea821dce21b768b
This commit is contained in:
Kenneth Giusti 2019-02-25 11:35:43 -05:00
parent 472d483942
commit 83a84d3f98

View File

@ -399,11 +399,32 @@ class ConnectionContext(Connection):
"""Create a new connection, or get one from the pool.""" """Create a new connection, or get one from the pool."""
self.connection = None self.connection = None
self.connection_pool = connection_pool self.connection_pool = connection_pool
# NOTE(sileht): Even if rabbit only has one Connection class this
# connection can be used for only one of two purposes:
#
# * receiving messages from the broker (read actions on the socket)
# * sending messages to the broker (write actions on the socket)
#
# Using one Connection class instance for both purposes will result in
# eventlet complaining about multiple greenthreads that read/write the
# same fd concurrently. This is because 'send' and 'listen' run in
# different greenthreads and the code inside a connection class is not
# concurrency safe. The 'purpose' parameter ensures that no connection
# is used for both sending and receiving messages.
#
# The rabbitmq driver allocates connections in the following manner:
# * driver.listen*(): each call creates a new dedicated
# 'PURPOSE_LISTEN' connection for the listener
# * driver.send*(): senders are assigned a connection from a pool of
# 'PURPOSE_SEND' connections maintained by the driver.
# * One 'PURPOSE_LISTEN' connection is dedicated to waiting for replies
# to rpc calls.
pooled = purpose == PURPOSE_SEND pooled = purpose == PURPOSE_SEND
if pooled: if pooled:
self.connection = connection_pool.get() self.connection = connection_pool.get()
else: else:
# a non-pooled connection is requested, so create a new connection
self.connection = connection_pool.create(purpose) self.connection = connection_pool.create(purpose)
self.pooled = pooled self.pooled = pooled
self.connection.pooled = pooled self.connection.pooled = pooled