Adddress nits, use asyncio signal handling, create_task
This commit is contained in:
parent
4bb7d1bc4d
commit
b471daf85b
2 changed files with 50 additions and 18 deletions
|
@ -3,12 +3,29 @@
|
||||||
# Distributed under the MIT software license, see the accompanying
|
# Distributed under the MIT software license, see the accompanying
|
||||||
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||||
|
|
||||||
# A blocking example using python 2.7 can be obtained from the git history:
|
"""
|
||||||
# https://github.com/bitcoin/bitcoin/blob/37a7fe9e440b83e2364d5498931253937abe9294/contrib/zmq/zmq_sub.py
|
ZMQ example using python3's asyncio
|
||||||
|
|
||||||
|
Bitcoin should be started with the command line arguments:
|
||||||
|
bitcoind -testnet -daemon \
|
||||||
|
-zmqpubhashblock=tcp://127.0.0.1:28332 \
|
||||||
|
-zmqpubrawtx=tcp://127.0.0.1:28332 \
|
||||||
|
-zmqpubhashtx=tcp://127.0.0.1:28332 \
|
||||||
|
-zmqpubhashblock=tcp://127.0.0.1:28332
|
||||||
|
|
||||||
|
We use the asyncio library here. `self.handle()` installs itself as a
|
||||||
|
future at the end of the function. Since it never returns with the event
|
||||||
|
loop having an empty stack of futures, this creates an infinite loop. An
|
||||||
|
alternative is to wrap the contents of `handle` inside `while True`.
|
||||||
|
|
||||||
|
A blocking example using python 2.7 can be obtained from the git history:
|
||||||
|
https://github.com/bitcoin/bitcoin/blob/37a7fe9e440b83e2364d5498931253937abe9294/contrib/zmq/zmq_sub.py
|
||||||
|
"""
|
||||||
|
|
||||||
import array
|
|
||||||
import binascii
|
import binascii
|
||||||
import asyncio, zmq, zmq.asyncio
|
import asyncio
|
||||||
|
import zmq
|
||||||
|
import zmq.asyncio
|
||||||
import signal
|
import signal
|
||||||
import struct
|
import struct
|
||||||
import sys
|
import sys
|
||||||
|
@ -55,7 +72,8 @@ class ZMQHandler():
|
||||||
asyncio.ensure_future(self.handle())
|
asyncio.ensure_future(self.handle())
|
||||||
|
|
||||||
def start(self):
|
def start(self):
|
||||||
asyncio.ensure_future(self.handle())
|
self.loop.add_signal_handler(signal.SIGINT, self.stop)
|
||||||
|
self.loop.create_task(self.handle())
|
||||||
self.loop.run_forever()
|
self.loop.run_forever()
|
||||||
|
|
||||||
def stop(self):
|
def stop(self):
|
||||||
|
@ -63,8 +81,4 @@ class ZMQHandler():
|
||||||
self.zmqContext.destroy()
|
self.zmqContext.destroy()
|
||||||
|
|
||||||
daemon = ZMQHandler()
|
daemon = ZMQHandler()
|
||||||
def signal_handler(num, frame):
|
|
||||||
daemon.stop()
|
|
||||||
exit(0)
|
|
||||||
signal.signal(signal.SIGINT, signal_handler)
|
|
||||||
daemon.start()
|
daemon.start()
|
||||||
|
|
|
@ -3,12 +3,33 @@
|
||||||
# Distributed under the MIT software license, see the accompanying
|
# Distributed under the MIT software license, see the accompanying
|
||||||
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||||
|
|
||||||
# A blocking example using python 2.7 can be obtained from the git history:
|
"""
|
||||||
# https://github.com/bitcoin/bitcoin/blob/37a7fe9e440b83e2364d5498931253937abe9294/contrib/zmq/zmq_sub.py
|
ZMQ example using python3's asyncio
|
||||||
|
|
||||||
|
Bitcoin should be started with the command line arguments:
|
||||||
|
bitcoind -testnet -daemon \
|
||||||
|
-zmqpubhashblock=tcp://127.0.0.1:28332 \
|
||||||
|
-zmqpubrawtx=tcp://127.0.0.1:28332 \
|
||||||
|
-zmqpubhashtx=tcp://127.0.0.1:28332 \
|
||||||
|
-zmqpubhashblock=tcp://127.0.0.1:28332
|
||||||
|
|
||||||
|
We use the asyncio library here. `self.handle()` installs itself as a
|
||||||
|
future at the end of the function. Since it never returns with the event
|
||||||
|
loop having an empty stack of futures, this creates an infinite loop. An
|
||||||
|
alternative is to wrap the contents of `handle` inside `while True`.
|
||||||
|
|
||||||
|
The `@asyncio.coroutine` decorator and the `yield from` syntax found here
|
||||||
|
was introduced in python 3.4 and has been deprecated in favor of the `async`
|
||||||
|
and `await` keywords respectively.
|
||||||
|
|
||||||
|
A blocking example using python 2.7 can be obtained from the git history:
|
||||||
|
https://github.com/bitcoin/bitcoin/blob/37a7fe9e440b83e2364d5498931253937abe9294/contrib/zmq/zmq_sub.py
|
||||||
|
"""
|
||||||
|
|
||||||
import array
|
|
||||||
import binascii
|
import binascii
|
||||||
import asyncio, zmq, zmq.asyncio
|
import asyncio
|
||||||
|
import zmq
|
||||||
|
import zmq.asyncio
|
||||||
import signal
|
import signal
|
||||||
import struct
|
import struct
|
||||||
import sys
|
import sys
|
||||||
|
@ -56,7 +77,8 @@ class ZMQHandler():
|
||||||
asyncio.ensure_future(self.handle())
|
asyncio.ensure_future(self.handle())
|
||||||
|
|
||||||
def start(self):
|
def start(self):
|
||||||
asyncio.ensure_future(self.handle())
|
self.loop.add_signal_handler(signal.SIGINT, self.stop)
|
||||||
|
self.loop.create_task(self.handle())
|
||||||
self.loop.run_forever()
|
self.loop.run_forever()
|
||||||
|
|
||||||
def stop(self):
|
def stop(self):
|
||||||
|
@ -64,8 +86,4 @@ class ZMQHandler():
|
||||||
self.zmqContext.destroy()
|
self.zmqContext.destroy()
|
||||||
|
|
||||||
daemon = ZMQHandler()
|
daemon = ZMQHandler()
|
||||||
def signal_handler(num, frame):
|
|
||||||
daemon.stop()
|
|
||||||
exit(0)
|
|
||||||
signal.signal(signal.SIGINT, signal_handler)
|
|
||||||
daemon.start()
|
daemon.start()
|
||||||
|
|
Loading…
Add table
Reference in a new issue