cassandra-user mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From Sylvain Lebresne <>
Subject Re: Batch isolation within a single partition
Date Tue, 19 May 2015 08:04:51 GMT
On Tue, May 19, 2015 at 9:42 AM, DuyHai Doan <> wrote:

> If RF > 1, the consistency level at QUORUM cannot guarantee strict
> isolation (for normal mutation or batch). If you look at this slide:
> you can see that the mutation is sent by the coordinator, in parallel, to
> all replicas.
>  Now it is very possible that due to network latency, the mutation is
> applied on the first replica and is applied with "some delay" (which can be
> at the order of microseconds) on other replicas.
>  Theoretically, one client can read updated value on first replica and old
> value on the other replicas, even at QUORUM.

Unfortunately different people will tend to have different definitions of
isolation and I don't seem to have the same definition than you but still,
I don't understand what you're talking about. Of course replicas might not
get a mutation at the same time, and yes, a read at QUORUM may thus not see
the most up to date value from all replicas. But the coordinator resolves
all responses together and return only the most recent one, so that doesn't
matter to the client and I don't see how that has anything to do with
isolation from the client perspective.

My response to the original question is that if by isolation you mean "can
a reader observe a write only partially applied", then for single partition
writes, Cassandra do offer isolation. One caveat however is that if 2
writes conflits, they are resolved using their timestamp and if the
timestamp are the same, resolution is based on values, which is not
necessarily intuitive and may make it sound like the writes where not
applied in isolation (even though technically they are), see for details on that
later problem. I'll note that my definition of isolation does not mean you
can't read stale data, and you can indeed if you use weak consistency

If you mean something else by isolation, then I think agreeing first on the
definition would be wise.


View raw message