Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mit-pdos/perennial-examples
Examples verified using Perennial
https://github.com/mit-pdos/perennial-examples
Last synced: about 2 months ago
JSON representation
Examples verified using Perennial
- Host: GitHub
- URL: https://github.com/mit-pdos/perennial-examples
- Owner: mit-pdos
- License: mit
- Created: 2020-05-19T21:43:19.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-07-20T16:14:36.000Z (6 months ago)
- Last Synced: 2024-07-21T03:42:51.335Z (6 months ago)
- Language: Go
- Homepage:
- Size: 115 KB
- Stars: 3
- Watchers: 10
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Example programs for Perennial
[![CI](https://github.com/mit-pdos/perennial-examples/actions/workflows/build.yml/badge.svg)](https://github.com/mit-pdos/perennial-examples/actions/workflows/build.yml)
## dir - single directory
Manages a fixed number of inodes, which support block appends and reads.
Illustrates the shadow update pattern. To append to an inode, we allocate a
block, update it with full ownership, and then atomically install. However,
while updating we still have a crash obligation to the allocator.Illustrates modularity. We're able to structure this into three components: an
allocator, an inode, and a directory. The inode uses the allocator but does not
manage it (it does not restore the allocator, and shares it).- The [allocator](alloc/) is an in-memory structure that serializes access to the free
space. It has to be restored during recovery by figuring out what has been
allocated.
- The [inode](inode/) is a durable, append-only structure. It calls into an
allocator which is shared among all the inodes.
- The [directory](dir/) composes multiple inodes and an allocator.
- The [single-inode package](single_inode/) is a simple client of the inode; as
an alternative to the directory, it only has a single inode.## replicated block
Self-contained example at [replicated_block](replicated_block/). Intended to
resemble the Perennial replicated disk example.Toy example that replicates a single logical disk block across two blocks. Reads
can pick which replica to use, while writes update both. For consistency, we
lock the disk addresses and recovery by syncing. This requires a crash lock, and
its crash invariant allows the addresses to be out-of-sync.This is a modular proof that can be instantiated by the caller for multiple
addresses, building a replicated disk out of tiny pieces.Note that this finally takes the 6.826 example and makes it horizontally
modular, vertically composable, concurrent, and written in Go.## toy example
A fragment of code to illustrate transferring a disk block from one thread to
another with a crash invariant.