[ 
https://issues.apache.org/jira/browse/CASSANDRA-5062?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13591828#comment-13591828
 ] 

Cristian Opris commented on CASSANDRA-5062:
-------------------------------------------

One more example of how mostRecentCommit is ambiguous:

{code}
R1           R2      R3
  Ct0          Ct0     Ct0        //initial state at t0
             Atn<     Atn <       //accept at Tn > t0
                      Atn -> Ctn  //R3 commits Ctn, mostRecentCommit = tn, 
Accept is cleared !
>Atn+m                >Atn+m      //R3 accepts new value at tn+m > tn, this is 
>valid since accept has been cleared
Atn+m -> Ctn+m                    //ambiguous state with R1=Ctn+m, R2=Ct0, 
R3=Ctn, needs read ALL to resolve
{code}     
          
                
> Support CAS
> -----------
>
>                 Key: CASSANDRA-5062
>                 URL: https://issues.apache.org/jira/browse/CASSANDRA-5062
>             Project: Cassandra
>          Issue Type: New Feature
>          Components: API, Core
>            Reporter: Jonathan Ellis
>             Fix For: 2.0
>
>         Attachments: half-baked commit 1.jpg, half-baked commit 2.jpg, 
> half-baked commit 3.jpg
>
>
> "Strong" consistency is not enough to prevent race conditions.  The classic 
> example is user account creation: we want to ensure usernames are unique, so 
> we only want to signal account creation success if nobody else has created 
> the account yet.  But naive read-then-write allows clients to race and both 
> think they have a green light to create.

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira

Reply via email to