forked from tobymao/saq
-
Notifications
You must be signed in to change notification settings - Fork 0
/
simple.py
110 lines (79 loc) · 2.71 KB
/
simple.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
import asyncio
import sys
import time
from benchmarks.funcs import *
SEM = asyncio.Semaphore(20)
N = 1000
async def sem_task(task):
async with SEM:
return await task
async def bench_arq():
from arq import create_pool
from arq.connections import RedisSettings
from arq.worker import Worker
async def enqueue(func):
await asyncio.gather(
*[asyncio.create_task(sem_task(redis.enqueue_job(func))) for _ in range(N)]
)
redis = await create_pool(RedisSettings())
worker = Worker(functions=[noop, sleeper], max_jobs=10, burst=True)
worker.loop = asyncio.get_event_loop()
now = time.time()
await enqueue("noop")
print(f"ARQ enqueue {N} {time.time() - now}")
now = time.time()
await worker.main()
print(f"ARQ process {N} noop {time.time() - now}")
await enqueue("sleeper")
now = time.time()
await worker.main()
print(f"ARQ process {N} sleep {time.time() - now}")
async def bench_saq(url: str):
from saq import Queue, Worker
async def enqueue(func):
await asyncio.gather(*[asyncio.create_task(queue.enqueue(func)) for _ in range(N)])
queue = Queue.from_url(url)
worker = Worker(queue=queue, functions=[noop, sleeper], concurrency=10)
await queue.connect()
now = time.time()
await enqueue("noop")
print(f"SAQ enqueue {N} {time.time() - now}")
now = time.time()
task = asyncio.create_task(worker.start())
while await queue.count("incomplete"):
await asyncio.sleep(0.1)
print(f"SAQ process {N} noop {time.time() - now}")
await enqueue("sleeper")
now = time.time()
while await queue.count("incomplete"):
await asyncio.sleep(0.1)
print(f"SAQ process {N} sleep {time.time() - now}")
def bench_rq():
from rq import Connection, Queue, Worker
with Connection() as connection:
queue = Queue(connection=connection)
worker = Worker("default", log_job_description=False)
worker.log_result_lifespan = False
def enqueue(func):
for _ in range(N):
queue.enqueue(func)
now = time.time()
enqueue(sync_noop)
print(f"RQ enqueue {N} {time.time() - now}")
worker.work(burst=True)
print(f"RQ process {N} noop {time.time() - now}")
enqueue(sync_sleeper)
worker.work(burst=True)
print(f"RQ process {N} sleep {time.time() - now}")
async def main():
lib = sys.argv[1]
if lib == "arq":
await bench_arq()
elif lib == "rq":
bench_rq()
elif lib == "saq_pg":
await bench_saq("postgres://postgres@localhost")
else:
await bench_saq("redis://localhost")
if __name__ == "__main__":
asyncio.run(main())