Optimistic Concurrency

I’ve been looking at synchronization-related concepts lately. It’s been really nice to revisit some ideas/concepts from my PhD years (e.g. consistency models for shared data in distributed environments). ‘Optimistic concurrency’ is a term I’ve encountered a lot and I just read the “Optimistic concurrency – a false panacea” post by Yaro Goland (via Mark Baker). Interesting!

I am not going to try to disagree with the arguments since I am just learning this area and I don’t have the much needed real world experience 🙂 However, I would like to point out that I’ve encountered systems where optimistic concurrency works relatively well (always apply the right tool for the right job!). A couple of examples come in mind: Active Directory and Windows Server Distributed File System. Granted, these are not transactions systems but they do optimistically propagate updates given their multi-owner nature for shared data. Perhaps I am not comparing similar things.

A good paper to read is “Optimistic Replication” by Saito and Shapiro.

Recent Posts

The Beginning of CVOYA

There’s a unique energy that comes with starting something new — a blend of excitement,…

1 month ago

Enhancements in Graph Model: Dynamic Entities & Full-Text Search

As I continued work on BrainExpanded and its MCP service, I came to realize that…

4 months ago

GraphModel: A .NET Abstraction for Graphs

Just over a month ago, I published "Playing with graphs and Neo4j". Back then, it…

5 months ago

Playing with graphs and neo4j

After my initial implementation of some BrainExpanded-related ideas on top of dgraph using its GraphQL…

6 months ago

A Graph Model DSL

Say hello to the Graph Model Domain Specific Language (GMDSL), created with the help of…

7 months ago

BrainExpanded – Web app and Data Sources

As I wrote in previous posts, the manual recording of memories for BrainExpanded is just…

7 months ago