Browse Source

ln gossip: run sig checks in a thread

to avoid blocking the asyncio event loop
patch-4
SomberNight 4 years ago
parent
commit
dca182992f
No known key found for this signature in database GPG Key ID: B33B5F232C6271E9
  1. 40
      electrum/lnworker.py
  2. 2
      electrum/sql_db.py

40
electrum/lnworker.py

@ -556,28 +556,30 @@ class LNGossip(LNWorker):
# and disconnect only from that peer # and disconnect only from that peer
await self.channel_db.data_loaded.wait() await self.channel_db.data_loaded.wait()
self.logger.debug(f'process_gossip {len(chan_anns)} {len(node_anns)} {len(chan_upds)}') self.logger.debug(f'process_gossip {len(chan_anns)} {len(node_anns)} {len(chan_upds)}')
# note: data processed in chunks to avoid taking sql lock for too long
# channel announcements # channel announcements
for payload in chan_anns: def process_chan_anns():
self.channel_db.verify_channel_announcement(payload) for payload in chan_anns:
for chan_anns_chunk in chunks(chan_anns, 300): self.channel_db.verify_channel_announcement(payload)
self.channel_db.add_channel_announcements(chan_anns_chunk) self.channel_db.add_channel_announcements(chan_anns)
await run_in_thread(process_chan_anns)
# node announcements # node announcements
for payload in node_anns: def process_node_anns():
self.channel_db.verify_node_announcement(payload) for payload in node_anns:
for node_anns_chunk in chunks(node_anns, 100): self.channel_db.verify_node_announcement(payload)
self.channel_db.add_node_announcements(node_anns_chunk) self.channel_db.add_node_announcements(node_anns)
await run_in_thread(process_node_anns)
# channel updates # channel updates
for chan_upds_chunk in chunks(chan_upds, 1000): categorized_chan_upds = await run_in_thread(partial(
categorized_chan_upds = self.channel_db.add_channel_updates( self.channel_db.add_channel_updates,
chan_upds_chunk, max_age=self.max_age) chan_upds,
orphaned = categorized_chan_upds.orphaned max_age=self.max_age))
if orphaned: orphaned = categorized_chan_upds.orphaned
self.logger.info(f'adding {len(orphaned)} unknown channel ids') if orphaned:
orphaned_ids = [c['short_channel_id'] for c in orphaned] self.logger.info(f'adding {len(orphaned)} unknown channel ids')
await self.add_new_ids(orphaned_ids) orphaned_ids = [c['short_channel_id'] for c in orphaned]
if categorized_chan_upds.good: await self.add_new_ids(orphaned_ids)
self.logger.debug(f'on_channel_update: {len(categorized_chan_upds.good)}/{len(chan_upds_chunk)}') if categorized_chan_upds.good:
self.logger.debug(f'on_channel_update: {len(categorized_chan_upds.good)}/{len(chan_upds)}')
class LNWallet(LNWorker): class LNWallet(LNWorker):

2
electrum/sql_db.py

@ -13,7 +13,7 @@ def sql(func):
"""wrapper for sql methods""" """wrapper for sql methods"""
def wrapper(self: 'SqlDB', *args, **kwargs): def wrapper(self: 'SqlDB', *args, **kwargs):
assert threading.currentThread() != self.sql_thread assert threading.currentThread() != self.sql_thread
f = asyncio.Future() f = self.asyncio_loop.create_future()
self.db_requests.put((f, func, args, kwargs)) self.db_requests.put((f, func, args, kwargs))
return f return f
return wrapper return wrapper

Loading…
Cancel
Save