Metalama.Patterns.Caching
2024.2.18
Prefix Reserved
See the version list below for details.
dotnet add package Metalama.Patterns.Caching --version 2024.2.18
NuGet\Install-Package Metalama.Patterns.Caching -Version 2024.2.18
<PackageReference Include="Metalama.Patterns.Caching" Version="2024.2.18" />
paket add Metalama.Patterns.Caching --version 2024.2.18
#r "nuget: Metalama.Patterns.Caching, 2024.2.18"
// Install Metalama.Patterns.Caching as a Cake Addin #addin nuget:?package=Metalama.Patterns.Caching&version=2024.2.18 // Install Metalama.Patterns.Caching as a Cake Tool #tool nuget:?package=Metalama.Patterns.Caching&version=2024.2.18
About
The Metalama.Patterns.Caching
package is a front-end library for caching. It simplifies caching method results and invalidating the cached results.
This package is designed for use with the Metalama.Patterns.Caching.Aspects
package, which offers Metalama-based aspects for caching, cache invalidation, and cache key generation. However, the Metalama.Patterns.Caching
package does not rely on the Metalama aspect framework, and it can be used independently or with another aspect framework.
Key Features
- Caching the return value of a method as a function of its arguments.
- Invalidation of cached method results, both directly and indirectly through cache dependencies.
- In-memory cache, Redis cache, Pub/Sub synchronized cache, L2 in-memory cache.
- Caching profiles for dynamically changing settings at runtime.
- Automatic reload of expired cached items.
- Cache key formatters through the
Flashtrace.Formatters
package. - Value adapters for caching "special" types like streams or enumerables.
- Locking to prevent concurrent execution.
This package can interact with any cache implementation. The abstraction is provided by the CachingBackend class from the Metalama.Patterns.Caching.Backend
package.
Main Types
The primary types in this package are:
- ICachingService is the main interface.
- CachingService is the primary implementation of
ICachingService
and should generally not be directly used unless you are not using dependency injection. - CachingServiceFactory extends
IServiceCollection
and allows the addition ofICachingService
to your application. - CachedMethodMetadata represents the metadata of a cached method. If you are not using an aspect framework, you must create an instance of this class for each cached method.
- CacheKeyBuilder is the algorithm that generates the cache key based on the method metadata and its arguments.
- IValueAdapter is the abstraction for caching special types like streams or enumerables.
Additional Documentation
- Conceptual documentation: https://doc.postsharp.net/metalama/patterns/caching.
- API documentation: https://doc.postsharp.net/metalama/api/metalama-patterns-caching.
Related Packages
Metalama.Patterns.Caching.Aspects
provides an aspect-oriented API for the current package.Metalama.Patterns.Caching.Backend
defines the CachingBackend abstraction and provides core implementations for in-memory and multi-layered caching.Metalama.Patterns.Caching.Backends.Redis
offers theCachingBackend
implementation for Redis.Metalama.Patterns.Caching.Backends.Azure
implements pub/sub synchronization of distributed in-memory caches through Azure Message Bus.Flashtrace.Formatters
provides an infrastructure for cache key formatting.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. 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. |
.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 is compatible. 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. |
-
.NETFramework 4.7.1
- Flashtrace (>= 2024.2.18)
- Flashtrace.Formatters (>= 2024.2.18)
- Metalama.Patterns.Caching.Backend (>= 2024.2.18)
- Microsoft.Extensions.Caching.Memory (>= 7.0.0)
- System.Collections.Immutable (>= 8.0.0)
- System.Runtime.Serialization.Xml (>= 4.3.0)
- System.Text.Json (>= 8.0.4)
- System.Text.RegularExpressions (>= 4.3.1)
- System.Threading (>= 4.3.0)
- System.Threading.Tasks.Extensions (>= 4.5.4)
- System.Threading.Thread (>= 4.3.0)
- System.Threading.ThreadPool (>= 4.3.0)
-
.NETStandard 2.0
- Flashtrace (>= 2024.2.18)
- Flashtrace.Formatters (>= 2024.2.18)
- Metalama.Patterns.Caching.Backend (>= 2024.2.18)
- Microsoft.Extensions.Caching.Memory (>= 7.0.0)
- System.Collections.Immutable (>= 8.0.0)
- System.Text.Json (>= 8.0.4)
- System.Threading.Tasks.Extensions (>= 4.5.4)
-
net6.0
- Flashtrace (>= 2024.2.18)
- Flashtrace.Formatters (>= 2024.2.18)
- Metalama.Patterns.Caching.Backend (>= 2024.2.18)
- Microsoft.Extensions.Caching.Memory (>= 7.0.0)
- System.Collections.Immutable (>= 8.0.0)
- System.Text.Json (>= 8.0.4)
NuGet packages (4)
Showing the top 4 NuGet packages that depend on Metalama.Patterns.Caching:
Package | Downloads |
---|---|
Shinya.Core
Shinya.Framework |
|
Metalama.Patterns.Caching.Aspects
A set of aspects that simplify the caching: [Cache] to cache a method result as a function of its parameters, [InvalidateCache] to invalidate the cache, or [CacheKey] to mark a cache key in a class. |
|
Metalama.Patterns.Caching.Backends.Redis
Redis back-end for Metalama.Patterns.Caching. Implements both caching and cache invalidation over Redis Pub/Sub |
|
Metalama.Patterns.Caching.Backends.Azure
Synchronizes the invalidation of distributed Metalama.Patterns.Caching caches over Azure Service Bus. |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
2025.0.7-rc | 202 | 12/6/2024 |
2025.0.6-rc | 259 | 11/15/2024 |
2025.0.5-preview | 145 | 11/8/2024 |
2025.0.4-preview | 135 | 10/31/2024 |
2025.0.3-preview | 137 | 10/25/2024 |
2025.0.2-preview | 140 | 10/24/2024 |
2025.0.1-preview | 127 | 10/14/2024 |
2024.2.31 | 170 | 12/6/2024 |
2024.2.30 | 182 | 11/15/2024 |
2024.2.29 | 187 | 10/31/2024 |
2024.2.28 | 180 | 10/25/2024 |
2024.2.27 | 168 | 10/24/2024 |
2024.2.26 | 218 | 10/14/2024 |
2024.2.25 | 200 | 10/2/2024 |
2024.2.24 | 241 | 9/10/2024 |
2024.2.23 | 552 | 8/30/2024 |
2024.2.22 | 207 | 8/29/2024 |
2024.2.21 | 188 | 8/28/2024 |
2024.2.20 | 245 | 8/15/2024 |
2024.2.19 | 806 | 8/1/2024 |
2024.2.18 | 175 | 7/29/2024 |
2024.2.17-rc | 181 | 7/22/2024 |
2024.2.16-rc | 148 | 7/18/2024 |
2024.2.15-rc | 182 | 7/12/2024 |
2024.2.14-rc | 183 | 7/8/2024 |
2024.2.13-rc | 171 | 7/2/2024 |
2024.2.12-preview | 164 | 6/28/2024 |
2024.2.11-preview | 188 | 6/26/2024 |
2024.2.10-preview | 164 | 6/20/2024 |
2024.2.9-preview | 215 | 6/11/2024 |
2024.2.8-preview | 129 | 6/6/2024 |
2024.2.7-preview | 187 | 5/30/2024 |
2024.2.6-preview | 191 | 5/25/2024 |
2024.2.5-preview | 198 | 5/6/2024 |
2024.2.4-preview | 179 | 5/4/2024 |
2024.2.3-preview | 193 | 4/30/2024 |
2024.2.2-preview | 178 | 4/23/2024 |
2024.2.1-preview | 164 | 4/11/2024 |
2024.1.30 | 158 | 10/24/2024 |
2024.1.29 | 171 | 10/11/2024 |
2024.1.28 | 192 | 9/9/2024 |
2024.1.27 | 195 | 8/28/2024 |
2024.1.26 | 226 | 8/15/2024 |
2024.1.25 | 178 | 7/22/2024 |
2024.1.24 | 183 | 7/12/2024 |
2024.1.23 | 221 | 6/26/2024 |
2024.1.22 | 219 | 6/15/2024 |
2024.1.21 | 194 | 6/6/2024 |
2024.1.20 | 227 | 5/30/2024 |
2024.1.19 | 230 | 5/24/2024 |
2024.1.18 | 323 | 5/6/2024 |
2024.1.17 | 210 | 5/3/2024 |
2024.1.16 | 254 | 4/30/2024 |
2024.1.15 | 244 | 4/29/2024 |
2024.1.14 | 194 | 4/23/2024 |
2024.1.13 | 223 | 4/23/2024 |
2024.1.12 | 250 | 4/17/2024 |
2024.1.11-rc | 164 | 4/11/2024 |
2024.1.10-rc | 171 | 4/4/2024 |
2024.1.9-rc | 187 | 3/27/2024 |
2024.1.8-preview | 167 | 3/25/2024 |
2024.1.7-preview | 185 | 3/19/2024 |
2024.1.6-preview | 194 | 3/6/2024 |
2024.1.5-preview | 197 | 2/29/2024 |
2024.1.4-preview | 230 | 2/27/2024 |
2024.1.3-preview | 199 | 2/23/2024 |
2024.1.2-preview | 207 | 2/7/2024 |
2024.1.1-preview | 158 | 1/30/2024 |
2024.0.16 | 253 | 6/15/2024 |
2024.0.15 | 208 | 6/6/2024 |
2024.0.14 | 205 | 5/30/2024 |
2024.0.13 | 220 | 5/24/2024 |
2024.0.12 | 233 | 4/17/2024 |
2024.0.11 | 232 | 3/21/2024 |
2024.0.10 | 215 | 3/19/2024 |
2024.0.9 | 237 | 2/29/2024 |
2024.0.8 | 236 | 2/23/2024 |
2024.0.7 | 236 | 2/7/2024 |
2024.0.6 | 291 | 1/3/2024 |
2024.0.5-rc | 208 | 12/21/2023 |
2024.0.4-rc | 200 | 12/12/2023 |
2024.0.3-preview | 195 | 12/6/2023 |
2024.0.2-preview | 205 | 11/14/2023 |
2024.0.1-preview | 203 | 11/6/2023 |
2023.4.9 | 246 | 2/7/2024 |
2023.4.8 | 249 | 12/21/2023 |
2023.4.7 | 238 | 12/12/2023 |
2023.4.6 | 257 | 11/7/2023 |
2023.4.5-rc | 212 | 10/26/2023 |
2023.4.4-preview | 188 | 10/18/2023 |
2023.4.3-preview | 194 | 10/4/2023 |
2023.4.2-preview | 201 | 9/26/2023 |
2023.3.10-preview | 178 | 12/21/2023 |
2023.3.9-preview | 193 | 12/12/2023 |
2023.3.8-preview | 237 | 10/17/2023 |
2023.3.7-preview | 181 | 9/29/2023 |
2023.3.6-preview | 210 | 9/26/2023 |
2023.3.5-preview | 164 | 9/13/2023 |
2023.3.4-preview | 180 | 8/30/2023 |