ProactiveCache 1.2.0

dotnet add package ProactiveCache --version 1.2.0                
NuGet\Install-Package ProactiveCache -Version 1.2.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="ProactiveCache" Version="1.2.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add ProactiveCache --version 1.2.0                
#r "nuget: ProactiveCache, 1.2.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install ProactiveCache as a Cake Addin
#addin nuget:?package=ProactiveCache&version=1.2.0

// Install ProactiveCache as a Cake Tool
#tool nuget:?package=ProactiveCache&version=1.2.0                

General description

A simple implementation of the "cache-aside" pattern with forward-looking updates of values on demand before the expiration of the value in the cache.

Features

  • Can be used as its own internal cache (if the external_cache parameter is not specified when creating the cache, then by default a separate instance of the ProactiveCache.MemoryCache class will be created), and any third-party (for example, for System.Runtime.Caching.MemoryCache it is enough to write a wrapper class that implements the ProactiveCache.ICache interface).
  • Allows updating the value in the cache before the expiration of this value by specifying the time before the update - outdate_ttl. After this time expires, the first read from the cache initiates the update of the value, and all subsequent reads will receive the old value from the cache until the update is completed.
  • There is a special cache implementation for updating and retrieving several values from the cache at once by passing an enumeration of keys (ProactiveCache.ProCacheBatch). In this case, the value request function will receive a list of keys whose values need to be updated or added to the cache. If as a result of the operation of such a function, the values of not all the requested keys are returned, then the missing values will be marked as "empty" and will not be included in the result, but at the same time I will be requested again after the cache time has expired.
  • A special implementation of the hooks mechanism will allow you to track some events that occur inside the cache (miss - the value is not in the cache, outdated - the value needs to be updated, expired - the value has been removed from the cache).

Performance issues

  • The time of relevance (time before the value of outdate_ttl expires) of the value in the cache must be long enough so that there are no duplicate update requests. The best practice is to set this value to half the lifetime of the value in the cache (outdate_ttl = expire_ttl / 2). If the time at which the value was received rises to the expiration time, a second request to update this value will be initiated.
  • Despite the strong typing of the cache, each value will be stored on the heap even if it has a value type (forced boxing and unboxing).

Examples of using

Various usage scenarios can be found in the tests for this library ProactiveCacheTests

An example of getting a value by key

Getting a single value from the cache by its key, in the absence of a value, call the local getter method.

ValueTask<float> getter(int key, CancellationToken cancellation) => new ValueTask<float>(key);

var cache = ProCacheFactory
    .CreateOptions<int, float>(expire_ttl: TimeSpan.FromSeconds(120), outdate_ttl: TimeSpan.FromSeconds(60))
    .CreateCache(getter);

var result = cache.Get(1).Result;

An example of getting multiple values from a list of keys

Retrieving several values from the cache by the list of keys, in the absence of a value, call the local getter method with a list of keys not found in the cache. In this example, the getter method will be called twice, the first time with a list of keys[1,2,3], and the second time with a list of keys[4,5,6]

ValueTask<IEnumerable<KeyValuePair<int, float>>> getter(int[] keys, CancellationToken cancellation)
    => new ValueTask<IEnumerable<KeyValuePair<int, float>>>(keys.Select(k => new KeyValuePair<int, float>(k, k)));

var cache = ProCacheFactory
    .CreateOptions<int, float>(expire_ttl: TimeSpan.FromSeconds(120), outdate_ttl: TimeSpan.FromSeconds(60))
    .CreateCache(getter);

var from1to3 = cache.Get(Enumerable.Range(1, 3)).Result;
var from1to6 = cache.Get(Enumerable.Range(1, 6)).Result;
Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on ProactiveCache:

Package Downloads
TypedWorkflow

Allows you to create a simple workflow structure from specially marked up handler methods, in which the input and output types are the links between the work items.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.2.0 465 6/7/2021
1.1.0 361 1/25/2021
1.0.1 584 1/14/2021
1.0.0 779 12/19/2020 1.0.0 is deprecated because it has critical bugs.