|
@ -134,7 +134,6 @@ class Prefetcher(LoggedClass): |
|
|
if caught_up: |
|
|
if caught_up: |
|
|
self.logger.info('new block height {:,d} hash {}' |
|
|
self.logger.info('new block height {:,d} hash {}' |
|
|
.format(first + count - 1, hex_hashes[-1])) |
|
|
.format(first + count - 1, hex_hashes[-1])) |
|
|
|
|
|
|
|
|
blocks = await self.daemon.raw_blocks(hex_hashes) |
|
|
blocks = await self.daemon.raw_blocks(hex_hashes) |
|
|
|
|
|
|
|
|
size = sum(len(block) for block in blocks) |
|
|
size = sum(len(block) for block in blocks) |
|
@ -386,7 +385,6 @@ class BlockProcessor(server.db.DB): |
|
|
try: |
|
|
try: |
|
|
while True: |
|
|
while True: |
|
|
await self._wait_for_update() |
|
|
await self._wait_for_update() |
|
|
await asyncio.sleep(0) # Yield |
|
|
|
|
|
except asyncio.CancelledError: |
|
|
except asyncio.CancelledError: |
|
|
self.on_cancel() |
|
|
self.on_cancel() |
|
|
# This lets the asyncio subsystem process futures cancellations |
|
|
# This lets the asyncio subsystem process futures cancellations |
|
@ -416,6 +414,9 @@ class BlockProcessor(server.db.DB): |
|
|
try: |
|
|
try: |
|
|
for block in blocks: |
|
|
for block in blocks: |
|
|
self.advance_block(block, caught_up) |
|
|
self.advance_block(block, caught_up) |
|
|
|
|
|
if not caught_up and time.time() > self.next_cache_check: |
|
|
|
|
|
self.check_cache_size() |
|
|
|
|
|
self.next_cache_check = time.time() + 60 |
|
|
await asyncio.sleep(0) # Yield |
|
|
await asyncio.sleep(0) # Yield |
|
|
if caught_up: |
|
|
if caught_up: |
|
|
await self.caught_up(mempool_hashes) |
|
|
await self.caught_up(mempool_hashes) |
|
@ -700,8 +701,8 @@ class BlockProcessor(server.db.DB): |
|
|
self.logger.info('removed {:,d} history entries from {:,d} addresses' |
|
|
self.logger.info('removed {:,d} history entries from {:,d} addresses' |
|
|
.format(nremoves, len(hash168s))) |
|
|
.format(nremoves, len(hash168s))) |
|
|
|
|
|
|
|
|
def cache_sizes(self): |
|
|
def check_cache_size(self): |
|
|
'''Returns the approximate size of the cache, in MB.''' |
|
|
'''Flush a cache if it gets too big.''' |
|
|
# Good average estimates based on traversal of subobjects and |
|
|
# Good average estimates based on traversal of subobjects and |
|
|
# requesting size from Python (see deep_getsizeof). For |
|
|
# requesting size from Python (see deep_getsizeof). For |
|
|
# whatever reason Python O/S mem usage is typically +30% or |
|
|
# whatever reason Python O/S mem usage is typically +30% or |
|
@ -718,7 +719,10 @@ class BlockProcessor(server.db.DB): |
|
|
'UTXOs {:,d}MB hist {:,d}MB' |
|
|
'UTXOs {:,d}MB hist {:,d}MB' |
|
|
.format(self.height, self.daemon.cached_height(), |
|
|
.format(self.height, self.daemon.cached_height(), |
|
|
utxo_MB, hist_MB)) |
|
|
utxo_MB, hist_MB)) |
|
|
return utxo_MB, hist_MB |
|
|
|
|
|
|
|
|
# Flush if a cache is too big |
|
|
|
|
|
if utxo_MB >= self.utxo_MB or hist_MB >= self.hist_MB: |
|
|
|
|
|
self.flush(utxo_MB >= self.utxo_MB) |
|
|
|
|
|
|
|
|
def undo_key(self, height): |
|
|
def undo_key(self, height): |
|
|
'''DB key for undo information at the given height.''' |
|
|
'''DB key for undo information at the given height.''' |
|
@ -758,14 +762,6 @@ class BlockProcessor(server.db.DB): |
|
|
if self.daemon.cached_height() - self.height <= self.reorg_limit: |
|
|
if self.daemon.cached_height() - self.height <= self.reorg_limit: |
|
|
self.write_undo_info(self.height, b''.join(undo_info)) |
|
|
self.write_undo_info(self.height, b''.join(undo_info)) |
|
|
|
|
|
|
|
|
# Check if we're getting full and time to flush? |
|
|
|
|
|
now = time.time() |
|
|
|
|
|
if now > self.next_cache_check: |
|
|
|
|
|
self.next_cache_check = now + 60 |
|
|
|
|
|
utxo_MB, hist_MB = self.cache_sizes() |
|
|
|
|
|
if utxo_MB >= self.utxo_MB or hist_MB >= self.hist_MB: |
|
|
|
|
|
self.flush(utxo_MB >= self.utxo_MB) |
|
|
|
|
|
|
|
|
|
|
|
if update_touched: |
|
|
if update_touched: |
|
|
self.touched.update(touched) |
|
|
self.touched.update(touched) |
|
|
|
|
|
|
|
|