From f1f1788f103677a9a96fd25562750df234274676 Mon Sep 17 00:00:00 2001 From: Amitay Isaacs Date: Tue, 10 Sep 2013 17:52:26 +1000 Subject: [PATCH] traverse: Wait till all data has been flushed from output queue To improve the traverse performance, records are directly sent from traverse child process to the originating node. Make sure that all the data is sent via socket, before informing ctdbd that traverse is complete. Without waiting for all the packets to be flushed from the queue, child process can incorrectly signal ctdbd that traverse has ended. This will cause the pending records in the queue never to make it to the originating node and traverse information will not be complete. Signed-off-by: Amitay Isaacs (This used to be ctdb commit 482ac708cb79cb6378d814a79c2cf13f88435bc4) --- ctdb/server/ctdb_traverse.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/ctdb/server/ctdb_traverse.c b/ctdb/server/ctdb_traverse.c index f75227e67ca..5b588c6a225 100644 --- a/ctdb/server/ctdb_traverse.c +++ b/ctdb/server/ctdb_traverse.c @@ -215,6 +215,12 @@ static struct ctdb_traverse_local_handle *ctdb_traverse_local(struct ctdb_db_con } else { res = h->records_sent; } + + /* Wait till all the data is flushed from output queue */ + while (ctdb_queue_length(ctdb->daemon.queue) > 0) { + tevent_loop_once(ctdb->ev); + } + write(h->fd[1], &res, sizeof(res)); while (ctdb_kill(ctdb, parent, 0) == 0 || errno != ESRCH) {