The zaqar.storage.pooling
module¶
-
class
Catalog
(conf, cache, control)¶ Bases:
object
Represents the mapping between queues and pool drivers.
-
deregister
(*args, **kwargs)¶ Removes a queue from the pool catalog.
Call this method after successfully deleting it from a backend pool.
Parameters: - queue (six.text_type) – Name of the new queue to assign to a pool
- project (six.text_type) – Project to which the queue belongs, or None for the “global” or “generic” project.
-
get_claim_controller
(queue, project=None)¶ Lookup the claim controller for the given queue and project.
Parameters: - queue – Name of the queue for which to find a pool
- project – Project to which the queue belongs, or None to specify the “global” or “generic” project.
Returns: The claim controller associated with the data driver for the pool containing (queue, project) or None if this doesn’t exist.
Return type: Maybe ClaimController
-
get_default_pool
(use_listing=True)¶
-
get_driver
(pool_id, pool_conf=None)¶ Get storage driver, preferably cached, from a pool name.
Parameters: pool_id (six.text_type) – The name of a pool. Returns: a storage driver Return type: zaqar.storage.base.DataDriver
-
get_message_controller
(queue, project=None)¶ Lookup the message controller for the given queue and project.
Parameters: - queue – Name of the queue for which to find a pool
- project – Project to which the queue belongs, or None to specify the “global” or “generic” project.
Returns: The message controller associated with the data driver for the pool containing (queue, project) or None if this doesn’t exist.
Return type: Maybe MessageController
-
get_queue_controller
(queue, project=None)¶ Lookup the queue controller for the given queue and project.
Parameters: - queue – Name of the queue for which to find a pool
- project – Project to which the queue belongs, or None to specify the “global” or “generic” project.
Returns: The queue controller associated with the data driver for the pool containing (queue, project) or None if this doesn’t exist.
Return type: Maybe QueueController
-
get_subscription_controller
(queue, project=None)¶ Lookup the subscription controller for the given queue and project.
Parameters: - queue – Name of the queue for which to find a pool
- project – Project to which the queue belongs, or None to specify the “global” or “generic” project.
Returns: The subscription controller associated with the data driver for the pool containing (queue, project) or None if this doesn’t exist.
Return type: Maybe SubscriptionController
-
lookup
(queue, project=None)¶ Lookup a pool driver for the given queue and project.
Parameters: - queue – Name of the queue for which to find a pool
- project – Project to which the queue belongs, or None to specify the “global” or “generic” project.
Returns: A storage driver instance for the appropriate pool. If the driver does not exist yet, it is created and cached. If the queue is not mapped, returns None.
Return type: Maybe DataDriver
-
register
(queue, project=None, flavor=None)¶ Register a new queue in the pool catalog.
This method should be called whenever a new queue is being created, and will create an entry in the pool catalog for the given queue.
After using this method to register the queue in the catalog, the caller should call lookup() to get a reference to a storage driver which will allow interacting with the queue’s assigned backend pool.
Parameters: - queue (six.text_type) – Name of the new queue to assign to a pool
- project (six.text_type) – Project to which the queue belongs, or None for the “global” or “generic” project.
- flavor (six.text_type) – Flavor for the queue (OPTIONAL)
Raises: NoPoolFound
-
-
class
ClaimController
(pool_catalog)¶ Bases:
zaqar.storage.base.Claim
Routes operations to a claim controller in the appropriate pool.
Parameters: pool_catalog (queues.pooling.base.Catalog) – a catalog of available pools -
create
(queue, metadata, project=None, limit=10)¶
-
delete
(queue, claim_id, project=None)¶
-
get
(queue, claim_id, project=None)¶
-
update
(queue, claim_id, metadata, project=None)¶
-
-
class
DataDriver
(conf, cache, control, control_driver=None)¶ Bases:
zaqar.storage.base.DataDriverBase
Pooling meta-driver for routing requests to multiple backends.
Parameters: - conf – Configuration from which to read pooling options
- cache – Cache instance that will be passed to individual storage driver instances that correspond to each pool. will also be used by the pool controller to reduce latency for some operations.
-
BASE_CAPABILITIES
= (<Capabilities.FIFO: 1>, <Capabilities.CLAIMS: 2>, <Capabilities.DURABILITY: 3>, <Capabilities.AOD: 4>, <Capabilities.HIGH_THROUGHPUT: 5>)¶
-
capabilities
¶
-
claim_controller
¶
-
close
()¶
-
gc
()¶
-
is_alive
()¶
-
message_controller
¶
-
queue_controller
¶
-
subscription_controller
¶
-
class
MessageController
(pool_catalog)¶ Bases:
zaqar.storage.base.Message
Routes operations to a message controller in the appropriate pool.
Parameters: pool_catalog (queues.pooling.base.Catalog) – a catalog of available pools -
bulk_delete
(queue, message_ids, project=None)¶
-
bulk_get
(queue, message_ids, project=None)¶
-
delete
(queue, message_id, project=None, claim=None)¶
-
first
(queue, project=None, sort=1)¶
-
get
(queue, message_id, project=None)¶
-
list
(queue, project=None, marker=None, limit=10, echo=False, client_uuid=None, include_claimed=False)¶
-
pop
(queue, limit, project=None)¶
-
post
(queue, messages, client_uuid, project=None)¶
-
-
class
QueueController
(pool_catalog)¶ Bases:
zaqar.storage.base.Queue
Routes operations to a queue controller in the appropriate pool.
Parameters: pool_catalog (queues.pooling.base.Catalog) – a catalog of available pools -
get_metadata
(name, project=None)¶
-
set_metadata
(name, metadata, project=None)¶
-
-
class
SubscriptionController
(pool_catalog)¶ Bases:
zaqar.storage.base.Subscription
Controller to facilitate processing for subscription operations.
-
confirm
(queue, subscription_id, project=None, confirmed=None)¶
-
create
(queue, subscriber, ttl, options, project=None)¶
-
delete
(queue, subscription_id, project=None)¶
-
exists
(queue, subscription_id, project=None)¶
-
get
(queue, subscription_id, project=None)¶
-
get_with_subscriber
(queue, subscriber, project=None)¶
-
list
(queue, project=None, marker=None, limit=10)¶
-
update
(queue, subscription_id, project=None, **kwargs)¶
-