DefaultCSRedisCachingProvider
EasyCaching.CSRedis is a redis caching lib which is based on EasyCaching.Core and CSRedisCore.
When you use this lib , it means that you will handle the data of your redis servers . As usual , we will use it as distributed caching .
How to use ?
Basic Usages
1. Install the package via Nuget
Install-Package EasyCaching.CSRedis
2. Config in Startup class
There are two way's how you can configure caching provider.
By C# code:
public class Startup
{
//...
public void ConfigureServices(IServiceCollection services)
{
//other services.
//Important step for Redis Caching
services.AddEasyCaching(option =>
{
option.UseCSRedis(config =>
{
config.DBConfig = new CSRedisDBOptions
{
ConnectionStrings = new System.Collections.Generic.List<string>
{
"127.0.0.1:6388,defaultDatabase=13,poolsize=10"
},
// the sentinels settings
Sentinels = new System.Collections.Generic.List<string>
{
"192.169.1.10:26379", "192.169.1.11:26379", "192.169.1.12:26379"
},
// the read write setting for sentinel mode
ReadOnly = false
};
});
});
}
}
Alternatively you can store configuration in the appsettings.json
.
public class Startup
{
//...
public void ConfigureServices(IServiceCollection services)
{
//other services.
//Important step for Redis Caching
services.AddEasyCaching(option =>
{
option.UseCSRedis(Configuration, "myredisname", "easycaching:csredis");
});
}
}
appsettings.json
example:
"easycaching": {
"csredis": {
"MaxRdSecond": 120,
"EnableLogging": false,
"LockMs": 5000,
"SleepMs": 300,
"dbconfig": {
"ConnectionStrings":[
"127.0.0.1:6388,defaultDatabase=13,poolsize=10"
],
"Sentinels":[
"192.169.1.10:26379", "192.169.1.11:26379", "192.169.1.12:26379"
],
"ReadOnly": false
}
}
}
3. Call the IEasyCachingProvider
Following code shows how to use EasyCachingProvider in ASP.NET Core Web API.
[Route("api/[controller]")]
public class ValuesController : Controller
{
private readonly IEasyCachingProvider _provider;
public ValuesController(IEasyCachingProvider provider)
{
this._provider = provider;
}
[HttpGet]
public string Get()
{
//Remove
_provider.Remove("demo");
//Set
_provider.Set("demo", "123", TimeSpan.FromMinutes(1));
//others ...
}
}
4. Redis Feature Provider
Redis has many other data types, such as Hash, List .etc.
EasyCaching.CSRedis also support those types that named redis feature provider.
If you want to use this feature provider, just call IRedisCachingProvider
to replace IEasyCachingProvider
.
[Route("api/[controller]")]
public class ValuesController : Controller
{
private readonly IRedisCachingProvider _provider;
public ValuesController(IRedisCachingProvider provider)
{
this._provider = provider;
}
[HttpGet]
public string Get()
{
// HMSet
var res = _provider.HMSet(cacheKey, new Dictionary<string, string>
{
{"a1","v1"},{"a2","v2"}
});
//others ...
}
}