mirror of https://github.com/zeromq/pyzmq.git
62 lines
1.4 KiB
Python
62 lines
1.4 KiB
Python
"""Example using zmq with tornado coroutines"""
|
|
# Copyright (c) PyZMQ Developers.
|
|
# This example is in the public domain (CC-0)
|
|
|
|
import asyncio
|
|
import time
|
|
|
|
import zmq
|
|
from zmq.eventloop.future import Context, Poller
|
|
|
|
url = 'tcp://127.0.0.1:5555'
|
|
|
|
ctx = Context.instance()
|
|
|
|
|
|
async def ping() -> None:
|
|
"""print dots to indicate idleness"""
|
|
while True:
|
|
await asyncio.sleep(0.25)
|
|
print('.')
|
|
|
|
|
|
async def receiver() -> None:
|
|
"""receive messages with poll and timeout"""
|
|
pull = ctx.socket(zmq.PULL)
|
|
pull.connect(url)
|
|
poller = Poller()
|
|
poller.register(pull, zmq.POLLIN)
|
|
while True:
|
|
events = await poller.poll(timeout=500)
|
|
if pull in dict(events):
|
|
print("recving", events)
|
|
msg = await pull.recv_multipart()
|
|
print('recvd', msg)
|
|
else:
|
|
print("nothing to recv")
|
|
|
|
|
|
async def sender() -> None:
|
|
"""send a message every second"""
|
|
tic = time.time()
|
|
push = ctx.socket(zmq.PUSH)
|
|
push.bind(url)
|
|
poller = Poller()
|
|
poller.register(push, zmq.POLLOUT)
|
|
while True:
|
|
print("sending")
|
|
await push.send_multipart([str(time.time() - tic).encode("ascii")])
|
|
await asyncio.sleep(1)
|
|
|
|
|
|
async def main() -> None:
|
|
await asyncio.gather(
|
|
ping(),
|
|
receiver(),
|
|
sender(),
|
|
)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
asyncio.run(main())
|