Skip to main content

Rocket task manager

Project description

pythonversions

Rocket task manager

Asynchronous task manager in python

Install

pip install rockettm

Link pypi: https://pypi.python.org/pypi/rockettm

Example

Redis not is localhost

from rockettm import connect

# to run it, reconnect to Redis
connect("other_ip_or_domain")

Configure logger in client

Using standard logger in python https://docs.python.org/2/library/logging.html#logging.basicConfig

import logging
from rockettm import send_task

# 50 CRITICAL, 40 ERROR, 30 WARNING, 20 INFO, 10 DEBUG, 0 NOTSET
logging.basicConfig(level=20)
send_task("queue_name", "name_task", "Pepito")

Configure logger in server

in settings.py:

# filename (DEFAULT "rockettm.log")
# level (DEFAULT 30)
# 50 CRITICAL, 40 ERROR, 30 WARNING, 20 INFO, 10 DEBUG, 0 NOTSET
logger = {'filename': "rockettm.log",  # optional,
                                       # is not defined print in console
          'level': 10  # optional
         }

Send task

# send task
from rockettm import send_task

send_task("queue_name", "name_task", "arg1", ["arg2", "2"], {'args': 3}, ('arg', 4), example="ok")

Declare new task

Warning! if there are 2 tasks registered with the same name, will run 2!

# task example
from rockettm import task


@task('name_task')
def function1(*args, **kwargs):
    return True

# max_time(timeout in seconds) example
@task('name_task2', max_time=10)
def long_call(*args, **kwargs):
    return True

settings.py example

# settings.py example
ip = "127.0.0.1"
port = 5672

logger = {'filename': "rockettm.log",  # optional,
                                       # is not defined print in console
          'level': 10  # optional
          }

# search @task in imports
imports = ['examples.test1',
           'examples.test2']

# support params
# name (mandatory), string
# concurrency (mandatory), int
# durable (optional), boolean
# max_time (in seconds) (optional), int
queues = [{'name': 'rocket1', 'durable': True, 'concurrency': 7},
          {'name': 'rocket2', 'concurrency': 1},
          {'name': 'rocket3', 'concurrency': 1, 'max_time': 10}]

Run server

rockettm_server file_settings.py

Documentation

Functions

  • task(name_task_event)

It is a decorator to create tasks

  • send_task(queue, name_task, *args)

Send task

  • add_task(name_task, func(object))

Add manual task

  • connect(ip_or_domain)

connects to another server other than localhost

Basicevents

rockettm currently used basicevents for noticificaciones the api. You can use basicevents as its official documentation *

  • Do not need to run(), rockettm up a common process for all workers

https://github.com/agalera/basicevents

CHANGELOG

2.2.13 (2017-05-16)

  • remove prints …

2.2.12 (2017-05-16)

  • fix gevent incompatibility (timekiller)

2.2.11 (2017-05-11)

  • fix gevent incompatibility

2.2.10 (2017-04-24)

  • qsize support name and namespace arguments

  • empty support name and namespace arguments

2.2.9 (2017-04-19)

  • only support ujson

  • fix serializer

2.2.8 (2017-04-19)

  • fix import

2.2.4 (2017-04-19)

  • fix dependencies

2.2.3 (2017-04-07)

  • Graceful stop

2.2.2 (2017-03-31)

  • support force exit

2.2.1 (2017-03-31)

  • sigterm safe

2.2.0 (2017-03-18)

  • callback is optional

  • return callback to rabbitmq (queue results)

  • Support return other results to basicevents (send(“results”, “type”, “data”))

2.1.11 (2016-12-12)

  • Fix dependencies conflict

2.1.11 (2016-11-02)

  • Fix dependencies conflict

2.1.10 (2016-10-20)

  • Clean code

2.1.9 (2016-10-19)

  • prevent infinite callback

2.1.6 (2016-09-29)

  • send return False with failed send

2.1.5 (2016-09-29)

  • Fix name var

2.1.4 (2016-09-29)

  • Support custom id

2.1.3 (2016-09-28)

  • Supported basicevents

2.1.2 (2016-09-28)

  • Fix dead MainThread in Python 3.4.2

2.1.1 (2016-09-21)

  • clean code

2.1.0 (2016-09-21)

  • call api in init tasks and return status task

2.0.6 (2016-09-20)

  • added support kwargs in tasks

2.0.5 (2016-09-07)

  • Revert heartbeat

2.0.4 (2016-09-07)

  • implemented heartbeat

  • fix ack failed for loss connection

2.0.3 (2016-09-07)

  • prevent relaunch finish task

2.0.2 (2016-09-07)

  • Change prefetch to 1

2.0.1 (2016-09-06)

  • Reuse connection in send_tasks

2.0.0 (2016-09-06)

  • Migrate pika to kambu

1.0.16 (2016-09-06)

  • Fix ack

1.0.8 - 1.0.15 (2016-09-06)

  • clean code

1.0.8 - 1.0.13 (2016-09-05)

  • fix timeouts and other exceptions

1.0.7 (2016-09-05)

  • fix rabbitmq ack timeout

1.0.6 (2016-08-26)

  • retry sending the message to the queue 5 times before returning an exception

  • When you add in the queue fails, now returns an exception

1.0.5 (2016-08-26)

  • timekiller stop propagate

  • fix inmortal server

1.0.4 (2016-08-25)

  • run tasks in safe and isolated proccess

1.0.3 (2016-08-25)

  • Solved multiple errors with disconnection with RabbitMQ

  • Update python compatibility (py2.x no loger supported)

1.0.2 (2016-08-23)

  • Fix automatic declare queues

1.0.1 (2016-08-22)

  • send_task now sends the set ip

1.0.0 (2016-07-19)

  • Added callback support

  • generate uuid for task

  • all tasks get _id in first attr

  • if multiple tasks with the same name, if continued with the following fails

  • prevent connection closed to send_task (automatic reconnect)

0.2.6 (2016-07-15)

  • py3 compatibility

  • fix hardcoding durable

  • ignore not exists logger config

0.2.5 (2016-07-15)

  • py3 compatibility

0.2.4 (2016-07-15)

  • Fix automatic declare queue

0.2.3 (2016-06-14)

  • Add new dependency (timekiller)

0.2.2 (2016-06-14)

  • hotfix bad raise

0.2.1 (2016-06-14)

  • Hotfix rabbitmq_server command

0.2.0 (2016-06-13)

  • add support timeout (tasks and queues)

0.1.1 (2016-04-27)

  • Fix dependencies

0.1.0 (2016-03-22)

  • Permit change log

0.0.4 (2016-03-21)

  • Fix CHANGELOG

  • Update README

0.0.3 (2016-03-21)

  • Permit connect different rabbitmq server

  • Prevent channel_closed

  • Support durable queues

0.0.2 (2016-03-14)

  • Add documentation

0.0.1 (2016-03-14)

  • initial version

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

rockettm-2.2.14.tar.gz (7.1 kB view details)

Uploaded Source

File details

Details for the file rockettm-2.2.14.tar.gz.

File metadata

  • Download URL: rockettm-2.2.14.tar.gz
  • Upload date:
  • Size: 7.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for rockettm-2.2.14.tar.gz
Algorithm Hash digest
SHA256 4aeb0a13126530223f01e3e4f4fe6484d94f1d47bf5ef3ab0ed2d5e0f1c0464f
MD5 a3d53e9210bdfbebbb426ff15f867016
BLAKE2b-256 ec8a2806e46b741b515bd1e46e4de06187c50d19094defde9c4b4ee7ade58de8

See more details on using hashes here.

Supported by

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