JoeShook.ZiggyCreatures.FusionCache.Metrics.AppMetrics
1.0.11
dotnet add package JoeShook.ZiggyCreatures.FusionCache.Metrics.AppMetrics --version 1.0.11
NuGet\Install-Package JoeShook.ZiggyCreatures.FusionCache.Metrics.AppMetrics -Version 1.0.11
<PackageReference Include="JoeShook.ZiggyCreatures.FusionCache.Metrics.AppMetrics" Version="1.0.11" />
paket add JoeShook.ZiggyCreatures.FusionCache.Metrics.AppMetrics --version 1.0.11
#r "nuget: JoeShook.ZiggyCreatures.FusionCache.Metrics.AppMetrics, 1.0.11"
// Install JoeShook.ZiggyCreatures.FusionCache.Metrics.AppMetrics as a Cake Addin #addin nuget:?package=JoeShook.ZiggyCreatures.FusionCache.Metrics.AppMetrics&version=1.0.11 // Install JoeShook.ZiggyCreatures.FusionCache.Metrics.AppMetrics as a Cake Tool #tool nuget:?package=JoeShook.ZiggyCreatures.FusionCache.Metrics.AppMetrics&version=1.0.11
FusionCache.AppMetrics
FusionCache.AppMetrics is a plugin to capture caching metrics using FusionCache
Metrics are missing from open-source resiliency projects in the .NET ecosystem where in equivalent Java libraries, metrics tend to be common. FusionCache is a feature rich caching library addressing resiliency needs of today’s enterprise implementations. Appmetrics is an easy-to-use metrics library that works in .NET Framework and .NET Core. Joining these two excellent libraries together you can easily be caching and writing metrics to your favorite timeseries database.
Usage
var hostNameCache = new MemoryCache(new MemoryCacheOptions());
var appMetricsContextLabel = "MyApplication";
var appMetrics = new MetricsBuilder()
.Configuration.Configure(
options =>
{
options.DefaultContextLabel = appMetricsContextLabel;
})
.Report
.ToInfluxDb(
options =>
{
var filter = new MetricsFilter();
filter.WhereContext(c => c == appMetricsContextLabel); //remove default AppMetrics metrics.
options.InfluxDb.BaseUri = new Uri($"http://{ Configuration["InfluxDbConfig.Host"] }:{ Configuration["InfluxDbConfig.Port"] }");
options.InfluxDb.Database = Configuration["InfluxDbConfig.Database"];
options.InfluxDb.RetentionPolicy = Configuration["InfluxDbConfig.RetentionPolicy"];
options.InfluxDb.UserName = Configuration["InfluxDbConfig.Username"];
options.InfluxDb.Password = Configuration["InfluxDbConfig.Password"];
options.InfluxDb.CreateDataBaseIfNotExists = false;
options.MetricsOutputFormatter = new MetricsInfluxDbLineProtocolOutputFormatter(
new MetricsInfluxDbLineProtocolOptions
{
MetricNameFormatter = (metricContext, metricName) => $"{appMetricsContextLabel}_{metricContext}"
});
})
// .Report.ToTextFile(
// options => {
// options.MetricsOutputFormatter = new MetricsJsonOutputFormatter();
// options.AppendMetricsToTextFile = true;
// // options.Filter = filter;
// options.FlushInterval = TimeSpan.FromSeconds(20);
// options.OutputPathAndFileName = @"C:\temp\metrics.txt";
// })
.Build();
//
// Cache called "domain"
//
// Register AppMetricsProvider as a IFusionCachePlugin.
// Note that a MemoryCache object must be created outside of AddFusionCache extension method so that
// AppMetricsProvider is holding the same object as FusionCache to enabled cache count reporting.
// See line 180 in FusionCacheEventSource.cs
//
services.AddSingleton<IMemoryCache>(hostNameCache);
services.AddSingleton<IFusionCachePlugin>(new AppMetricsProvider("domain", appMetrics, hostNameCache));
services.AddFusionCache(options =>
options.DefaultEntryOptions = new FusionCacheEntryOptions
{
Duration = TimeSpan.FromSeconds(1),
JitterMaxDuration = TimeSpan.FromMilliseconds(200),
IsFailSafeEnabled = true,
FailSafeMaxDuration = TimeSpan.FromHours(1),
FailSafeThrottleDuration = TimeSpan.FromSeconds(1),
FactorySoftTimeout = TimeSpan.FromMilliseconds(100),
FactoryHardTimeout = TimeSpan.FromSeconds(1)
});
var metricsReporterService = new MetricsReporterBackgroundService(appMetrics, appMetrics.Options, appMetrics.Reporters);
metricsReporterService.StartAsync(CancellationToken.None);
services.AddSingleton(sp => metricsReporterService );
AppMetrics Plugin is an easy to use solution for .NET Framework apps. If you already use AppMetrics then this would be an easy way to go.
There are two example WebApi style projects included:
Metrics plugins are created by subscribing to FusionCache Events.
MetricsConfig
MetricsConfig
contains the following properties and can be overriden by adding a CacheMetrics
section to appsettings.json.
ApplicationName
is defaulted to the executing assembly name.ApplicationVersion
is defaulted to the executing assembly version.Prefix
is defaulted to "appMetrics"MeasurementName
is defaulted to "Cache-Events"see Examples for usage
The following Events are subscribed to. Each event includes a Tag named "cacheEvent" and a tag value. Both the "cacheEvent" name and Tag values are defined in the SemanticConventions
class. These conventions can be changed by implementing a new ISemanticConventions
interface and registering in you dependency injection framework. Tags are typical in time series databases and are indexed making them friendly to searching and grouping over time.
Events:: Incrementing Polling Counters for Hits and Misses
The following counters all set AppMetrics's CounterOptions for ResetOnReporting to true. The effect is each time a reporter queries the counter it will be reset. All the following counters accept the CacheCountIncrement and CacheCountDecrement set ResetOnReporting to true.
CacheHit()
The cache tag is "HIT". Every cache hit will increment a counter.
CacheMiss()
The cache tag is "MISS". Every cache miss will increment a counter.
CacheStaleHit()
The cache tag is "STALE_HIT". When FailSafe is enabled and a request times out due to a "soft timeout" and a stale cache item exists then increment a counter. Note this will not trigger the CacheMiss() counter.
CacheBackgroundRefresh()
The cache tag is "STALE_REFRESH". When FailSafe is enabled and a request times out due to a "soft timeout" the request will continue for the length of a "hard timeout". If the request finds data it will call this CacheBackgroundRefresh() and increment a counter. Note it would be normal for this counter and CacheStaleHit() to track with eachother.
CacheRemoved()
The cache tag is "REMOVE". When the cache is removed by user code.
Incrementing Polling Counter for Evictions
Eviction counters are wired into the ICacheEntries with the PostEvictionDelegate.
CacheExpired
The cache tag is "EXPIRE". When the EvictionReason is Expired increment a counter.
CacheCapacityExpired()
The cache tag is "CAPACITY". When the EvictionReason is Capacity increment a counter.
Events:: Polling Counters
CacheCount()
The cach tag is "ITEM_COUNT". Calls the MemoryCache.Count
For this feature MemoryCache
must be created and passed to FusionCache
and AppMetricsProvider
so they share the same intance of MemoryCache
Product | Versions 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. |
-
.NETStandard 2.0
- App.Metrics (>= 4.3.0)
- JoeShook.ZiggyCreatures.FusionCache.Metrics.Core (>= 1.0.11)
- ZiggyCreatures.FusionCache (>= 0.23.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.0.11 | 1,739 | 10/17/2023 |
1.0.7 | 190 | 7/27/2023 |
1.0.6 | 248 | 3/28/2023 |
1.0.5 | 3,743 | 11/25/2022 |
1.0.4 | 443 | 5/2/2022 |
1.0.3 | 447 | 2/20/2022 |
1.0.3-preview001 | 503 | 12/6/2021 |
1.0.2 | 1,065 | 12/1/2021 |
1.0.0 | 370 | 7/26/2021 |
1.0.0-preview003 | 237 | 7/23/2021 |
1.0.0-preview002 | 258 | 7/22/2021 |
1.0.0-preview001 | 215 | 7/20/2021 |
Update to FusionCache v0.10