Redis
 sql >> Datenbank >  >> NoSQL >> Redis

Redis Async-APIs

Alle Redis-Client-Manager implementieren beide IRedisClientsManager und IRedisClientsManagerAsync Daher bleiben die IOC-Registrierungen gleich, die sich weiterhin für den vorhandenen IRedisClientsManager registrieren können Schnittstelle, z. B.:

container.Register<IRedisClientsManager>(c => 
    new RedisManagerPool(redisConnectionString));

Wo es verwendet werden kann, um sowohl IRedisClient zu synchronisieren und asynchron IRedisClientAsync Kunden, z. B.:

using var syncRedis = container.Resolve<IRedisClientsManager>().GetClient();
await using var asyncRedis = await container.Resolve<IRedisClientsManager>().GetClientAsync();

Wenn Sie nur asynchrone API-Nutzung erzwingen möchten, können Sie einfach IRedisClientsManagerAsync registrieren wo es nur erlaubt, async only IRedisClientAsync aufzulösen und ICacheClientAsync Kunden, z. B.:

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);
    }
}

Verwendung in ServiceStack #

Innerhalb von ServiceStack Services &Controllers empfehlen wir die Verwendung von GetRedisAsync() um ein IRedisClientAsync aufzulösen :

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);
    }
}