1 Star 0 Fork 0

exlimit / tegola

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
redis.go 2.41 KB
一键复制 编辑 原始数据 按行查看 历史
package redis
import (
"fmt"
"time"
"github.com/go-redis/redis"
"github.com/go-spatial/tegola"
"github.com/go-spatial/tegola/cache"
"github.com/go-spatial/tegola/dict"
)
const CacheType = "redis"
const (
ConfigKeyNetwork = "network"
ConfigKeyAddress = "address"
ConfigKeyPassword = "password"
ConfigKeyDB = "db"
ConfigKeyMaxZoom = "max_zoom"
ConfigKeyTTL = "ttl"
)
func init() {
cache.Register(CacheType, New)
}
func New(config dict.Dicter) (rcache cache.Interface, err error) {
// default values
defaultNetwork := "tcp"
defaultAddress := "127.0.0.1:6379"
defaultPassword := ""
defaultDB := 0
defaultMaxZoom := uint(tegola.MaxZ)
defaultTTL := 0
c := config
network, err := c.String(ConfigKeyNetwork, &defaultNetwork)
if err != nil {
return nil, err
}
addr, err := c.String(ConfigKeyAddress, &defaultAddress)
if err != nil {
return nil, err
}
password, err := c.String(ConfigKeyPassword, &defaultPassword)
if err != nil {
return nil, err
}
db, err := c.Int(ConfigKeyDB, &defaultDB)
if err != nil {
return nil, err
}
client := redis.NewClient(&redis.Options{
Network: network,
Addr: addr,
Password: password,
DB: db,
PoolSize: 2,
DialTimeout: 3 * time.Second,
})
pong, err := client.Ping().Result()
if err != nil {
return nil, err
}
if pong != "PONG" {
return nil, fmt.Errorf("redis did not respond with 'PONG', '%s'", pong)
}
// the config map's underlying value is int
maxZoom, err := c.Uint(ConfigKeyMaxZoom, &defaultMaxZoom)
if err != nil {
return nil, err
}
ttl, err := c.Int(ConfigKeyTTL, &defaultTTL)
if err != nil {
return nil, err
}
return &RedisCache{
Redis: client,
MaxZoom: maxZoom,
Expiration: time.Duration(ttl) * time.Second,
}, nil
}
type RedisCache struct {
Redis *redis.Client
Expiration time.Duration
MaxZoom uint
}
func (rdc *RedisCache) Set(key *cache.Key, val []byte) error {
if key.Z > rdc.MaxZoom {
return nil
}
return rdc.Redis.
Set(key.String(), val, rdc.Expiration).
Err()
}
func (rdc *RedisCache) Get(key *cache.Key) (val []byte, hit bool, err error) {
val, err = rdc.Redis.Get(key.String()).Bytes()
switch err {
case nil: // cache hit
return val, true, nil
case redis.Nil: // cache miss
return val, false, nil
default: // error
return val, false, err
}
}
func (rdc *RedisCache) Purge(key *cache.Key) (err error) {
return rdc.Redis.Del(key.String()).Err()
}
1
https://gitee.com/exlimit/tegola.git
git@gitee.com:exlimit/tegola.git
exlimit
tegola
tegola
v0.10.4

搜索帮助