*Marshaller: get CacheSerilizer only once

CacheSerializer implementations are stateless (often implemented through
the enum-singleton pattern). There is no need to reach out for them for
each (de)serilize operation. As a bonus 'unchecked' doesn't have to
suppressed in 'read' operations.

Change-Id: I25d4ef94c52de9199029117abb73613bd841b1f5
2 files changed
tree: 42d36b292272cd702408c1e20c52c5f993319f58
  1. src/
  2. .gitignore
  3. BUILD
  4. external_plugin_deps.bzl
  5. Jenkinsfile
  6. LICENSE
  7. README.md
README.md

Persistent cache for Gerrit, based on ChronicleMap

Non-blocking and super-fast on-disk cache libModule for Gerrit Code Review based on ChronicleMap on-disk implementation.

How to build

This libModule is built like a Gerrit in-tree plugin, using Bazelisk. See the build instructions for more details.

Setup

  • Install cache-chronicalmap module

Install the chronicle-map module into the $GERRIT_SITE/lib directory.

Add the cache-chroniclemap module to $GERRIT_SITE/etc/gerrit.config as follows:

[gerrit]
  installModule = com.googlesource.gerrit.modules.cache.chroniclemap.ChronicleMapCacheModule

For further information and supported options, refer to config documentation.

Migration from H2 caches

You can check how to migrate from H2 to chronicle-map here.