Merge branch 'develop-memo-cache' of git.pbiernat.dev:golang/vegvisir into develop-memo-cache
All checks were successful
continuous-integration/drone/push Build is passing

This commit is contained in:
Piotr Biernat 2021-11-20 15:28:20 +01:00
commit 51f6cf8569
15 changed files with 76 additions and 63 deletions

View File

@ -4,31 +4,32 @@ name: default
steps:
- name: static_check
image: golang:1.16
image: golang:1.17
commands:
- go get honnef.co/go/tools/cmd/staticcheck
- staticcheck ./pkg/...
- go install honnef.co/go/tools/cmd/staticcheck@latest
- staticcheck -checks all ./pkg/...
volumes:
- name: gopath
- name: env_cache
path: /go
- name: lint
image: golang:1.16
image: golang:1.17
commands:
- go get golang.org/x/lint/golint
- go install golang.org/x/lint/golint@latest
- golint -set_exit_status ./pkg/...
volumes:
- name: gopath
- name: env_cache
path: /go
- name: vet
image: golang:1.16
image: golang:1.17
commands:
- go vet ./pkg/...
volumes:
- name: gopath
- name: env_cache
path: /go
volumes:
- name: gopath
temp: {}
- name: env_cache
host:
path: /tmp/drone/envs/vegvisir

5
.gitignore vendored
View File

@ -1,3 +1,6 @@
.idea
vegvisir.json
*.prof
.idea
*.local*

2
go.mod
View File

@ -1,4 +1,4 @@
module vegvisir
module git.pbiernat.dev/golang/vegvisir
go 1.17

3
pkg/cache/cache.go vendored
View File

