From: Vladimir Davydov <vdavydov.dev@gmail.com> To: tarantool-patches@freelists.org Subject: [PATCH] replication: update replica gc state on subscribe Date: Wed, 13 Mar 2019 16:13:45 +0300 [thread overview] Message-ID: <b5b4809cf2e6d48230eb9e4301eac188b080e0f4.1552482730.git.vdavydov.dev@gmail.com> (raw) We advance replica->gc state only when an xlog file is fully recovered, see recovery_close_log and relay_on_close_log_f. It may turn out that an xlog file is fully recovered, but isn't closed properly by relay (i.e. recovery_close_log isn't called), because the replica closes connection for some reason (e.g. timeout). If this happens, the old xlog file won't be removed when the replica reconnects, because we don't advance replica->gc state on reconnect, so the useless xlog file won't be removed until the next xlog file is relayed. This results in occasional replication/gc.test.lua failures. Fix this by updating replica->gc on reconnect with the current replica vclock. Closes #4034 --- https://github.com/tarantool/tarantool/issues/4034 https://github.com/tarantool/tarantool/commits/dv/gh-4034-replication-update-gc-state-on-subscribe src/box/relay.cc | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/box/relay.cc b/src/box/relay.cc index 90fced24..945c01a5 100644 --- a/src/box/relay.cc +++ b/src/box/relay.cc @@ -637,13 +637,16 @@ relay_subscribe(struct replica *replica, int fd, uint64_t sync, /* * Register the replica with the garbage collector * unless it has already been registered by initial - * join. + * join or subscribe. Otherwise update the consumer + * state with the current replica vclock. */ if (replica->gc == NULL) { replica->gc = gc_consumer_register(replica_clock, "replica %s", tt_uuid_str(&replica->uuid)); if (replica->gc == NULL) diag_raise(); + } else { + gc_consumer_advance(replica->gc, replica_clock); } relay_start(relay, fd, sync, relay_send_row); -- 2.11.0
next reply other threads:[~2019-03-13 13:13 UTC|newest] Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top 2019-03-13 13:13 Vladimir Davydov [this message] 2019-03-13 13:38 ` Vladimir Davydov
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=b5b4809cf2e6d48230eb9e4301eac188b080e0f4.1552482730.git.vdavydov.dev@gmail.com \ --to=vdavydov.dev@gmail.com \ --cc=tarantool-patches@freelists.org \ --subject='Re: [PATCH] replication: update replica gc state on subscribe' \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox