Легкое решение для кэширования в Scala?

Мне просто интересно, есть ли какое-либо решение для кэширования в Scala. Я ищу что-то похожее на Guava на Java.

Должен ли я использовать Guava тоже в Scala? В Скалазе есть обертка / сутенер или что-то подобное? Любая альтернатива больше подходит для разработчиков Scala?

Что обеспечивает Гуава:

LoadingCache<Key, Graph> CACHE= CacheBuilder.newBuilder()
       .maximumSize(1000)
       .expireAfterWrite(10, TimeUnit.MINUTES)
       .removalListener(MY_LISTENER)
       .build(
           new CacheLoader<Key, Graph>() {
             public Graph load(Key key) throws AnyException {
               return createExpensiveGraph(key);
             }
           });

Supplier<Animal> singleAnimalCache = Suppliers.memoizeWithExpiration(animalFromDbSupplier(), 365, TimeUnit.DAYS);

Мне нужно базовое управление кешем, как в Гуаве.

Ответы на вопрос(4)

Ваш ответ на вопрос