summaryrefslogtreecommitdiff
path: root/tools/merge_backup.py
diff options
context:
space:
mode:
authorLinus Nordberg <linus@nordu.net>2016-12-03 16:35:28 +0100
committerLinus Nordberg <linus@nordu.net>2016-12-03 16:35:28 +0100
commit1befdbb267f9c0960b9049cb551b470dbac15ae1 (patch)
tree65e26895321fb00467b1cebdfd8a85d6a0bc2ff6 /tools/merge_backup.py
parentd1fc3a48ff50f85ff5e3098edb3c0774d110af23 (diff)
merge_backup: Print timing info for each secondary.
Also, prefix all log entries with the name of the secondary merge node operating on.
Diffstat (limited to 'tools/merge_backup.py')
-rwxr-xr-xtools/merge_backup.py38
1 files changed, 21 insertions, 17 deletions
diff --git a/tools/merge_backup.py b/tools/merge_backup.py
index d1b6d93..8a44c65 100755
--- a/tools/merge_backup.py
+++ b/tools/merge_backup.py
@@ -33,7 +33,7 @@ def backup_loop(nodename, nodeaddress, own_key, paths, verifiedsize, chunk):
if trynumber == 1:
return None
select.select([], [], [], 10.0)
- logging.info("tries left: %d", trynumber)
+ logging.info("%s: tries left: %d", nodename, trynumber)
continue
return sendlogresult
@@ -41,17 +41,17 @@ sendlog_discover_chunksize = 100000
def sendlog_helper(entries, verifiedsize, nodename, nodeaddress, own_key, paths,
statusupdates):
- logging.info("sending log")
+ logging.info("%s: sending log", nodename)
for chunk in chunks(entries, 1000):
sendlogresult = backup_loop(nodename, nodeaddress, own_key, paths, verifiedsize, chunk)
if sendlogresult == None:
sys.exit(1)
if sendlogresult["result"] != "ok":
- logging.error("backup_sendlog: %s", sendlogresult)
+ logging.error("%s: backup_sendlog: %s", nodename, sendlogresult)
sys.exit(1)
verifiedsize += len(chunk)
statusupdates.status("PROG sending log: %d" % verifiedsize)
- logging.info("log sent")
+ logging.info("%s: log sent", nodename)
def fill_in_missing_entries(nodename, nodeaddress, own_key, paths, chainsdb,
timing, statusupdates):
@@ -60,8 +60,8 @@ def fill_in_missing_entries(nodename, nodeaddress, own_key, paths, chainsdb,
timing_point(timing, "get missing")
while missingentries:
- logging.info("about to send %d missing entries", len(missingentries))
-
+ logging.info("%s: about to send %d missing entries", nodename,
+ len(missingentries))
fetched_entries = 0
with requests.sessions.Session() as session:
for missingentry_chunk in chunks(missingentries, 100):
@@ -71,7 +71,8 @@ def fill_in_missing_entries(nodename, nodeaddress, own_key, paths, chainsdb,
own_key, paths,
hashes_and_entries, session)
if sendentryresult["result"] != "ok":
- logging.error("sendentries_merge: %s", sendentryresult)
+ logging.error("%s: sendentries_merge: %s", nodename,
+ sendentryresult)
sys.exit(1)
fetched_entries += len(missingentry_hashes)
statusupdates.status("PROG sending missing entries: %d" %
@@ -89,18 +90,19 @@ def check_root(logorder, nodename, nodeaddress, own_key, paths, tree_size, timin
verifyrootresult = verifyroot(nodename, nodeaddress, own_key, paths,
tree_size)
if verifyrootresult["result"] != "ok":
- logging.error("verifyroot: %s", verifyrootresult)
+ logging.error("%s: verifyroot: %s", nodename, verifyrootresult)
sys.exit(1)
secondary_root_hash = b64decode(verifyrootresult["root_hash"])
if root_hash != secondary_root_hash:
- logging.error("secondary root hash was %s while expected was %s",
- hexencode(secondary_root_hash), hexencode(root_hash))
+ logging.error("%s: secondary root hash was %s while expected was %s",
+ nodename, hexencode(secondary_root_hash),
+ hexencode(root_hash))
sys.exit(1)
timing_point(timing, "verifyroot")
return root_hash
def do_send(backupargs):
- secondary, localconfig, chainsdb, logorder, s, timing = backupargs
+ args, secondary, localconfig, chainsdb, logorder, s, timing = backupargs
maxwindow = localconfig.get("maxwindow", 1000)
paths = localconfig["paths"]
nodename = secondary["name"]
@@ -110,10 +112,10 @@ def do_send(backupargs):
localconfig["nodename"]))
tree_size = len(logorder)
- logging.info("backing up to node %s", nodename)
+ logging.info("%s: backing up", nodename)
verifiedsize = get_verifiedsize(nodename, nodeaddress, own_key, paths)
timing_point(timing, "get verified size")
- logging.info("verified size %d", verifiedsize)
+ logging.info("%s: verified size %d", nodename, verifiedsize)
if verifiedsize == tree_size:
root_hash = check_root(logorder, nodename, nodeaddress, own_key, paths, tree_size, timing)
@@ -131,13 +133,17 @@ def do_send(backupargs):
verifiedsize = uptopos
setverifiedsize(nodename, nodeaddress, own_key, paths, verifiedsize)
+
+ if args.timing:
+ logging.debug("%s: timing: merge_backup: %s", nodename, timing["deltatimes"])
+
return root_hash
def update_backupfile(mergedb, nodename, tree_size, root_hash):
backuppath = mergedb + "/verified." + nodename
backupdata = {"tree_size": tree_size,
"sha256_root_hash": hexencode(root_hash)}
- logging.debug("writing to %s: %s", backuppath, backupdata)
+ logging.debug("%s: writing to %s: %s", nodename, backuppath, backupdata)
write_file(backuppath, backupdata)
def merge_backup(args, config, localconfig, secondaries):
@@ -165,7 +171,7 @@ def merge_backup(args, config, localconfig, secondaries):
nodename = secondary["name"]
timing = timing_point()
- backupargs = (secondary, localconfig, chainsdb, logorder, s, timing)
+ backupargs = (args, secondary, localconfig, chainsdb, logorder, s, timing)
if args.mergeinterval:
name = 'backup_%s' % nodename
p, pipe = start_worker(name,
@@ -193,8 +199,6 @@ def merge_backup(args, config, localconfig, secondaries):
break
sleep(1)
- if args.timing:
- logging.debug("timing: merge_backup: %s", timing["deltatimes"])
return failures
def main():