Skip to content

Latest commit

 

History

History
94 lines (75 loc) · 2.79 KB

README-PTB.md

File metadata and controls

94 lines (75 loc) · 2.79 KB

Redis.EasyConnectMultiServers

Nuget GitHub Workflow Status Nuget

Biblioteca para facilitar a integração com multiplos servidores do Redis, assim sendo fácil realizar todas as operações de crud.

Configuração

  • AddRedisProviderMultiServers: Injeta uma instância singleton de IRedisProviderMultiServers.
  • IRedisProviderMultiServers Abstração responsável por fornecer contratos que realiza as operações de CRUD em multiplos servidores
var configurations = new[]
{
    new RedisConfiguration
    {
        AbortOnConnectFail = true,
        KeyPrefix = "MyPrefix__",
        Hosts = new[] { new RedisHost { Host = "localhost", Port = 6379 } },
        AllowAdmin = true,
        ConnectTimeout = 5000,
        Database = 0,
        PoolSize = 5,
        IsDefault = true
    },
    new RedisConfiguration
    {
        AbortOnConnectFail = true,
        KeyPrefix = "MyPrefix__",
        Hosts = new[] { new RedisHost { Host = "localhost", Port = 6389 } },
        AllowAdmin = true,
        ConnectTimeout = 5000,
        Database = 0,
        PoolSize = 2,
        Name = "Secndary Instance"
    }
};

services.AddRedisProviderMultiServers(configurations);

Exemplo de uso

public class WeatherForecastController
{
    private readonly IRedisProviderMultiServers _redisProviderMultiServers;

    public WeatherForecastController(IRedisProviderMultiServers redisProviderMultiServers) =>
        _redisProviderMultiServers = redisProviderMultiServers;
}

Escrever/ Atualizar

  • Vai escrever em todos os sevidores configurados.
await _redisProviderMultiServers.AddAsync(Guid.NewGuid().ToString(), "value");
await _redisProviderMultiServers.ReplaceAsync(Guid.NewGuid().ToString(), "value");
  • Vai escrever somente no servidor padrão: IsDefault = true
await _redisProviderMultiServers.AddDefaultClientAsync(Guid.NewGuid().ToString(), "value");
await _redisProviderMultiServers.ReplaceDefaultClientAsync(Guid.NewGuid().ToString(), "value");

Consulta

  • A consulta é realizada a partir do client default: IsDefault = true.
  • O método responde assim que encontra a chave, não seguindo com a consulta nos demais servidores.
await _redisProviderMultiServers.GetMultiAsync<string>(guid.ToString());

Remover

  • Vai remover em todos os servidores configurados
  • Vai remover somente no cliente padrão: IsDefault = true
await _redisProviderMultiServers.RemoveAsync(key);
await _redisProviderMultiServers.RemoveDefaultClientAsync(key);