Skip to content

Latest commit

 

History

History
58 lines (41 loc) · 1.34 KB

README.md

File metadata and controls

58 lines (41 loc) · 1.34 KB

Asyncify

轻量级的异步任务框架

License License License


使用示例:

(1) - 安装:

python setup.py install

(2) - 使用: 创建一个task.py

# task.py

import json
import redis
from asyncify.queue_ import Queue
from asyncify.producer import Producer

# 创建redis 连接
redis_client = redis.Redis()

# 创建message_queue
message_queue = Queue("demo_queue", ack=False, serialize_factory=json.dumps, unserialize_factory=json.loads, redis_client=redis_client)

# 创建producer
producer = Producer(message_queue)

# producer.register_task 加到需要异步的方法上
@producer.register_task
def add(a, b):
    return a + b

if __name__ == "__main__":
    # 模拟每隔1s,调用一次 add 方法
    import time
    while True:
        time.sleep(1)
        add.delay(1,2)

运行当前task.py脚本,脚本每个1s会调用add方法,每次调用会产生一个消息,这些消息将等待消费者的执行

  • 使用python运行: python3 task.py

  • 启动消费者:asyncify-cli --queue task.message_queue customer

消费者运行截图:

x