Skip to main content

Changelog

· 14 min read
Croxx
Author of foyer

2024-10-11

Releases

crateversion
foyer0.12.2
foyer-common0.12.2
foyer-intrusive0.12.2
foyer-memory0.12.2
foyer-storage0.12.2
foyer-bench0.12.2

Changes

  • Revert "Scale shards to 1 when there is not enough capacity". It would be useful sometimes. Just raise the warning.

2024-10-10

Releases

crateversion
foyer0.12.1
foyer-common0.12.1
foyer-intrusive0.12.1
foyer-memory0.12.1
foyer-storage0.12.1
foyer-bench0.12.1

Changes

  • Downgrade hashbrown to 0.14 to fix build on nightly for projects using hashbrown < 0.15.
  • Fix build with madsim.
  • Refine small object disk cache.
  • Scale shards to 1 when there is not enough capacity.

2024-10-09

Releases

crateversion
foyer0.12.0
foyer-common0.12.0
foyer-intrusive0.12.0
foyer-memory0.12.0
foyer-storage0.12.0
foyer-bench0.12.0

Changes

  • Align the versions of all components to the same. 📣
  • Introduce small object disk cache. 🎉
  • Introduce mixed/large/small storage engine.
  • Refactor builders for the hybrid cache.
  • Introduce submit queue size threshold to prevent from channel piling up.
  • Support jeprof for foyer-bench.
  • Rename feature "mtrace" to "tracing".

2024-09-25

Releases

crateversion
foyer0.11.5
foyer-common0.9.5
foyer-intrusive0.9.5
foyer-memory0.7.5
foyer-storage0.10.5
foyer-bench0.3.5

Changes

  • Fix panic on dropping the hybrid cache. #736

2024-09-24

Releases

crateversion
foyer0.11.4
foyer-common0.9.4
foyer-intrusive0.9.4
foyer-memory0.7.4
foyer-storage0.10.4
foyer-bench0.3.4

Changes

  • Revert pre-serialization design. The insert latency and memory usage would be better for most cases.
  • Rename with_buffer_threshold to with_buffer_pool_size. The old method is kept but marked as deprecated.
  • Raise a warn when using DirectFileDevice on within a file system.

2024-09-20

Releases

crateversion
foyer0.11.3
foyer-common0.9.3
foyer-intrusive0.9.3
foyer-memory0.7.3
foyer-storage0.10.3
foyer-bench0.3.3

Changes

  • Fix panicked by io buffer pool alignment issue.

2024-09-12

Releases

crateversion
foyer0.11.2
foyer-common0.9.2
foyer-intrusive0.9.2
foyer-memory0.7.2
foyer-storage0.10.2
foyer-bench0.3.2

Changes

  • Support windows (for foyer only).
  • Bump rust toolchain to 1.81.0.
  • Expose in-memory cache builder and cache entry.
  • Reduce page fault and vec growth overhead.
  • Use bytes size for foyer-bench.
  • Fix install deps script.

2024-08-31

Releases

crateversion
foyer0.11.1
foyer-common0.9.1
foyer-intrusive0.9.1
foyer-memory0.7.1
foyer-storage0.10.1
foyer-bench0.3.1

Changes

  • Add metrics for serde.
  • Refine fetch runtime usage.
  • Fix unhandled low-layer errors. #674 #677 #679
  • Implement Default for TokioRuntimeConfig.
  • Fix typos and format code with unstable features.

2024-08-21

Releases

crateversion
foyer0.11.0
foyer-common0.9.0
foyer-intrusive0.9.0
foyer-memory0.7.0
foyer-storage0.10.0
foyer-bench0.3.0

Changes

  • Support disk cache on raw block device.
  • Support fine-grained storage engine runtime configuration.
  • Enhance performance via reducing page fault.
  • Refine storage engine framework for future features.
  • Expose Weighter trait.
  • Support serde for more configurations.
  • Update foyer-bench with more fine-grained configurations.
  • Fix panics with None recover mode.

2024-08-15

Releases

crateversion
foyer0.10.4
foyer-storage0.9.3
foyer-bench0.2.3

Changes

  • Support serde for recover mode configuration.

2024-08-14

Releases

crateversion
foyer0.10.2
foyer-storage0.9.2
foyer-bench0.2.2

Changes

  • Fix panic with "none" recovery mode.

2024-07-08

Releases

crateversion
foyer0.10.1
foyer-common0.8.1
foyer-intrusive0.8.1
foyer-memory0.6.1
foyer-storage0.9.1
foyer-bench0.2.1

Changes

  • Refine write model, make flush buffer threshold configurable to mitigate memory usage spike and OOM.

2024-07-02

Releases

crateversion
foyer0.10.0
foyer-common0.8.0
foyer-intrusive0.8.0
foyer-memory0.6.0
foyer-storage0.9.0
foyer-bench0.2.0

Changes

2024-06-14

Releases

crateversion
foyer0.9.4
foyer-storage0.8.5
foyer-bench0.1.4

Changes

  • Fix phantom entries after foyer storage recovery. #560
  • Fix hybrid cache hit metrics with fetch() interface. #563

