mirror of
https://git.yoctoproject.org/poky
synced 2026-06-01 13:09:50 +00:00
bitbake: hashserv: Chunkify large messages
The hash equivalence client and server can occasionally send messages that are too large for the server to fit in the receive buffer (64 KB). To prevent this, support is added to the protocol to "chunkify" the stream and break it up into manageable pieces that the server can each side can back together. Ideally, this would be negotiated by the client and server, but it's currently hard coded to 32 KB to prevent the round-trip delay. (Bitbake rev: e27a28c1e40e886ee68ba4b99b537ffc9c3577d4) Signed-off-by: Joshua Watt <JPEWhacker@gmail.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
committed by
Richard Purdie
parent
b3f212d6bc
commit
07a02b31fd
@@ -7,6 +7,7 @@ import json
|
||||
import logging
|
||||
import socket
|
||||
import os
|
||||
from . import chunkify, DEFAULT_MAX_CHUNK
|
||||
|
||||
|
||||
logger = logging.getLogger('hashserv.client')
|
||||
@@ -25,6 +26,7 @@ class Client(object):
|
||||
self.reader = None
|
||||
self.writer = None
|
||||
self.mode = self.MODE_NORMAL
|
||||
self.max_chunk = DEFAULT_MAX_CHUNK
|
||||
|
||||
def connect_tcp(self, address, port):
|
||||
def connect_sock():
|
||||
@@ -58,7 +60,7 @@ class Client(object):
|
||||
self.reader = self._socket.makefile('r', encoding='utf-8')
|
||||
self.writer = self._socket.makefile('w', encoding='utf-8')
|
||||
|
||||
self.writer.write('OEHASHEQUIV 1.0\n\n')
|
||||
self.writer.write('OEHASHEQUIV 1.1\n\n')
|
||||
self.writer.flush()
|
||||
|
||||
# Restore mode if the socket is being re-created
|
||||
@@ -91,18 +93,35 @@ class Client(object):
|
||||
count += 1
|
||||
|
||||
def send_message(self, msg):
|
||||
def proc():
|
||||
self.writer.write('%s\n' % json.dumps(msg))
|
||||
self.writer.flush()
|
||||
|
||||
l = self.reader.readline()
|
||||
if not l:
|
||||
def get_line():
|
||||
line = self.reader.readline()
|
||||
if not line:
|
||||
raise HashConnectionError('Connection closed')
|
||||
|
||||
if not l.endswith('\n'):
|
||||
if not line.endswith('\n'):
|
||||
raise HashConnectionError('Bad message %r' % message)
|
||||
|
||||
return json.loads(l)
|
||||
return line
|
||||
|
||||
def proc():
|
||||
for c in chunkify(json.dumps(msg), self.max_chunk):
|
||||
self.writer.write(c)
|
||||
self.writer.flush()
|
||||
|
||||
l = get_line()
|
||||
|
||||
m = json.loads(l)
|
||||
if 'chunk-stream' in m:
|
||||
lines = []
|
||||
while True:
|
||||
l = get_line().rstrip('\n')
|
||||
if not l:
|
||||
break
|
||||
lines.append(l)
|
||||
|
||||
m = json.loads(''.join(lines))
|
||||
|
||||
return m
|
||||
|
||||
return self._send_wrapper(proc)
|
||||
|
||||
@@ -155,6 +174,14 @@ class Client(object):
|
||||
m['unihash'] = unihash
|
||||
return self.send_message({'report-equiv': m})
|
||||
|
||||
def get_taskhash(self, method, taskhash, all_properties=False):
|
||||
self._set_mode(self.MODE_NORMAL)
|
||||
return self.send_message({'get': {
|
||||
'taskhash': taskhash,
|
||||
'method': method,
|
||||
'all': all_properties
|
||||
}})
|
||||
|
||||
def get_stats(self):
|
||||
self._set_mode(self.MODE_NORMAL)
|
||||
return self.send_message({'get-stats': None})
|
||||
|
||||
Reference in New Issue
Block a user