17 releases
0.2.20241203-120811+a2174689 | Dec 3, 2024 |
---|---|
0.2.20240718-145624+f4e9df48 | Jul 18, 2024 |
0.2.20240219-172743+3e819974 | Feb 20, 2024 |
0.2.20231113-145254+995db0d6 | Nov 13, 2023 |
0.1.20221118-210929-cfbb6… | Nov 19, 2022 |
#11 in #control-system
6,215 stars & 73 watchers
13MB
306K
SLoC
Mononoke xxx 2024-01-30
Mononoke is a the server built for the Sapling Source Control System, meant to scale up to accepting thousands of commits every hour across millions of files. It is primarily written in the Rust programming language.
Caveat Emptor
Mononoke is still in development. We are making it available now because we plan to start making references to it from our other open source projects.
The version that we provide on GitHub is omitting some functions.
This is because the code is exported verbatim from an internal repository at Facebook, and not all of the scaffolding from our internal repository can be easily extracted. The key areas where we need to shore things up are:
- Support for running thrift based apis.
- Production metadata SQL support (e.g. something like a MySQL backend). We provide sqlite in OSS for now.
- Production blobstore storage backends (e.g. something like S3). We provide SQL (on sqlite) and File System backends currently in OSS.
Linux is Mononoke's primary target plaform with OSS CI also running on MacOS. Other Unix-like OSes may be supported in the future.
Subsystem Docs
Most of our documentation is in internal systems, however a few subsystems have in-repo markdown docs available:
- Integration Tests
- Packblob Storage how Mononoke compressed store works
- Graph Walker used to check/scrub storage
Dependencies
~20–31MB
~546K SLoC