kombu/docs/userguide/pools.rst

193 lines
5.3 KiB
ReStructuredText
Raw Normal View History

2011-09-11 14:06:24 +00:00
.. _guide-pools:
===============================
Connection and Producer Pools
===============================
.. _default-pools:
Default Pools
=============
Kombu ships with two global pools: one connection pool,
and one producer pool.
These are convenient and the fact that they are global
may not be an issue as connections should often be limited
at the process level, rather than per thread/application
and so on, but if you need custom pools per thread
see :ref:`custom-pool-groups`.
.. _default-connections:
The connection pool group
-------------------------
The connection pools are available as :attr:`kombu.pools.connections`.
This is a pool group, which means you give it a connection instance,
and you get a pool instance back. We have one pool per connection
2011-09-11 14:06:24 +00:00
instance to support multiple connections in the same app.
All connection instances with the same connection parameters will
2016-04-07 22:59:26 +00:00
get the same pool:
.. code-block:: pycon
2011-09-11 14:06:24 +00:00
>>> from kombu import Connection
2011-09-11 14:06:24 +00:00
>>> from kombu.pools import connections
>>> connections[Connection('redis://localhost:6379')]
2011-09-11 14:06:24 +00:00
<kombu.connection.ConnectionPool object at 0x101805650>
>>> connections[Connection('redis://localhost:6379')]
2011-09-11 14:06:24 +00:00
<kombu.connection.ConnectionPool object at 0x101805650>
Let's acquire and release a connection:
.. code-block:: python
from kombu import Connection
2011-09-11 14:06:24 +00:00
from kombu.pools import connections
connection = Connection('redis://localhost:6379')
2011-09-11 14:06:24 +00:00
with connections[connection].acquire(block=True) as conn:
print('Got connection: {0!r}'.format(connection.as_uri()))
2011-09-11 14:06:24 +00:00
.. note::
The ``block=True`` here means that the acquire call will block
until a connection is available in the pool.
Note that this will block forever in case there is a deadlock
in your code where a connection is not released. There
2011-09-11 14:06:24 +00:00
is a ``timeout`` argument you can use to safeguard against this
(see :meth:`kombu.connection.Resource.acquire`).
If blocking is disabled and there aren't any connections
left in the pool an :class:`kombu.exceptions.ConnectionLimitExceeded`
exception will be raised.
That's about it. If you need to connect to multiple brokers
2011-09-11 14:06:24 +00:00
at once you can do that too:
.. code-block:: python
from kombu import Connection
2011-09-11 14:06:24 +00:00
from kombu.pools import connections
c1 = Connection('amqp://')
c2 = Connection('redis://')
2011-09-11 14:06:24 +00:00
with connections[c1].acquire(block=True) as conn1:
with connections[c2].acquire(block=True) as conn2:
# ....
.. _default-producers:
The producer pool group
=======================
This is a pool group just like the connections, except
that it manages :class:`~kombu.Producer` instances
2012-01-05 17:20:55 +00:00
used to publish messages.
2011-09-11 14:06:24 +00:00
Here is an example using the producer pool to publish a message
to the ``news`` exchange:
.. code-block:: python
from kombu import Connection, Exchange
2011-09-11 14:06:24 +00:00
from kombu.pools import producers
# The exchange we send our news articles to.
news_exchange = Exchange('news')
2011-09-11 14:06:24 +00:00
# The article we want to send
article = {'title': 'No cellular coverage on the tube for 2012',
'ingress': 'yadda yadda yadda'}
2011-09-11 14:06:24 +00:00
# The broker where our exchange is.
connection = Connection('amqp://guest:guest@localhost:5672//')
2011-09-11 14:06:24 +00:00
with producers[connection].acquire(block=True) as producer:
producer.publish(
article,
exchange=news_exchange,
routing_key='domestic',
declare=[news_exchange],
serializer='json',
compression='zlib')
2011-09-11 14:06:24 +00:00
.. _default-pool-limits:
Pool limits
2011-09-11 14:06:24 +00:00
-------------------
By default every connection instance has a limit of 10 connections.
2011-09-11 14:06:24 +00:00
You can change this limit using :func:`kombu.pools.set_limit`.
You are able to grow the pool at runtime, but you can't shrink it,
so it is best to set the limit as early as possible after your application
2016-04-07 22:59:26 +00:00
starts:
.. code-block:: pycon
2011-09-11 14:06:24 +00:00
>>> from kombu import pools
>>> pools.set_limit()
You can also get current limit using :func:`kombu.pools.get_limit`:
.. code-block:: pycon
>>> from kombu import pools
>>> pools.get_limit()
10
>>> pools.set_limit(100)
100
>>> kombu.pools.get_limit()
100
2011-09-11 14:06:24 +00:00
Resetting all pools
-------------------
You can close all active connections and reset all pool groups by
using the :func:`kombu.pools.reset` function. Note that this
2011-09-11 14:06:24 +00:00
will not respect anything currently using these connections,
so will just drag the connections away from under their feet:
you should be very careful before you use this.
Kombu will reset the pools if the process is forked,
so that forked processes start with clean pool groups.
.. _custom-pool-groups:
Custom Pool Groups
==================
To maintain your own pool groups you should create your own
:class:`~kombu.pools.Connections` and :class:`kombu.pools.Producers`
instances:
.. code-block:: python
from kombu import pools
from kombu import Connection
2011-09-11 14:06:24 +00:00
2015-07-01 11:51:40 +00:00
connections = pools.Connections(limit=100)
2011-09-11 14:06:24 +00:00
producers = pools.Producers(limit=connections.limit)
connection = Connection('amqp://guest:guest@localhost:5672//')
2011-09-11 14:06:24 +00:00
with connections[connection].acquire(block=True):
# ...
If you want to use the global limit that can be set with
:func:`~kombu.pools.set_limit` you can use a special value as the ``limit``
argument:
.. code-block:: python
from kombu import pools
connections = pools.Connections(limit=pools.use_default_limit)