Skip to main content

Interface for TaskQueue

Project description

Support for Python client for Task Queue Rest API using gcloud

Required Dependencies

The following third-party Python modules are required: - gcloud

The easiest way to install the dependencies is to run:

$ pip install -r requirements.txt

Why an interface to the Task Queue API?

The Google Cloud Client Library for Python (gcloud) is great, but it’s missing an interface to the Task Queue Rest API. This is understandable, because the API is experimental and still in alpha, and not fully accesble from outside the App Egine. And gcloud does support Pubsub.

However, Task Queues offer a few functions that aren’t available in Pubsub. And although Push Queues are restricted to use within App Engine, Pull Queues can be used outside the App Engine enviroment.

With Pull Queues a worker can lease tasks for a certain period. During this period, the tasks aren’t available to other workers. This prevents processing a single task multiple times by different workers. This makes Task Queues very useful for background processing, for example in combination with object change notifications, to process objects in a Storage Bucket the moment they are changed or created.

Example

Example:

>>> from gcloud_taskqueue import Taskqueue, Client

For object change notifications, you need to create a service account. To pull tasks created with this account, you need to use it’s credentials:

>>> json_credentials_path = "/path/to/my-service-credential.json"
>>> client = Client.from_service_account_json(json_credentials_path, project="my-project")

Get taskqueue:

>>> tq = Taskqueue(client=client, id="my-taskqueue")

Get tasks in taskqueue:

>>> for task in tq.list_tasks(client=client):
>>>     print("{}\t{}\t{}".format(task.id, task.leaseTimestamp, task.retry_count))

Lease 10 tasks for 60 seconds:

>>> for task in tq.lease(lease_time=60, num_tasks=10, client=client):
>>>     print("{}\t{}\t{}".format(task.id, task.leaseTimestamp, task.retry_count))

Lease 10 tasks with specific tag for 60 seconds:

>>> for task in tq.lease(lease_time=60, num_tasks=10, tag='my-tag', client=client):
>>>     print("{}\t{}\t{}".format(task.id, task.leaseTimestamp, task.retry_count))

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gcloud_taskqueue-0.0.10.tar.gz (7.5 kB view details)

Uploaded Source

Built Distribution

gcloud_taskqueue-0.0.10-py2.py3-none-any.whl (12.9 kB view details)

Uploaded Python 2Python 3

File details

Details for the file gcloud_taskqueue-0.0.10.tar.gz.

File metadata

File hashes

Hashes for gcloud_taskqueue-0.0.10.tar.gz
Algorithm Hash digest
SHA256 deec22bb4bf80f8ff260fa7081115d5d5afb433c1232a847553ab9364ac3ebb5
MD5 6b930b5e36971a8cccabefc4eace45e2
BLAKE2b-256 0eb4e011e3ba22373ec6254c113db8a64615f5c700656c40339f8caf99d05ed8

See more details on using hashes here.

File details

Details for the file gcloud_taskqueue-0.0.10-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for gcloud_taskqueue-0.0.10-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 88beeeda9aec9745b4bd2c780502cc3cdfb155825d60aeb075ebc34dd0c330a1
MD5 5dd1011a0c6ebb781a85b09fc7647a80
BLAKE2b-256 534d14e941841863ecf67813ee527f2965353b258d625766b63841da3832eda2

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page