Welcome to MixT! Whether you're here because you happened to see my recent PLDI Talk, paper, or happened to find it in some other way, Welcome!
MixT is a domain-specific programming langauge for writing transactions, embedded into C++. What makes MixT unique is its approach to consistency and transaction isolation: rather than associate consistency with operations, MixT associates consistency with data and expects programmers to use multiple consistency models in the same application. With MixT:
-
Transactions compile down to a sequence of standard, single-consistency transactions appropriate for execution on any number of SQL/NoSQL/NewSQL datastores.
-
An information-flow type system keeps your consistent data safe from corruption by less-consistent data.
-
You can use multiple consistency models even within a single transaction.
-
A single transaction can execute across multiple independent datastores, while still preserving write atomicity.
-
Transactions are expressive; you can define custom operations as methods, use while-loops and if-statements, and generally write code that looks and feels like the surrounding C++. For full details on the allowed syntax, please check the paper (open access link, no paywall).
To use MixT, define an interface for your datastore, write a few transactions, and you're off to the races!
If picking one consistency model works for your application, then great! There's a dizzying array of consistency models out there; every third NoSQL/NewSQL database is oh-so-excited to tell you about their new twist on their new eventually, causally, semi-snapshot, absurdly-complex consistency model. If you're thinking about using something like MixT, chances are you're already a user of one of these databases—and already familiar with what they do well, and (perhaps more importantly) what they really don't do well. Rather than continuing to migrate all your data to ever-newer single databases, MixT lets you keep using your existing databases for the cases they handle well, mixing access among multiple different databases in the same application. Using multiple consistency models is an error-prone process; MixT helps you avoid the errors that can happen when you mix models.
The best source of information about the ideas behind MixT is the paper; if you're looking for information specifically about its prototype implementation, the readme has basic instructions for getting started. The code is first and foremost a research artifact; some difficulties building and using this artifact are to be expected, and documentation beyond setup and "hello world" is spare. I am happy to provide any help required; send me a message via e-mail, on github, or by filing an issue against this repository.