The missing specification.
This document has been adopted by the Thrift project at https://github.com/apache/thrift/tree/master/doc/specs and is maintained there by the Thrift community. This copy will not receive any further updates.
Thrift is a RPC mechanism that easily blends in with your code. It has a wonderful transport protocol that stays backward and forward compatible without the security pitfalls brought by seriapalooza.
This document specifies the so far undocumented thrift RPC message exchange and the wire encoding of those messages in the binary protocol and the more modern compact protocol. Then the binary protocol and compact protocol are compared. Finally it describes the framed vs. unframed transport.
For background on Thrift see the Thrift white paper (pdf).
This document is for Thrift implementers. Thrift users should read the thrift documentation and the missing thrift guide.
The information here is based on research in the Java implementation in the Apache thrift library (version 0.9.1 and 0.9.3) and THRIFT-110 A more compact format. Other implementation however, should behave the same.
Copyright © 2016 Erik van Oosten
This work is licensed under the Creative Commons Attribution-ShareAlike 4.0 International License.
Feedback and contributions to this specifications are very welcome. You can find the source code on GitHub.
There is also a PDF version of this document.
The following BNF notation is used:
-
a plus
+
appended to an item represents repetition; the item is repeated 1 or more times -
a star
*
appended to an item represents optional repetition; the item is repeated 0 or more times -
a pipe
|
between items represents choice, the first matching item is selected -
parenthesis
(
and)
are used for grouping multiple items