You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@geode.apache.org by "Kirk Lund (JIRA)" <ji...@apache.org> on 2018/03/01 22:57:00 UTC

[jira] [Commented] (GEODE-4748) Geode put may result in inconsistent cache if serialization of key or value class fails

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

Kirk Lund commented on GEODE-4748:
----------------------------------

This ticket is not specific to transactions. Performing a put on a replicated region without transactions will reproduce the same problem. User expectation is for transaction to have stronger guarantees to prevent this bug.

> Geode put may result in inconsistent cache if serialization of key or value class fails
> ---------------------------------------------------------------------------------------
>
>                 Key: GEODE-4748
>                 URL: https://issues.apache.org/jira/browse/GEODE-4748
>             Project: Geode
>          Issue Type: Bug
>          Components: regions
>    Affects Versions: 1.0.0-incubating, 1.1.0, 1.1.1, 1.2.0, 1.3.0, 1.2.1, 1.4.0
>            Reporter: Vadim Lotarev
>            Priority: Major
>
> Geode cache became inconsistent in case if networking problems occur at commit time. How to reproduce:
> # create any simple _replicated_ region
> # run two nodes
> # put some value in the region within a transaction
> # execute query on both nodes to check that the same value is returned (I used JMX for that)
> # emulate somehow temporary networking error (I changed the code throwing IOException from toData())
> # repeat [#3], exception should occur
> # repeat [#4] - you should see different values on different nodes
> It looks like errors occurred after {{TXState.applyChanges}} produce inconsistency - it is impossible to rollback applied local changes what leads to the state where local cache contains  changed data but other node(s) old data (before changes made in transaction).
> To me, consistency is a key property for the systems like Geode so I would consider this bug as a critical one.



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)