Tutti i Client Manager Redis implementano entrambi IRedisClientsManager
e IRedisClientsManagerAsync
quindi le registrazioni IOC rimangono le stesse che possono continuare a registrarsi contro l'esistente IRedisClientsManager
interfaccia, ad esempio:
container.Register<IRedisClientsManager>(c =>
new RedisManagerPool(redisConnectionString));
Dove può essere utilizzato per risolvere sia IRedisClient
di sincronizzazione e asincrono IRedisClientAsync
clienti, ad esempio:
using var syncRedis = container.Resolve<IRedisClientsManager>().GetClient();
await using var asyncRedis = await container.Resolve<IRedisClientsManager>().GetClientAsync();
Se vuoi forzare l'utilizzo dell'API solo asincrona, puoi scegliere di registrare semplicemente IRedisClientsManagerAsync
dove ti consente solo di risolvere solo asincroni IRedisClientAsync
e ICacheClientAsync
clienti, ad esempio:
public void ConfigureServices(IServiceCollection services)
{
services.AddSingleton<IRedisClientsManagerAsync>(c => new RedisManagerPool());
}
//...
public class MyDep
{
private IRedisClientsManagerAsync manager;
public MyDep(IRedisClientsManagerAsync manager) => this.manager = manager;
public async Task<long> Incr(string key, uint value)
{
await using var redis = await manager.GetClientAsync();
return await redis.IncrementAsync(key, value);
}
}
Utilizzo in ServiceStack #
All'interno di ServiceStack Services &Controllers consigliamo di utilizzare GetRedisAsync()
per risolvere un IRedisClientAsync
:
public class MyService : Service
{
public async Task<object> Any(MyRequest request)
{
await using var redis = await GetRedisAsync();
await redis.IncrementAsync(nameof(MyRequest), 1);
}
}
public class HomeController : ServiceStackController
{
public async Task<ActionResult> Index()
{
await using var redis = await GetRedisAsync();
await redis.IncrementAsync(nameof(HomeController), 1);
}
}