https://github.com/zowens/commitlog
  
  
    Append-only commit log library for Rust 
    https://github.com/zowens/commitlog
  
database log rust
        Last synced: 6 months ago 
        JSON representation
    
Append-only commit log library for Rust
- Host: GitHub
- URL: https://github.com/zowens/commitlog
- Owner: zowens
- License: mit
- Created: 2016-11-25T21:39:58.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2024-06-19T07:25:34.000Z (over 1 year ago)
- Last Synced: 2024-08-10T09:05:48.547Z (about 1 year ago)
- Topics: database, log, rust
- Language: Rust
- Homepage:
- Size: 252 KB
- Stars: 102
- Watchers: 8
- Forks: 14
- Open Issues: 12
- 
            Metadata Files:
            - Readme: README.md
- License: LICENSE.md
 
Awesome Lists containing this project
README
          # Commit Log
Sequential, disk-backed commit log library for Rust. The library can be used in various higher-level distributed abstractions on top of a distributed log such as [Paxos](https://github.com/zowens/paxos-rs), [Chain Replication](https://github.com/zowens/chain-replication) or Raft.
[](https://crates.io/crates/commitlog)
[](https://docs.rs/commitlog/)
[](https://travis-ci.org/zowens/commitlog/)
[Documentation](https://docs.rs/commitlog/)
## Usage
First, add this to your `Cargo.toml`:
```toml
[dependencies]
commitlog = "0.2"
```
```rust
use commitlog::*;
use commitlog::message::*;
fn main() {
    // open a directory called 'log' for segment and index storage
    let opts = LogOptions::new("log");
    let mut log = CommitLog::new(opts).unwrap();
    // append to the log
    log.append_msg("hello world").unwrap(); // offset 0
    log.append_msg("second message").unwrap(); // offset 1
    // read the messages
    let messages = log.read(0, ReadLimit::default()).unwrap();
    for msg in messages.iter() {
        println!("{} - {}", msg.offset(), String::from_utf8_lossy(msg.payload()));
    }
    // prints:
    //    0 - hello world
    //    1 - second message
}
```
## Prior Art
- [Apache Kafka](https://kafka.apache.org/)
- [Jocko](https://github.com/travisjeffery/jocko) + [EXCELLENT Blog Post](https://medium.com/the-hoard/how-kafkas-storage-internals-work-3a29b02e026)