From 45fbcd24a5db69911fa64a31fb771ed8a8aa9340 Mon Sep 17 00:00:00 2001 From: Mike Lewis <76072290+mikeCRL@users.noreply.github.com> Date: Tue, 8 Oct 2024 13:43:30 -0400 Subject: [PATCH] Minor TA wording improvement (#18996) --- src/current/advisories/a131639.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/current/advisories/a131639.md b/src/current/advisories/a131639.md index 74556e3bcb1..386690eb7ab 100644 --- a/src/current/advisories/a131639.md +++ b/src/current/advisories/a131639.md @@ -12,9 +12,11 @@ Publication date: {{ page.advisory_date | date: "%B %e, %Y" }} ## Description -In v22.2 through v24.2, in circumstances where there is a sustained period of disk slowness in the presence of lease transfers, it is possible for some writes in a transaction that straddle multiple ranges to be lost. In cases where these lost writes are not also present on one or more secondary indexes that could allow for reconstructing or repairing the row, these writes could be irrecoverably lost. +In v22.2 through v24.2, in rare circumstances where there is a sustained period of disk slowness in the presence of lease transfers, it is possible for some writes in a transaction that straddle multiple ranges to be lost. In cases where these lost writes are not also present on one or more secondary indexes that could allow for reconstructing or repairing the row, these writes could be irrecoverably lost. -However, in certain scenarios, these writes may be fully recoverable. For example, if the lost writes were on a secondary index, these could be fully repaired from the primary index, or a primary index could be fully repaired if there exists a set of secondary indexes that fully covers the primary index columns. The lost writes may also be partially recoverable. For example, if only some of the lost writes from a primary index are contained in secondary indexes. +Transactions that write to a single range, or transactions that take advantage of the One-Phase-Commit (1PC) optimization, are not affected. + +In certain scenarios, the lost writes may be fully recoverable. For example, if the lost writes were on a secondary index, these could be fully repaired from the primary index, or a primary index could be fully repaired if there exists a set of secondary indexes that fully covers the primary index columns. The lost writes may also be partially recoverable. For example, if only some of the lost writes from a primary index are contained in secondary indexes. In detail, since v22.2, when a lease for a range is transferred, it is done so as an expiration-based lease. This lease is then promoted to an epoch-based lease. In situations where the block device backing a store is experiencing intermittent slowness over an extended period of time, the expiration time for the lease transferred to the node with the slow stores can move back in time during this promotion. The lease expiration is said to have "regressed". This lease expiration regression can result in a brief period of time where another node can claim the lease, and the range can have two leaseholders.