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
Auth0 for AI Agents now in GA Icon
Auth0 for AI Agents now in GA

Ready to implement AI with confidence (without sacrificing security)?

Connect your AI agents to apps and data more securely, give users control over the actions AI agents can perform and the data they can access, and enable human confirmation for critical agent actions.
Start building today
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