@ -7,11 +7,12 @@
// Copyright (c) 2021 Piotr Biernat. https://pbiernat.dev. MIT License
// Repo: https://git.pbiernat.dev/golang/vegvisir
// Package cache whole cache functionality
package cache
import (
"git.pbiernat.dev/golang/vegvisir/pkg/config"
"log"
"vegvisir/pkg/config"
)
const (

22
pkg/cache/manager.go vendored
View File

@ -27,6 +27,7 @@ import (
"time"
)
// Manager main struct
type Manager struct {
sync.RWMutex
datastore Datastore
@ -46,7 +47,8 @@ type entry struct {
ready chan struct{} // closed when res is ready
}
type HandlerFunc func(url, method string, route *RouteCache) (error, *ResponseCache)
// HandlerFunc non-blocking cache handler func signature definition
type HandlerFunc func(url, method string, route *RouteCache) (*ResponseCache, error)
type queue struct {
items chan queueItem
@ -64,9 +66,10 @@ type queueItem struct {
//var reqsSend = 0
func NewCachedManager(datastore Datastore, prefix string, ttl int, handler HandlerFunc) Manager {
// NewCachedManager Creates instance of non-blocking cache manager
func NewCachedManager(datastore Datastore, prefix string, ttl int, handler HandlerFunc) *Manager {
//log.Printf("Create DS: %s %d", prefix, ttl)
m := Manager{
m := &Manager{
datastore: datastore,
prefix: prefix,
ttl: ttl,
@ -78,7 +81,8 @@ func NewCachedManager(datastore Datastore, prefix string, ttl int, handler Handl
return m
}
func HttpRequestHandler(url, method string, route *RouteCache) (error, *ResponseCache) { // FIXME: Refactor|Move to handler/
// HTTPRequestHandler HTTP Handler for non-blocking cache reads
func HTTPRequestHandler(url, method string, route *RouteCache) (*ResponseCache, error) { // FIXME: Refactor|Move to handler/
//start := time.Now()
bckReq := fasthttp.AcquireRequest()
bckResp := fasthttp.AcquireResponse()
@ -91,7 +95,7 @@ func HttpRequestHandler(url, method string, route *RouteCache) (error, *Response
err := fasthttp.Do(bckReq, bckResp)
if err != nil {
return err, nil
return nil, err
}
body, code := string(bckResp.Body()), bckResp.StatusCode()
@ -101,11 +105,12 @@ func HttpRequestHandler(url, method string, route *RouteCache) (error, *Response
// ^^ FIXME: rename NewResponseCache(with all depend struct) and move to handler/ (without dependencies)
//reqsSend++
log.Println(time.Now().Nanosecond(), "HttpRequestHandler() done:", route.TargetURL, url)
log.Println(time.Now().Nanosecond(), "HTTPRequestHandler() done:", route.TargetURL, url)
return nil, respCache
return respCache, nil
}
// Fetch Non-blocking cache response read
// FIXME: #68 - refactor
func (m *Manager) Fetch(url, method string, route *RouteCache) (*ResponseCache, error) {
//log.Println("Response CM: Fetch()")
@ -116,6 +121,7 @@ func (m *Manager) Fetch(url, method string, route *RouteCache) (*ResponseCache,
return res.body, res.err
}
// Close exec while server shutting down
func (m *Manager) Close() {
close(m.queue.items)
}
@ -188,7 +194,7 @@ func (m *Manager) server(handler HandlerFunc) {
func (m *Manager) call(e *entry, f HandlerFunc, url, method string, route *RouteCache) {
e.res.name = method + "_" + url // FIXME: hardcoded key pattern
m.RLock()
e.res.err, e.res.body = f(url, method, route)
e.res.body, e.res.err = f(url, method, route)
m.save(e.res.name, e.res.body)
m.RUnlock()

View File

@ -10,12 +10,11 @@
package cache
import (
"github.com/go-redis/redis"
"log"
"os"
"strconv"
"time"
"github.com/go-redis/redis"
)
// NewRedisDatastore function

View File

@ -23,6 +23,7 @@ type ResponseCache struct {
Headers *fasthttp.ResponseHeader
}
// NewResponseCache Creates new ResponseCache structure
func NewResponseCache(url, method, body string, code int, headers *fasthttp.ResponseHeader) *ResponseCache {
return &ResponseCache{url, method, body, code, headers}
}

2
pkg/cache/route.go vendored
View File

@ -9,11 +9,13 @@
package cache
// RouteCache struct corresponding route cache item
type RouteCache struct {
SourceURL string
TargetURL string
}
// NewRouteCache Creates new router instance
func NewRouteCache(source, target string) *RouteCache {
return &RouteCache{
SourceURL: source,

View File

@ -7,6 +7,7 @@
// Copyright (c) 2021 Piotr Biernat. https://pbiernat.dev. MIT License
// Repo: https://git.pbiernat.dev/golang/vegvisir
// Package client all available clients lives here (httpo, https, grpc etc.)
package client
import "github.com/valyala/fasthttp"

View File

@ -7,6 +7,7 @@
// Copyright (c) 2021 Piotr Biernat. https://pbiernat.dev. MIT License
// Repo: https://git.pbiernat.dev/golang/vegvisir
// Package config main config file structs
package config
import (

View File

@ -7,4 +7,5 @@
// Copyright (c) 2021 Piotr Biernat. https://pbiernat.dev. MIT License
// Repo: https://git.pbiernat.dev/golang/vegvisir
// Package handler all handlers will be placed here in future...
package handler

View File

@ -11,14 +11,14 @@ package main
import (
"flag"
"git.pbiernat.dev/golang/vegvisir/pkg/server"
"log"
"net/http"
_ "net/http/pprof"
"os"
"runtime"
"runtime/pprof"
"vegvisir/pkg/server"
)
import _ "net/http/pprof"
var (
cPath = flag.String("c", "vegvisir.json", "Path to config file")

View File

@ -12,27 +12,24 @@ package server
import (
"fmt"
"git.pbiernat.dev/golang/vegvisir/pkg/cache"
"git.pbiernat.dev/golang/vegvisir/pkg/config"
"log"
"regexp"
"strings"
"vegvisir/pkg/cache"
"vegvisir/pkg/config"
)
// Router struct
type Router struct {
config *config.Config
//cache map[string]cache.RouteCache
cache *cache.MemoryDatastore
//cache *cache.RedisDatastore
}
// NewRouter function
func NewRouter(config *config.Config, ds cache.Datastore, ttl int) *Router {
func NewRouter(config *config.Config, ds *cache.MemoryDatastore, ttl int) *Router {
return &Router{
config: config,
//cache: make(map[string]cache.RouteCache),
cache: cache.NewMemoryDatastore(),
cache: ds,
//cache: cache.NewRedisDatastore(config.Cache.Host, config.Cache.Password, config.Cache.Database, config.Cache.Port),
}
}

View File

@ -7,20 +7,20 @@
// Copyright (c) 2021 Piotr Biernat. https://pbiernat.dev. MIT License
// Repo: https://git.pbiernat.dev/golang/vegvisir
// Package server contains main sever files
package server
import (
"context"
"fmt"
"git.pbiernat.dev/golang/vegvisir/pkg/cache"
"git.pbiernat.dev/golang/vegvisir/pkg/config"
"github.com/valyala/fasthttp"
"log"
"os"
"os/signal"
"syscall"
"time"
"vegvisir/pkg/cache"
"vegvisir/pkg/config"
"github.com/valyala/fasthttp"
)
const (
@ -34,7 +34,7 @@ const (
type Server struct {
config *config.Config
router *Router
respCM cache.Manager
respCM *cache.Manager
daemon *fasthttp.Server
}
@ -52,7 +52,7 @@ func NewServer(cPath string) *Server {
config: cfg,
router: NewRouter(cfg, cache.NewMemoryDatastore(), cfg.Cache.RouteTTL),
// ^^ INFO: Routes always use memoryCache cause low size and fast read time (optimalization)
respCM: cache.NewCachedManager(*datastore, "response_", cfg.Cache.ResponseTTL, cache.HttpRequestHandler),
respCM: cache.NewCachedManager(*datastore, "response_", cfg.Cache.ResponseTTL, cache.HTTPRequestHandler),
// ^^ FIXME: add handler detection option by config etc...
}
}