2024-06-05

Releases

crateversion
foyer0.9.3
foyer-common0.7.3
foyer-intrusive0.7.2
foyer-memory0.5.2
foyer-storage0.8.4
foyer-bench0.1.3

Changes

  • Hybrid cache fetch() use the dedicated runtime by default if enabled.
  • Separate fetch() and fetch_with_runtime() interface for in-memory cache.

2024-06-04

Releases

crateversion
foyer-storage0.8.3

Changes

  • Fix "invalid argument (code: 22)" on target aarch64.

2024-06-03

Releases

crateversion
foyer0.9.2
foyer-common0.7.2
foyer-intrusive0.7.1
foyer-memory0.5.1
foyer-storage0.8.2
foyer-bench0.1.2

Changes

  • Support customized cache event listener.

2024-05-31

Releases

crateversion
foyer0.9.1
foyer-common0.7.1
foyer-intrusive0.7.0
foyer-memory0.5.0
foyer-storage0.8.1
foyer-bench0.1.1

Changes

  • Fix "attempt to subtract with overflow" panic after cloning cache entry. #543.
  • Fix "assertion failed: base.is_in_indexer()" panic after replacing deposit entry. #547.
  • Fix setting name for in-memory cache.
  • Add region related metrics.
  • Introduce strict_assertions and sanity feature for debugging.
  • foyer-bench support setting eviction algorithm.
  • Upgrade metrics to 0.23.
  • Remove pop() related interface from the in-memory cache.
  • Refine intrusive data structure implementation.

2024-05-27

Releases

crateversion
foyer0.9.0
foyer-common0.7.0
foyer-intrusive0.6.0
foyer-memory0.4.0
foyer-storage0.8.0
foyer-bench0.1.0

Changes

  • Refine the storage engine to reduce the overhead and boost the performance.
    • Hybrid cache memory overhead reduced by ~50%.
    • Hybrid cache operation latency reduced by ~80%.
  • Replace prometheus with metrics to support more flexible metrics collection.
  • Introduce foyer-bench to replace the original foyer-storage-bench for better benchmarking.
  • Fulfill rust docs for public APIs.
  • Introduce tombstone log for updatable persistent cache.
  • Reduce unnecessary dependencies.
  • More details: foyer - Development Roadmap.

2024-04-28

Releases

crateversion
foyer0.8.9
foyer-common0.6.4
foyer-memory0.3.6
foyer-storage0.7.6
foyer-storage-bench0.7.5

Changes

  • feat: Add config to control the recover mode.
  • feat: Add config to enable/disable direct i/o. (Enabled by default for large entries optimization.)

2024-04-28

Releases

crateversion
foyer0.8.8
foyer-memory0.3.5
foyer-storage0.7.5
foyer-storage-bench0.7.4

Changes

  • feat: Impl Debug for HybridCache.
  • feat: Impl serde, Default for eviction configs.
  • refactor: Add internal trait EvictionConfig to bound eviction algorithm configs.

2024-04-27

Releases

crateversion
foyer0.8.7

Changes

  • Make HybridCache cloneable.

2024-04-27

Releases

crateversion
foyer-memory0.3.4

Changes

  • Fix S3FIFO ghost queue.

2024-04-26

Releases

crateversion
foyer-storage0.7.4

Changes

  • Fix FsDeviceBuilder on a non-exist directory without capacity given.

2024-04-26

Releases

crateversion
foyer0.8.6
foyer-common0.6.3
foyer-intrusive0.5.3
foyer-memory0.3.3
foyer-storage0.7.3
foyer-storage-bench0.7.3

Changes

  • Remove unused dependencies.
  • Remove hakari workspace hack.

2024-04-26

Releases

crateversion
foyer0.8.5

Changes

  • Expose EntryState, HybridEntry.
  • Expose StorageWriter, Metrics, get_metrics_registry, set_metrics_registry.
  • Expose RangeBoundsExt, BufExt, BufMutExt.
  • Re-export ahash::RandomState.
  • Loose entry() args trait bounds.

2024-04-25

Releases

crateversion
foyer0.8.4

Changes

  • Expose HybridCacheEntry.

2024-04-25

Releases

crateversion
foyer0.8.3

Changes

  • Expose Key, Value, StorageKey, StorageValue traits.

2024-04-24

Releases

crateversion
foyer0.8.2
foyer-common0.6.2
foyer-intrusive0.5.2
foyer-memory0.3.2
foyer-storage0.7.2
foyer-storage-bench0.7.2
foyer-workspace-hack0.5.2

Changes

  • Add nightly feature to make it compatible with night toolchain.

2024-04-24

Releases

crateversion
foyer0.8.1
foyer-common0.6.1
foyer-intrusive0.5.1
foyer-memory0.3.1
foyer-storage0.7.1
foyer-storage-bench0.7.1
foyer-workspace-hack0.5.1

Changes

  • Add with_flush to enable flush for each io.
  • Loose MSRV to 1.76 .
  • Flush the device on store close.

2024-04-23

Releases

