Skip to content

hslam/wal

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

64 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

wal

PkgGoDev Build Status codecov Go Report Card LICENSE

Package wal implements write-ahead logging.

Feature

  • Low memory usage
  • Segment
  • Batch writes
  • Clean/Truncate/Reset

Get started

Install

go get github.com/hslam/wal

Import

import "github.com/hslam/wal"

Usage

Example

package main

import (
	"fmt"
	"github.com/hslam/wal"
	"os"
)

func main() {
	path := "wal"
	os.RemoveAll(path)
	w, err := wal.Open(path, &wal.Options{SegmentEntries: 3})
	if err != nil {
		panic(err)
	}
	defer w.Close()
	// Write
	w.Write(1, []byte("Hello World"))
	w.Flush()
	w.Sync()
	// Batch Write
	w.Write(2, []byte("Hello WAL"))
	w.Write(3, []byte("Hello MH"))
	w.Flush()
	w.Sync()
	data, _ := w.Read(1)
	fmt.Println(string(data))
	w.Clean(2)
	w.Truncate(2)
	w.Reset()
}

Output

Hello World

License

This package is licensed under a MIT license (Copyright (c) 2020 Meng Huang)

Author

wal was written by Meng Huang.

About

Package wal implements write-ahead logging.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages