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

ASF GitHub Bot commented on S2GRAPH-68:
---------------------------------------

Github user daewon commented on the issue:

    https://github.com/apache/incubator-s2graph/pull/53
  
    +1
    It make harder to pass the test.


> Refactor write-write conflict resolving logic
> ---------------------------------------------
>
>                 Key: S2GRAPH-68
>                 URL: https://issues.apache.org/jira/browse/S2GRAPH-68
>             Project: S2Graph
>          Issue Type: Improvement
>            Reporter: DOYUNG YOON
>            Assignee: DOYUNG YOON
>              Labels: consistency, write
>   Original Estimate: 168h
>  Remaining Estimate: 168h
>
> Current implementation for resolving write-write conflict on snapshotEdge is 
> overwhelmingly complicated, so I am suggesting refactor this to make it easy 
> to understand.
> Current master test cases failed with positive fail probability for 
> RPC(hbase.fail.prob=0.01).
> I can reproduce it by running `sbt "project s2core" 
> -Dconfig.file=s2rest_play/conf/test.conf test`.
> We can think this problem as critical section problem. Multiple thread that 
> want to mutate same SnapshotEdge can only proceed one-by-one to keep 
> consistent view on related IndexEdge. To achieve this, we are storing extra 
> data on SnapshotEdge. 
> Details are on 
> [gitbook|https://steamshon.gitbooks.io/s2graph-book/content/request_state_diagram.html].
> I think following 3 things would be expected output after resolving this 
> issue.
> 1. more comments and simplified code.
> 2. remove excessive re-fetch on every retry from partial failure. since it is 
> guaranteed that only one thread can proceed at a time, re-fetch is not 
> necessary.
> 3. remove Thread.sleep between retry from partial failure.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to