Browse Source

update peers script

283
ThomasV 11 years ago
parent
commit
a4d904bfd3
  1. 12
      scripts/peers

12
scripts/peers

@ -5,7 +5,7 @@ from electrum import Interface, SimpleConfig
from electrum.network import filter_protocol, parse_servers from electrum.network import filter_protocol, parse_servers
from collections import defaultdict from collections import defaultdict
#electrum.util.set_verbosity(1) # electrum.util.set_verbosity(1)
# 1. start interface and wait for connection # 1. start interface and wait for connection
interface = electrum.Interface('ecdsa.net:50002:s') interface = electrum.Interface('ecdsa.net:50002:s')
@ -28,7 +28,6 @@ print "Contacting %d servers"%len(peers)
# start interfaces # start interfaces
config = SimpleConfig() config = SimpleConfig()
interfaces = map ( lambda server: Interface(server, config), peers ) interfaces = map ( lambda server: Interface(server, config), peers )
results_queue = Queue.Queue()
reached_servers = [] reached_servers = []
for i in interfaces: for i in interfaces:
i.start(q) i.start(q)
@ -46,8 +45,7 @@ while peers:
if i.server in peers: if i.server in peers:
peers.remove(i.server) peers.remove(i.server)
if i.is_connected: if i.is_connected:
i.send_request({'method':'blockchain.headers.subscribe','params':[]}, results_queue) reached_servers.append(i)
reached_servers.append(i.server)
else: else:
print "Connection failed:", i.server print "Connection failed:", i.server
@ -83,11 +81,15 @@ def analyze(results):
return out return out
results_queue = Queue.Queue()
for i in reached_servers:
i.send_request({'method':'blockchain.headers.subscribe','params':[]}, results_queue)
results = {} results = {}
while reached_servers: while reached_servers:
i, r = results_queue.get(timeout=10000) i, r = results_queue.get(timeout=10000)
results[i.server] = r.get('result') results[i.server] = r.get('result')
reached_servers.remove(i.server) reached_servers.remove(i)
i.stop() i.stop()
errors = analyze(results).keys() errors = analyze(results).keys()

Loading…
Cancel
Save