From 58eaaef0b31f77e7c2d18bc66e780aa042b11afb Mon Sep 17 00:00:00 2001 From: Piotr Biernat Date: Sun, 25 Jul 2021 01:02:35 +0200 Subject: [PATCH] [refactor] Simplified selecting cache datasource and fail-safe mechanism --- pkg/cache/cache.go | 39 +++++++++++++++++++++++++++++++++++++++ pkg/config/config.go | 12 ++++++++++++ pkg/main.go | 6 ++---- pkg/server/server.go | 20 +++++--------------- vegvisir.json.dist | 10 ++++++++++ 5 files changed, 68 insertions(+), 19 deletions(-) create mode 100644 pkg/cache/cache.go diff --git a/pkg/cache/cache.go b/pkg/cache/cache.go new file mode 100644 index 0000000..9296fb3 --- /dev/null +++ b/pkg/cache/cache.go @@ -0,0 +1,39 @@ +// ___ ____ ___ ___ +// \ \ / / | _ | __| \ \ / / || | __ || || _ | +// \ \/ / |___ | |__ \ \/ / || |___ || ||___| +// \ / | _ | _ | \ / || __ | || ||\\ +// \/ |___ |___ | \/ || ____| || || \\ +// +// Copyright (c) 2021 Piotr Biernat. https://pbiernat.dev. MIT License +// Repo: https://git.pbiernat.dev/golang/vegvisir + +package cache + +import ( + "log" + "vegvisir/pkg/config" +) + +const ( + TYPE_REDIS = "redis" + TYPE_MEMORY = "memory" +) + +func GetCacheDatastore(config config.Cache) *CacheDatastore { + var datastore CacheDatastore + + if config.Type == TYPE_REDIS { + datastore = NewRedisDatastore(config.Host, config.Port) + } else { + datastore = NewMemoryDatastore() + } + + //fail-safe switch to memory datasource + if !datastore.IsConnected() { + log.Println("Cache server is not responding, switching to memory cache.") + + datastore = NewMemoryDatastore() + } + + return &datastore +} diff --git a/pkg/config/config.go b/pkg/config/config.go index 23b6fff..b322d9f 100644 --- a/pkg/config/config.go +++ b/pkg/config/config.go @@ -17,6 +17,7 @@ import ( type Config struct { Server Server + Cache Cache Backends map[string]Backend confPath string @@ -27,6 +28,17 @@ type Server struct { Port int } +type Cache struct { + Type string + Host string + Port int + Username string + Password string + Database string + RouteTtl int + ResponseTtl int +} + type Backend struct { PrefixUrl string BackendAddress string diff --git a/pkg/main.go b/pkg/main.go index 27e15bf..3d4ee7f 100644 --- a/pkg/main.go +++ b/pkg/main.go @@ -19,15 +19,13 @@ import ( ) var ( - cFile = flag.String("c", "vegvisir.json", "Path to config file") - + cPath = flag.String("c", "vegvisir.json", "Path to config file") // for profiling... cpuprofile = flag.String("cpuprofile", "", "write cpu profile to `file`") memprofile = flag.String("memprofile", "", "write memory profile to `file`") ) func main() { - flag.Parse() // cpu profiling if *cpuprofile != "" { @@ -42,7 +40,7 @@ func main() { defer pprof.StopCPUProfile() } - server.NewServer(*cFile).Run() + server.NewServer(*cPath).Run() // memory profiling if *memprofile != "" { diff --git a/pkg/server/server.go b/pkg/server/server.go index 31790d8..826434e 100644 --- a/pkg/server/server.go +++ b/pkg/server/server.go @@ -40,23 +40,13 @@ func NewServer(cPath string) *Server { log.Fatalln("Unable to find config file: ", cPath, err) } - server := &Server{ + datastore := cache.GetCacheDatastore(config.Cache) + + return &Server{ config: config, + router: NewRouter(config, *datastore, config.Cache.RouteTtl), + respCM: cache.NewResponseCacheManager(*datastore, config.Cache.ResponseTtl), } - - redisDS := cache.NewRedisDatastore("127.0.0.1", 6379) // FIXME use config or env... - if !redisDS.IsConnected() { - log.Println("Redis server not responding, switching to memory cache...") - - memDS := cache.NewMemoryDatastore() - server.router = NewRouter(config, memDS, 30) //FIXME for memory datasource ttl is useles right now... - server.respCM = cache.NewResponseCacheManager(memDS, 30) //FIXME for memory datasource ttl is useles right now... - } else { - server.router = NewRouter(config, redisDS, 30) //FIXME use ttl(seconds) from config or env... - server.respCM = cache.NewResponseCacheManager(redisDS, 30) //FIXME use ttl(seconds) from config or env... - } - - return server } func (s *Server) Run() { diff --git a/vegvisir.json.dist b/vegvisir.json.dist index 8394cc5..c98251b 100644 --- a/vegvisir.json.dist +++ b/vegvisir.json.dist @@ -29,5 +29,15 @@ "target": "article-global/$1" }] } + }, + "cache": { + "type": "redis", + "host": "localhost", + "port": 6379, + "username": "", + "password": "", + "database": "0", + "routeTtl": 300, + "responseTtl": 300 } } \ No newline at end of file