config: Add redis-url
This commit is contained in:
parent
054c163ffb
commit
53bd3b4e58
4 changed files with 25 additions and 6 deletions
|
@ -106,6 +106,8 @@ cache {
|
|||
cleanup-interval 1h
|
||||
|
||||
# Redis cache settings
|
||||
# URL to connect to redis (default: redis://localhost:6379)
|
||||
redis-url redis://user:password@localhost:6789/3
|
||||
}
|
||||
```
|
||||
|
||||
|
|
20
config.go
20
config.go
|
@ -56,9 +56,13 @@ type labelConfig struct {
|
|||
}
|
||||
|
||||
type cacheConfig struct {
|
||||
// shared settings
|
||||
Type cacheType
|
||||
CleanupInterval time.Duration
|
||||
Duration time.Duration
|
||||
// memory settings
|
||||
CleanupInterval time.Duration
|
||||
// redis settings
|
||||
RedisURL string
|
||||
}
|
||||
|
||||
type alertmanagerConfig struct {
|
||||
|
@ -86,8 +90,11 @@ func readConfig(path string) (*config, error) {
|
|||
config.alertMode = single
|
||||
|
||||
config.cache.Type = memory
|
||||
config.cache.CleanupInterval = time.Hour
|
||||
config.cache.Duration = time.Hour * 24
|
||||
// memory
|
||||
config.cache.CleanupInterval = time.Hour
|
||||
// redis
|
||||
config.cache.RedisURL = "redis://localhost:6379"
|
||||
|
||||
d := cfg.Get("log-level")
|
||||
if d != nil {
|
||||
|
@ -279,6 +286,7 @@ func readConfig(path string) (*config, error) {
|
|||
config.cache.Duration = duration
|
||||
}
|
||||
|
||||
// memory
|
||||
var cleanupIntervalString string
|
||||
d = cacheDir.Children.Get("cleanup-interval")
|
||||
if d != nil {
|
||||
|
@ -293,6 +301,14 @@ func readConfig(path string) (*config, error) {
|
|||
|
||||
config.cache.CleanupInterval = interval
|
||||
}
|
||||
|
||||
// redis
|
||||
d = cacheDir.Children.Get("redis-url")
|
||||
if d != nil {
|
||||
if err := d.ParseParams(&config.cache.RedisURL); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
amDir := cfg.Get("alertmanager")
|
||||
|
|
|
@ -56,6 +56,7 @@ alertmanager {
|
|||
cache {
|
||||
type redis
|
||||
duration 48h
|
||||
redis-url redis://user:password@localhost:6789/3
|
||||
}
|
||||
`
|
||||
|
||||
|
@ -76,8 +77,9 @@ cache {
|
|||
},
|
||||
cache: cacheConfig{
|
||||
Type: redis,
|
||||
CleanupInterval: time.Hour,
|
||||
Duration: 48 * time.Hour,
|
||||
CleanupInterval: time.Hour,
|
||||
RedisURL: "redis://user:password@localhost:6789/3",
|
||||
},
|
||||
am: alertmanagerConfig{
|
||||
SilenceDuration: time.Hour * 24,
|
||||
|
|
3
main.go
3
main.go
|
@ -407,8 +407,7 @@ func main() {
|
|||
c = cache.NewMemoryCache(cfg.cache.Duration)
|
||||
case redis:
|
||||
var err error
|
||||
// TODO: Read URL from config
|
||||
c, err = cache.NewRedisCache("redis://localhost:6379", cfg.cache.Duration)
|
||||
c, err = cache.NewRedisCache(cfg.cache.RedisURL, cfg.cache.Duration)
|
||||
if err != nil {
|
||||
logger.Fatalf("Failed to create redis cache: %v", err)
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue