https://github.com/wodsonluiz/redis.easyconnectmultiservers
Package for ease integration with multiple servers Redis.
https://github.com/wodsonluiz/redis.easyconnectmultiservers
caching dotnet redis redis-client redis-clients stackexchange stackexchange-redis
Last synced: 6 months ago
JSON representation
Package for ease integration with multiple servers Redis.
- Host: GitHub
- URL: https://github.com/wodsonluiz/redis.easyconnectmultiservers
- Owner: wodsonluiz
- License: mit
- Created: 2023-05-09T12:59:29.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-10-25T06:25:52.000Z (8 months ago)
- Last Synced: 2024-12-15T22:13:13.955Z (6 months ago)
- Topics: caching, dotnet, redis, redis-client, redis-clients, stackexchange, stackexchange-redis
- Language: C#
- Homepage:
- Size: 99.6 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README-PTB.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# Redis.EasyConnectMultiServers


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```csharp
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
```csharp
public class WeatherForecastController
{
private readonly IRedisProviderMultiServers _redisProviderMultiServers;public WeatherForecastController(IRedisProviderMultiServers redisProviderMultiServers) =>
_redisProviderMultiServers = redisProviderMultiServers;
}
```#### Escrever/ Atualizar
- Vai escrever em todos os sevidores configurados.```csharp
await _redisProviderMultiServers.AddAsync(Guid.NewGuid().ToString(), "value");
``````csharp
await _redisProviderMultiServers.ReplaceAsync(Guid.NewGuid().ToString(), "value");
```- Vai escrever somente no servidor padrão: `IsDefault = true`
```csharp
await _redisProviderMultiServers.AddDefaultClientAsync(Guid.NewGuid().ToString(), "value");
``````csharp
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.```csharp
await _redisProviderMultiServers.GetMultiAsync(guid.ToString());
```#### Remover
- Vai remover em todos os servidores configurados
- Vai remover somente no cliente padrão: `IsDefault = true````csharp
await _redisProviderMultiServers.RemoveAsync(key);
``````csharp
await _redisProviderMultiServers.RemoveDefaultClientAsync(key);
```