To meet the requirements presented at the beginning of this chapter, we implemented our own cache and named it BigCache. The BigCache provides shards, eviction and it omits GC for cache entries. As a result, it is very fast cache even for large number of entries. Freecache is the only one of the available in-memory caches in Go which provides that kind of functionality. BigCache is an alternative solution for it and reduces GC overhead differently, therefore we decided to share it. Fast, concurrent, evicting in-memory cache written to keep big number of entries without impact on performance. BigCache keeps entries on heap but omits GC for them. To achieve that, operations on byte slices take place, therefore entries (de)serialization in front of the cache will be needed in most use cases.

Features

  • Requires Go 1.12 or newer
  • Use custom initialization because additional memory allocation can be avoided in that way
  • Writes and reads in BigCache are faster than in freecache
  • BigCache relies on optimization presented in 1.5 version of Go
  • Entries are kept in byte slices, to omit GC again
  • BigCache does not handle collisions

Project Samples

Project Activity

See All Activity >

License

Apache License V2.0

Follow BigCache

BigCache Web Site

Other Useful Business Software
Our Free Plans just got better! | Auth0 Icon
Our Free Plans just got better! | Auth0

With up to 25k MAUs and unlimited Okta connections, our Free Plan lets you focus on what you do best—building great apps.

You asked, we delivered! Auth0 is excited to expand our Free and Paid plans to include more options so you can focus on building, deploying, and scaling applications without having to worry about your security. Auth0 now, thank yourself later.
Try free now
Rate This Project
Login To Rate This Project

User Reviews

Be the first to post a review of BigCache!

Additional Project Details

Operating Systems

Linux

Programming Language

Go

Related Categories

Go Performance Testing Software

Registered

2021-11-11