algorithmpaxosoperational-transformcrdtnosql

Differences between OT and CRDT


Can someone explain me simply the main differences between Operational Transform and CRDT?

As far as I understand, both are algorithms that permits data to converge without conflict on different nodes of a distributed system.

In which usecase would you use which algorithm? As far as I understand, OT is mostly used for text and CRDT is more general and can handle more advanced structures right?

Is CRDT more powerful than OT?


I ask this question because I am trying to see how to implement a collaborative editor for HTML documents, and not sure in which direction to look first. I saw the ShareJS project, and their attempts to support rich text collaboration on the browser on contenteditables elements. Nowhere in ShareJS I see any attempt to use CRDT for that.

We also know that Google Docs is using OT and it's working pretty well for real-time edition of rich documents. Is Google's choice of using OT because CRDT was not very known at that time? Or would it be a good choice today too?

I'm also interested to hear about other use cases too, like using these algorithms on databases. Riak seems to use CRDT. Can OT be used to sync nodes of a database too and be an alternative to Paxos/Zab/Raft?


Solution

  • Both approaches are similar in that they provide eventual consistency. The difference is in how they do it. One way of looking at it is:

    You're right, OT is mostly used for text and does predate CRDTs but research shows that:

    many OT algorithms in the literature do not satisfy convergence properties unlike what was stated by their authors

    In other words CRDT merging is commutative while OT transformation functions sometimes are not.

    From the Wikipedia article on CRDT:

    OTs are generally complex and non-scalable

    There are different kinds of CRDTs (sets, counters, ...) suited for different kinds of problems. There are some that are designed for text editing. For example, Treedoc - A commutative replicated data type for cooperative editing.