GitHub - mdaliyan/icache: A High Performance, Generic, thread-safe, zero-dependency, key-value, in-memory cache (original) (raw)

icache

example workflow Coverage Status Go Report Card Go Reference License

icache is a no-dependency, generic support cache library for Go with high concurrent access performance. icache doean't require serialization, so the benchmark report you see at the bottom of the page is what you get at the end, there is no need to marshal and unmarshal anything and waste your valuable resources.

Features

Installation

icache v2 requires go v1.8.0 and above.

go get github.com/mdaliyan/icache/v2

previous version for Go < 1.18

icache v1 is compatible with Go < 1.18, and it also doean't require serialization. it uses reflections to make sure about your data type.

Follow instructions at version v1.x.x for installation and usage. V1 will be maintained separately.

Usage

// make a new Pot: // - to store user structs // - with expiration time of 1 Hour var pot = icache.NewPotuser

var User = user{ ID: "foo", Name: "John Doe", Age: 30, }

// set user to "foo" key pot.Set("foo", User)

// get the user previously set to "foo" key into user1 user1, err := pot.Get("foo")

// you also can add tags to your entries pot.Set("foo", User, "tag1", "tag2") pot.Set("faa", User, "tag1") pot.Set("fom", User, "tag3")

// and delete multiple entries at once pot.DropTags("tag1")

Invalidation Strategies

Benchmarks

goos: darwin goarch: amd64 pkg: github.com/mdaliyan/icache/v2 cpu: Intel(R) Core(TM) i7-8557U CPU @ 1.70GHz BenchmarkICache BenchmarkICache-8 9570999 118.1 ns/op 0 B/op 0 allocs/op BenchmarkICacheConcurrent BenchmarkICacheConcurrent-8 6117471 191.4 ns/op 0 B/op 0 allocs/op

Plans for later