使用 python 脚本安排 sidekiq 作业

gab*_*aba 5 python api task sidekiq luigi

我让 Sidekiq 与 Rails 应用程序一起运行。我需要能够从 Python 脚本运行作业(因为我通常使用 Luigi 来运行任务)。我正在寻找一个与 Sidekiq API 一起使用的 Python 库,但到目前为止还没有成功。对此有什么想法或想法吗?

Nan*_*ana 6

这是 Python 的翻译:

import redis
import json

from random import choice
from datetime import datetime

sidekiq_queues = redis.Redis(host=host, port=port, db=db, password=password)

queue = 'my_queue'
job = 'MyJob'
arguments = 123456789

value = {
    "class": job,
    "queue": queue,
    "args": [arguments],
    "retry": 'true',
    "jid": ''.join([choice('qwertyuiopasdfghjklzxcvbnm1234567890') for i in range(24)]),
    "created_at": datetime.now().timestamp(),
    "enqueued_at": datetime.now().timestamp()}

sidekiq_queues.sadd(f"queues", queue)
sidekiq_queues.lpush(f"queue:{queue}" , json.dumps(value))
Run Code Online (Sandbox Code Playgroud)


Mik*_*ham 4

https://github.com/mperham/sidekiq/wiki/FAQ#how-do-i-push-a-job-to-sidekiq-without-ruby

这是最简单的Ruby,将其翻译成Python:

require 'securerandom'
require 'json'

redis = Redis.new(:url => 'redis://hostname:port/db')
msg = { "class" => 'MyWorker',
    "queue" => 'default',
    "args" => [1, 2, 3],
    'retry' => true,
    'jid' => SecureRandom.hex(12),
    'created_at' => Time.now.to_f,
    'enqueued_at' => Time.now.to_f }
redis.lpush("queue:default", JSON.dump(msg))
Run Code Online (Sandbox Code Playgroud)

  • 针对本地主机运行“redis-cli monitor”可能非常有教育意义。 (3认同)