diff --git a/ch_tools/chadmin/internal/zookeeper.py b/ch_tools/chadmin/internal/zookeeper.py index 3a1b3002..c405149b 100644 --- a/ch_tools/chadmin/internal/zookeeper.py +++ b/ch_tools/chadmin/internal/zookeeper.py @@ -6,7 +6,7 @@ from math import sqrt from kazoo.client import KazooClient -from kazoo.exceptions import NoNodeError +from kazoo.exceptions import NoNodeError, NotEmptyError from ch_tools.chadmin.cli import get_clickhouse_config, get_macros from ch_tools.chadmin.internal.utils import chunked @@ -162,11 +162,18 @@ def _delete_nodes_transaction(zk, to_delete_in_trasaction): to_delete_in_trasaction, ) for node in to_delete_in_trasaction: - try: - zk.delete(node, recursive=True) - except NoNodeError: - # Someone deleted node before us. Do nothing. - print("Node {node} is already absent, skipped".format(node=node)) + successful_delete = False + while not successful_delete: + try: + zk.delete(node, recursive=True) + successful_delete = True + except NoNodeError: + # Someone deleted node before us. Do nothing. + print("Node {node} is already absent, skipped".format(node=node)) + successful_delete = True + except NotEmptyError: + # Someone created a node while we deleting. Restart the operation. + pass def _remove_subpaths(paths): @@ -294,7 +301,6 @@ def _set_replicas_is_lost(zk, table_paths, nodes): Set flag /replicas//is_lost to 1 """ for path in table_paths: - replica_path = os.path.join(path, "replicas") if not zk.exists(replica_path): continue