From d464fb5b88962767cfdf3bb699349bdadfe45320 Mon Sep 17 00:00:00 2001 From: Fernando Llaca Date: Wed, 8 Jan 2020 12:29:51 +0100 Subject: [PATCH] Use timestamp to deduplicate snapshots of same index --- es-cleanup.py | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/es-cleanup.py b/es-cleanup.py index 09240ae..2ea9705 100644 --- a/es-cleanup.py +++ b/es-cleanup.py @@ -163,8 +163,12 @@ def snapshot_index(self, index_name, snapshot_repository): "include_global_state": False } + # Append a timestamp to deduplicate multiple snapshots for same index + now = str(datetime.datetime.now()) + snapshot_name = format("{}_{}".format(index_name, now) + # create snapshot - snapshot = self.send_to_es("_snapshot/{}/{}".format(snapshot_repository, index_name), method="PUT", payload=snapshot_payload) + snapshot = self.send_to_es("_snapshot/{}/{}".format(snapshot_repository, snapshot_name), method="PUT", payload=snapshot_payload) # Wait for snapshot to be sucessful retries = 0 @@ -172,7 +176,7 @@ def snapshot_index(self, index_name, snapshot_repository): if retries > 0: seconds = (5**retries) * .1 time.sleep(seconds) - snapshots = self.get_snapshot(snapshot_repository, index_name) + snapshots = self.get_snapshot(snapshot_repository, snapshot_name) if snapshots["snapshots"][0]["state"] == "SUCCESS": break return snapshot @@ -255,7 +259,10 @@ def lambda_handler(event, context): snapshot_earliest_to_keep = datetime.date.today() - datetime.timedelta( days=int(es.cfg["snapshot_delete_after"])) for snapshot in es.get_snapshots(es.cfg["snapshot_repository"])["snapshots"]: - snapshot_split = snapshot["snapshot"].rsplit("-", + # split by "-", ignoring the timestamp part of the snapshot name: + timestamp_pos=snapshot["snapshot"].rfind("_") + timestamp_pos=timestamp_pos+1 if timestamp_pos >= 0 else len(snapshot["snapshot"]) + snapshot_split = snapshot["snapshot"][:timestamp_pos].rsplit("-", 1 + es.cfg["index_format"].count("-")) snapshot_name = snapshot_split[0] snapshot_date = '-'.join(word for word in snapshot_split[1:])