crateversion
foyer0.8.0
foyer-common0.6.0
foyer-intrusive0.5.0
foyer-memory0.3.0
foyer-storage0.7.0
foyer-storage-bench0.7.0
foyer-workspace-hack0.5.0

Changes

  • Combine in-memory cache and disk cache into HybridCache.
  • Refine APIs, make them more user-friendly.
  • Refine Key, Value, StorageKey, StorageValue traits.
  • Support serde for storage key and value serialization and deserialization.
  • Loose trait bounds for key and value.
  • Add configurable ghost queue for S3FIFO.
  • Fix S3FIFO eviction bugs.
  • Add more examples.

2024-04-11

Releases

crateversion
foyer0.7.0
foyer-common0.5.0
foyer-intrusive0.4.0
foyer-memory0.2.0
foyer-storage0.6.0
foyer-storage-bench0.6.0
foyer-workspace-hack0.4.0

Changes

  • Make foyer compatible with rust stable toolchain (MSRV = 1.77.2). 🎉

2024-04-09

Releases

crateversion
foyer-storage0.5.1
foyer-memory0.1.4

Changes

  • fix: Fix panics on state() for s3fifo entry.
  • fix: Enable offset_of feature for foyer-storage.

2024-04-08

Releases

crateversion
foyer-intrusive0.3.1
foyer-memory0.1.3

Changes

  • feat: Introduce s3fifo to foyer-memory.
  • fix: Fix doctest for foyer-intrusive.

2024-03-21

Releases

crateversion
foyer-memory0.1.2

Changes

  • fix: foyer-memory export DefaultCacheEventListener.

2024-03-14

Releases

crateversion
foyer-memory0.1.1

Changes

  • Make eviction config cloneable.

2024-03-13

Releases

crateversion
foyer-storage-bench0.5.1

Changes

  • Fix foyer-storage-bench build with trace feature.

2024-03-12

Releases

crateversion
foyer0.6.0
foyer-common0.4.0
foyer-intrusive0.3.0
foyer-memory0.1.0
foyer-storage0.5.0
foyer-storage-bench0.5.0
foyer-workspace-hack0.3.0

Changes

  • Release foyer in-memory cache as crate foyer-memory.
  • Bump other components with changes.

2023-12-28

Releases

crateversion
foyer0.5.0
foyer-common0.3.0
foyer-intrusive0.2.0
foyer-storage0.4.0
foyer-storage-bench0.4.0
foyer-workspace-hack0.2.0

Changes

  • Bump rust-toolchain to "nightly-2023-12-26".
  • Introduce time-series distribution args to bench tool. #253
  • Fix duplicated insert drop metrics.

2023-12-22

Releases

crateversion
foyer0.4.0
foyer-storage0.3.0
foyer-storage-bench0.3.0
foyer-workspace-hack0.1.1

Changes

  • Remove config flusher_buffer_capacity.
  • Fix benchmark tool cache miss ratio.

2023-12-20

Releases

crateversion
foyer-storage0.2.2

Changes

  • Fix metrics for writer dropping.
  • Add interface insert_async_with_callback and insert_if_not_exists_async_with_callback for callers to get the insert result.

2023-12-18

Releases

crateversion
foyer-storage0.2.1

Changes

  • Introduce the entry size histogram, update metrics.

2023-12-18

Releases

crateversion
foyer0.3.0
foyer-common0.2.0
foyer-storage0.2.0
foyer-storage-bench0.2.0

Changes

  • Introduce the associated type Cursor for trait Key and Value to reduce unnecessary buffer copy if possible.
  • Remove the ring buffer and continuum tracker for they are no longer needed.
  • Update the configuration of the storage engine and the benchmark tool.

2023-11-29

Releases

crateversion
foyer0.2.0
foyer-common0.1.0
foyer-intrusive0.1.0
foyer-storage0.1.0
foyer-storage-bench0.1.0
foyer-workspace-hack0.1.0

Changes

The first version that can be used as file cache.

The write model and the design of storage engine has been switched from CacheLib navy version to the ring buffer version (which was highly inspired by MySQL 8.0 link_buf).

Introduces Store, RuntimeStore, LazyStore to simplify usage. In most cases, RuntimeStore is preferred to use a dedicated tokio runtime to serve foyer to avoid the influence to the user's runtime. If lazy-load is needed, use RuntimeLazyStore instead.

The implementation of foyer is separated into multiple crates. But importing foyer is enough for it re-exports the crates that foyer's user needs.

Brief description about the subcrates:

  • foyer-common: Provide basic data structures and algorithms.
  • foyer-intrusive: Provide intrusive containers for implementing eviction lists and collections. Intrusive data structures provide the ability to implement low-cost multi-index data structures, which will be used for the memory cache in future.
  • foyer-storage: Provide the file cache storage engine and wrappers to simplify the code.
  • foyer-storage-bench: Runnable benchmark tool for the file cache storage engine.
  • foyer-workspace-hack: Generated by hakari to prevent building each crate from triggering building from scratch.

2023-05-12

Releases

crateversion
foyer0.1.0

Changes

Initial version with just basic interfaces.