Skip to main content

Gearman Task Server

Project description

Simple multiprocessing server for gearman.

Until I get a chance to write better documentation, please look at the sample usage below.

Sample usage

from multiprocessing   import freeze_support
from gmtasks.jsonclass import GearmanWorker
from gmtasks           import GearmanTaskServer, Task

# Jobs
def job1(worker, job):
    return job.data['string1']
def job2(worker, job):
    return job.data['string2']
def job3(worker, job):
    return job.data['string3']

# Main loop
if __name__ == '__main__':
    # Need this to run in Windows
    freeze_support()
    # Import all of the jobs we handle
    tasks = [
        Task('job1', job1),
        {'task': 'job2', 'callback': job2},
        ['job3', job3],
        ]
    # Initialize the server
    server = GearmanTaskServer(
        host_list   = ['localhost:4730'],
        tasks       = tasks,
        max_workers = None, # Defaults to multiprocessing.cpu_count()
        id_prefix   = 'myworker.',
        GMWorker    = GearmanWorker,
        sighandler  = True, # SIGINT and SIGTERM send KeyboardInterrupt
        verbose     = True, # log.info() and log.error() messages
        )
    # Run the loop
    server.serve_forever()

Download

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

gmtasks-0.2.tar.gz (5.3 kB view hashes)

Uploaded Source

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