title |
description |
authors |
date |
Changelog |
Changelog for foyer. |
mrcroxx |
2023-05-12 11:02:09 +0800 |
crate |
version |
foyer |
0.14.0 |
foyer-common |
0.14.0 |
foyer-memory |
0.14.0 |
foyer-storage |
0.14.0 |
foyer-bench |
0.14.0 |
- Insert disk cache on in-memory cache eviction, instead of double write on insertion.
- Extrace multiple metrics backend support to crate
mixtrics
.
crate |
version |
foyer |
0.13.1 |
foyer-common |
0.13.1 |
foyer-memory |
0.13.1 |
foyer-storage |
0.13.1 |
foyer-bench |
0.13.1 |
- Refactor cache builders.
name
field requires Cow<'static, str>
instead of &'static str
for convenience.
crate |
version |
foyer |
0.13.0 |
foyer-common |
0.13.0 |
foyer-memory |
0.13.0 |
foyer-storage |
0.13.0 |
foyer-bench |
0.13.0 |
- Refine in-memory cache framework:
- Allow "get"/"release"/"entry drop" to acquire read lock or lock-free if the algorithm allows.
- Make most
Eviction
APIs safe, only acquire unsafe Rust while accessing algorithm managed per-entry state with UnsafeCell
.
- Replace the "reinsertion" design with
release
with real "release last ref" design.
- Rename some APIs.
- Refine metrics framework:
- Replace
metrics
with customized metrics framework to support various metrics backend.
- Implement built-in metrics exporter that adapts to crate
prometheus
/prometheus-client
/opentelemetry
.
crate |
version |
foyer |
0.12.2 |
foyer-common |
0.12.2 |
foyer-intrusive |
0.12.2 |
foyer-memory |
0.12.2 |
foyer-storage |
0.12.2 |
foyer-bench |
0.12.2 |
- Revert "Scale shards to 1 when there is not enough capacity". It would be useful sometimes. Just raise the warning.
crate |
version |
foyer |
0.12.1 |
foyer-common |
0.12.1 |
foyer-intrusive |
0.12.1 |
foyer-memory |
0.12.1 |
foyer-storage |
0.12.1 |
foyer-bench |
0.12.1 |
- 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.
crate |
version |
foyer |
0.12.0 |
foyer-common |
0.12.0 |
foyer-intrusive |
0.12.0 |
foyer-memory |
0.12.0 |
foyer-storage |
0.12.0 |
foyer-bench |
0.12.0 |
- 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".
crate |
version |
foyer |
0.11.5 |
foyer-common |
0.9.5 |
foyer-intrusive |
0.9.5 |
foyer-memory |
0.7.5 |
foyer-storage |
0.10.5 |
foyer-bench |
0.3.5 |
- Fix panic on dropping the hybrid cache. #736
crate |
version |
foyer |
0.11.4 |
foyer-common |
0.9.4 |
foyer-intrusive |
0.9.4 |
foyer-memory |
0.7.4 |
foyer-storage |
0.10.4 |
foyer-bench |
0.3.4 |
- 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.
crate |
version |
foyer |
0.11.3 |
foyer-common |
0.9.3 |
foyer-intrusive |
0.9.3 |
foyer-memory |
0.7.3 |
foyer-storage |
0.10.3 |
foyer-bench |
0.3.3 |
- Fix panicked by io buffer pool alignment issue.
crate |
version |
foyer |
0.11.2 |
foyer-common |
0.9.2 |
foyer-intrusive |
0.9.2 |
foyer-memory |
0.7.2 |
foyer-storage |
0.10.2 |
foyer-bench |
0.3.2 |
- 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.
crate |
version |
foyer |
0.11.1 |
foyer-common |
0.9.1 |
foyer-intrusive |
0.9.1 |
foyer-memory |
0.7.1 |
foyer-storage |
0.10.1 |
foyer-bench |
0.3.1 |
- 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.
crate |
version |
foyer |
0.11.0 |
foyer-common |
0.9.0 |
foyer-intrusive |
0.9.0 |
foyer-memory |
0.7.0 |
foyer-storage |
0.10.0 |
foyer-bench |
0.3.0 |
- 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.
crate |
version |
foyer |
0.10.4 |
foyer-storage |
0.9.3 |
foyer-bench |
0.2.3 |
- Support serde for recover mode configuration.
crate |
version |
foyer |
0.10.2 |
foyer-storage |
0.9.2 |
foyer-bench |
0.2.2 |
- Fix panic with "none" recovery mode.
crate |
version |
foyer |
0.10.1 |
foyer-common |
0.8.1 |
foyer-intrusive |
0.8.1 |
foyer-memory |
0.6.1 |
foyer-storage |
0.9.1 |
foyer-bench |
0.2.1 |
- Refine write model, make flush buffer threshold configurable to mitigate memory usage spike and OOM.
crate |
version |
foyer |
0.10.0 |
foyer-common |
0.8.0 |
foyer-intrusive |
0.8.0 |
foyer-memory |
0.6.0 |
foyer-storage |
0.9.0 |
foyer-bench |
0.2.0 |
crate |
version |
foyer |
0.9.4 |
foyer-storage |
0.8.5 |
foyer-bench |
0.1.4 |
- Fix phantom entries after foyer storage recovery. #560
- Fix hybrid cache hit metrics with
fetch()
interface. #563
crate |
version |
foyer |
0.9.3 |
foyer-common |
0.7.3 |
foyer-intrusive |
0.7.2 |
foyer-memory |
0.5.2 |
foyer-storage |
0.8.4 |
foyer-bench |
0.1.3 |
- Hybrid cache
fetch()
use the dedicated runtime by default if enabled.
- Separate
fetch()
and fetch_with_runtime()
interface for in-memory cache.
crate |
version |
foyer-storage |
0.8.3 |
- Fix "invalid argument (code: 22)" on target aarch64.
crate |
version |
foyer |
0.9.2 |
foyer-common |
0.7.2 |
foyer-intrusive |
0.7.1 |
foyer-memory |
0.5.1 |
foyer-storage |
0.8.2 |
foyer-bench |
0.1.2 |
- Support customized cache event listener.
crate |
version |
foyer |
0.9.1 |
foyer-common |
0.7.1 |
foyer-intrusive |
0.7.0 |
foyer-memory |
0.5.0 |
foyer-storage |
0.8.1 |
foyer-bench |
0.1.1 |
- 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.
crate |
version |
foyer |
0.9.0 |
foyer-common |
0.7.0 |
foyer-intrusive |
0.6.0 |
foyer-memory |
0.4.0 |
foyer-storage |
0.8.0 |
foyer-bench |
0.1.0 |
- 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.
crate |
version |
foyer |
0.8.9 |
foyer-common |
0.6.4 |
foyer-memory |
0.3.6 |
foyer-storage |
0.7.6 |
foyer-storage-bench |
0.7.5 |
- feat: Add config to control the recover mode.
- feat: Add config to enable/disable direct i/o. (Enabled by default for large entries optimization.)
crate |
version |
foyer |
0.8.8 |
foyer-memory |
0.3.5 |
foyer-storage |
0.7.5 |
foyer-storage-bench |
0.7.4 |
- feat: Impl
Debug
for HybridCache
.
- feat: Impl
serde
, Default
for eviction configs.
- refactor: Add internal trait
EvictionConfig
to bound eviction algorithm configs.
crate |
version |
foyer |
0.8.7 |
- Make
HybridCache
cloneable.
crate |
version |
foyer-memory |
0.3.4 |
crate |
version |
foyer-storage |
0.7.4 |
- Fix
FsDeviceBuilder
on a non-exist directory without capacity given.
crate |
version |
foyer |
0.8.6 |
foyer-common |
0.6.3 |
foyer-intrusive |
0.5.3 |
foyer-memory |
0.3.3 |
foyer-storage |
0.7.3 |
foyer-storage-bench |
0.7.3 |
- Remove unused dependencies.
- Remove hakari workspace hack.
crate |
version |
foyer |
0.8.5 |
- 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.
crate |
version |
foyer |
0.8.4 |
crate |
version |
foyer |
0.8.3 |
- Expose
Key
, Value
, StorageKey
, StorageValue
traits.
crate |
version |
foyer |
0.8.2 |
foyer-common |
0.6.2 |
foyer-intrusive |
0.5.2 |
foyer-memory |
0.3.2 |
foyer-storage |
0.7.2 |
foyer-storage-bench |
0.7.2 |
foyer-workspace-hack |
0.5.2 |
- Add
nightly
feature to make it compatible with night toolchain.
crate |
version |
foyer |
0.8.1 |
foyer-common |
0.6.1 |
foyer-intrusive |
0.5.1 |
foyer-memory |
0.3.1 |
foyer-storage |
0.7.1 |
foyer-storage-bench |
0.7.1 |
foyer-workspace-hack |
0.5.1 |
- Add
with_flush
to enable flush for each io.
- Loose MSRV to 1.76 .
- Flush the device on store close.
crate |
version |
foyer |
0.8.0 |
foyer-common |
0.6.0 |
foyer-intrusive |
0.5.0 |
foyer-memory |
0.3.0 |
foyer-storage |
0.7.0 |
foyer-storage-bench |
0.7.0 |
foyer-workspace-hack |
0.5.0 |
- 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.
crate |
version |
foyer |
0.7.0 |
foyer-common |
0.5.0 |
foyer-intrusive |
0.4.0 |
foyer-memory |
0.2.0 |
foyer-storage |
0.6.0 |
foyer-storage-bench |
0.6.0 |
foyer-workspace-hack |
0.4.0 |
- Make
foyer
compatible with rust stable toolchain (MSRV = 1.77.2). 🎉
crate |
version |
foyer-storage |
0.5.1 |
foyer-memory |
0.1.4 |
- fix: Fix panics on
state()
for s3fifo entry.
- fix: Enable
offset_of
feature for foyer-storage
.
crate |
version |
foyer-intrusive |
0.3.1 |
foyer-memory |
0.1.3 |
- feat: Introduce s3fifo to
foyer-memory
.
- fix: Fix doctest for
foyer-intrusive
.
crate |
version |
foyer-memory |
0.1.2 |
- fix:
foyer-memory
export DefaultCacheEventListener
.
crate |
version |
foyer-memory |
0.1.1 |
- Make eviction config cloneable.
crate |
version |
foyer-storage-bench |
0.5.1 |
- Fix
foyer-storage-bench
build with trace
feature.
crate |
version |
foyer |
0.6.0 |
foyer-common |
0.4.0 |
foyer-intrusive |
0.3.0 |
foyer-memory |
0.1.0 |
foyer-storage |
0.5.0 |
foyer-storage-bench |
0.5.0 |
foyer-workspace-hack |
0.3.0 |
- Release foyer in-memory cache as crate
foyer-memory
.
- Bump other components with changes.
crate |
version |
foyer |
0.5.0 |
foyer-common |
0.3.0 |
foyer-intrusive |
0.2.0 |
foyer-storage |
0.4.0 |
foyer-storage-bench |
0.4.0 |
foyer-workspace-hack |
0.2.0 |
- Bump rust-toolchain to "nightly-2023-12-26".
- Introduce time-series distribution args to bench tool. #253
- Fix duplicated insert drop metrics.
crate |
version |
foyer |
0.4.0 |
foyer-storage |
0.3.0 |
foyer-storage-bench |
0.3.0 |
foyer-workspace-hack |
0.1.1 |
- Remove config
flusher_buffer_capacity
.
- Fix benchmark tool cache miss ratio.
crate |
version |
foyer-storage |
0.2.2 |
- 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.
crate |
version |
foyer-storage |
0.2.1 |
- Introduce the entry size histogram, update metrics.
crate |
version |
foyer |
0.3.0 |
foyer-common |
0.2.0 |
foyer-storage |
0.2.0 |
foyer-storage-bench |
0.2.0 |
- 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.
crate |
version |
foyer |
0.2.0 |
foyer-common |
0.1.0 |
foyer-intrusive |
0.1.0 |
foyer-storage |
0.1.0 |
foyer-storage-bench |
0.1.0 |
foyer-workspace-hack |
0.1.0 |
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.
crate |
version |
foyer |
0.1.0 |
Initial version with just basic interfaces.