12 releases

✓ Uses Rust 2018 edition

0.4.4 Jan 30, 2020
0.4.3 Dec 29, 2019
0.4.2 Oct 9, 2019
0.4.1 Sep 1, 2019
0.1.0 Jan 5, 2017

#121 in Encoding

Download history 2352/week @ 2020-01-25 1526/week @ 2020-02-01 1502/week @ 2020-02-08 1788/week @ 2020-02-15 1780/week @ 2020-02-22 2422/week @ 2020-02-29 1698/week @ 2020-03-07 2019/week @ 2020-03-14 2444/week @ 2020-03-21 1929/week @ 2020-03-28 2162/week @ 2020-04-04 2163/week @ 2020-04-11 2057/week @ 2020-04-18 1850/week @ 2020-04-25 1550/week @ 2020-05-02 1476/week @ 2020-05-09

8,511 downloads per month
Used in 23 crates (16 directly)

MIT license


Rust 3.5K SLoC // 0.1% comments Ruby HTML 1K SLoC // 0.5% comments

RMP - Rust MessagePack

RMP is a pure Rust MessagePack implementation.

Build Status Coverage Status

This repository consists of three separate crates: the RMP core and two implementations to ease serializing and deserializing Rust structs.

crates.io API Documentation
rmp RMP
rmps RMP Serde
rmpv RMP Value


  • Convenient API

    RMP is designed to be lightweight and straightforward. There are low-level API, which gives you full control on data encoding/decoding process and makes no heap allocations. On the other hand there are high-level API, which provides you convenient interface using Rust standard library and compiler reflection, allowing to encode/decode structures using derive attribute.

  • Zero-copy value decoding

    RMP allows to decode bytes from a buffer in a zero-copy manner easily and blazingly fast, while Rust static checks guarantees that the data will be valid as long as the buffer lives.

  • Clear error handling

    RMP's error system guarantees that you never receive an error enum with unreachable variant.

  • Robust and tested

    This project is developed using TDD and CI, so any found bugs will be fixed without breaking existing functionality.


  • Rust 1.34.2


This project adheres to Semantic Versioning. However until 1.0.0 comes there will be the following rules:

  • Any API/ABI breaking changes will be notified in the changelog explicitly and results in minor version bumping.
  • API extending features results in patch version bumping.
  • Non-breaking bug fixes and performance improving results in patch version bumping.