2011-09-11 14:05:08 +00:00
|
|
|
.. _guide-connections:
|
|
|
|
|
2010-08-05 16:16:02 +00:00
|
|
|
============================
|
|
|
|
Connections and transports
|
|
|
|
============================
|
|
|
|
|
2011-09-11 14:05:08 +00:00
|
|
|
.. _connection-basics:
|
|
|
|
|
|
|
|
Basics
|
|
|
|
======
|
|
|
|
|
2010-08-05 16:16:02 +00:00
|
|
|
To send and receive messages you need a transport and a connection.
|
|
|
|
There are several transports to choose from (amqplib, pika, redis, in-memory),
|
|
|
|
and you can even create your own. The default transport is amqplib.
|
|
|
|
|
|
|
|
Create a connection using the default transport::
|
|
|
|
|
|
|
|
>>> from kombu import BrokerConnection
|
2011-09-11 14:05:08 +00:00
|
|
|
>>> connection = BrokerConnection("amqp://guest:guest@localhost:5672//")
|
2010-08-05 16:16:02 +00:00
|
|
|
|
|
|
|
The connection will not be established yet, as the connection is established
|
|
|
|
when needed. If you want to explicitly establish the connection
|
|
|
|
you have to call the :meth:`~kombu.connection.BrokerConnection.connect`
|
|
|
|
method::
|
|
|
|
|
|
|
|
>>> connection.connect()
|
|
|
|
|
2011-09-11 14:05:08 +00:00
|
|
|
You can also check wether the connection is connected::
|
|
|
|
|
|
|
|
>>> connection.connected()
|
|
|
|
True
|
|
|
|
|
|
|
|
Connections must always be closed after use::
|
|
|
|
|
|
|
|
>>> connection.close()
|
|
|
|
|
|
|
|
But best practice is to release the connection instead,
|
|
|
|
this will release the resource if the connection is associated
|
|
|
|
with a connection pool, or close the connection if not,
|
|
|
|
and makes it easier to transist to connection pools later::
|
|
|
|
|
|
|
|
>>> connection.release()
|
|
|
|
|
|
|
|
.. seealso::
|
|
|
|
|
|
|
|
:ref:`guide-pools`
|
|
|
|
|
|
|
|
Of course, the connection can be used as a context, and you are
|
|
|
|
encouraged to do so as it makes it harder to forget releasing open
|
|
|
|
resources::
|
|
|
|
|
|
|
|
with BrokerConnection() as connection:
|
|
|
|
# work with connection
|
|
|
|
|
|
|
|
.. _connection-urls:
|
|
|
|
|
|
|
|
URLs
|
|
|
|
====
|
|
|
|
|
|
|
|
Connection parameters can be provided as an URL in the format::
|
|
|
|
|
|
|
|
transport://userid:password@hostname:port/virtual_host
|
|
|
|
|
|
|
|
All of these are valid URLs::
|
|
|
|
|
|
|
|
# Specifies using the amqp transport only, default values
|
|
|
|
# are taken from the keyword arguments.
|
|
|
|
amqp://
|
|
|
|
|
|
|
|
# Using Redis
|
|
|
|
redis://localhost:6379/
|
|
|
|
|
|
|
|
# Using virtual host '/foo'
|
|
|
|
amqp://localhost//foo
|
|
|
|
|
|
|
|
# Using virtual host 'foo'
|
|
|
|
amqp://localhost/foo
|
|
|
|
|
|
|
|
The query part of the URL can also be used to set options, e.g.::
|
|
|
|
|
|
|
|
amqp://localhost/myvhost?ssl=1
|
|
|
|
|
|
|
|
See :ref:`connection-options` for a list of supported options.
|
|
|
|
|
|
|
|
A connection without options will use the default connection settings,
|
|
|
|
which is using the localhost host, default port, username `guest`,
|
2010-10-27 07:17:37 +00:00
|
|
|
password `guest` and virtual host "/". A connection without arguments
|
2010-08-05 16:16:02 +00:00
|
|
|
is the same as::
|
|
|
|
|
2011-09-11 14:05:08 +00:00
|
|
|
>>> BrokerConnection("amqp://guest:guest@localhost:5672//")
|
2010-08-05 16:16:02 +00:00
|
|
|
|
2011-09-11 14:05:08 +00:00
|
|
|
The default port is transport specific, for AMQP this is 5672.
|
2010-08-05 16:16:02 +00:00
|
|
|
|
|
|
|
Other fields may also have different meaning depending on the transport
|
2010-10-27 07:17:37 +00:00
|
|
|
used. For example, the Redis transport uses the `virtual_host` argument as
|
2010-08-05 16:16:02 +00:00
|
|
|
the redis database number.
|
|
|
|
|
2011-09-11 14:05:08 +00:00
|
|
|
.. _connection-options:
|
|
|
|
|
|
|
|
Keyword arguments
|
|
|
|
=================
|
|
|
|
|
|
|
|
The :class:`BrokerConnection` class supports additional
|
|
|
|
keyword arguments, these are:
|
|
|
|
|
|
|
|
:hostname: Default hostname if not provided in the URL.
|
|
|
|
:userid: Default username if not provided in the URL.
|
|
|
|
:password: Default password if not provided in the URL.
|
|
|
|
:virtual_host: Default virtual host if not provided in the URL.
|
|
|
|
:port: Default port if not provided in the URL.
|
|
|
|
:transport: Default transport if not provided in the URL.
|
|
|
|
Can be a string specifying the path to the class. (e.g.
|
|
|
|
``kombu.transport.pyamqplib.Transport``), or one of the aliases:
|
2011-09-12 09:25:42 +00:00
|
|
|
``amqplib``, ``pika``, ``redis``, ``memory``, and so on.
|
2011-09-11 14:05:08 +00:00
|
|
|
|
|
|
|
:ssl: Use ssl to connect to the server. Default is ``False``.
|
|
|
|
Only supported by the amqp transport.
|
|
|
|
:insist: Insist on connecting to a server.
|
|
|
|
In a configuration with multiple load-sharing servers, the insist
|
|
|
|
option tells the server that the client is insisting on a connection
|
|
|
|
to the specified server. Default is ``False``.
|
|
|
|
Only supported by the amqp and pika transports, and not by AMQP 0-9-1.
|
|
|
|
:connect_timeout: Timeout in seconds for connecting to the
|
|
|
|
server. May not be suported by the specified transport.
|
|
|
|
:transport_options: A dict of additional connection arguments to
|
|
|
|
pass to alternate kombu channel implementations. Consult the transport
|
|
|
|
documentation for available options.
|
|
|
|
|
|
|
|
Transport Comparison
|
|
|
|
====================
|
|
|
|
|
|
|
|
+---------------+----------+------------+-----------+---------------+
|
|
|
|
| **Client** | **Type** | **Direct** | **Topic** | **Fanout** |
|
|
|
|
+---------------+----------+------------+-----------+---------------+
|
|
|
|
| *amqplib* | Native | Yes | Yes | Yes |
|
|
|
|
+---------------+----------+------------+-----------+---------------+
|
|
|
|
| *pika* | Native | Yes | Yes | Yes |
|
|
|
|
+---------------+----------+------------+-----------+---------------+
|
|
|
|
| *redis* | Virtual | Yes | Yes[*]_ | Yes (PUB/SUB) |
|
|
|
|
+---------------+----------+------------+-----------+---------------+
|
|
|
|
| *beanstalk* | Virtual | Yes | Yes[*]_ | No |
|
|
|
|
+---------------+----------+------------+-----------+---------------+
|
|
|
|
| *SQS* | Virtual | Yes | Yes[*]_ | Yes[#]_ |
|
|
|
|
+---------------+----------+------------+-----------+---------------+
|
|
|
|
| *mongodb* | Virtual | Yes | Yes[*]_ | No |
|
|
|
|
+---------------+----------+------------+-----------+---------------+
|
|
|
|
| *couchdb* | Virtual | Yes | Yes[*]_ | No |
|
|
|
|
+---------------+----------+------------+-----------+---------------+
|
|
|
|
| *in-memory* | Virtual | Yes | Yes[*]_ | No |
|
|
|
|
+---------------+----------+------------+-----------+---------------+
|
|
|
|
|
|
|
|
|
|
|
|
.. [*] Declarations only kept in memory, so exchanges/queues
|
|
|
|
must be declared by all clients that needs them.
|
|
|
|
|
|
|
|
.. [#] Fanout supported via storing routing tables in SimpleDB.
|
|
|
|
Can be disabled by setting the ``supports_fanout`` transport option.
|