1 Star 0 Fork 0

go-spring2/spring-base

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
cache.go 2.55 KB
一键复制 编辑 原始数据 按行查看 历史
kzhu 提交于 27天前 . first commit
/*
* Copyright 2012-2019 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
// Package cache provides object caching in memory.
package cache
import (
"context"
"sync"
"time"
)
var (
Cache Shardable
Engine Driver
)
func init() {
Cache = NewStorage(1, SimpleHash)
Engine = &engine{}
}
// A Shardable cache can improve the performance of concurrency.
type Shardable interface {
Sharding(key string) *sync.Map
}
type LoadType int
const (
LoadNone LoadType = iota
LoadOnCtx
LoadCache
LoadSource
)
// ResultLoader returns a wrapper for the source value of the key.
type ResultLoader func(ctx context.Context, key string) (Result, error)
// Driver loads value from m, if there is no cached value, call the loader
// to get value, and then stores it into m.
type Driver interface {
Load(ctx context.Context, m *sync.Map, key string, loader ResultLoader, arg OptionArg) (loadType LoadType, result Result, err error)
}
// Has returns whether the key exists.
func Has(key string) bool {
v, ok := Cache.Sharding(key).Load(key)
if ok && v != nil {
return !v.(*cacheItem).expired()
}
return false
}
type OptionArg struct {
ExpireAfterWrite time.Duration
}
type Option func(*OptionArg)
// ExpireAfterWrite sets the expiration time of the cache value after write.
func ExpireAfterWrite(v time.Duration) Option {
return func(arg *OptionArg) {
arg.ExpireAfterWrite = v
}
}
// Loader gets value from a background, such as Redis, MySQL, etc.
type Loader func(ctx context.Context, key string) (interface{}, error)
// Load loads value from cache, if there is no cached value, call the loader
// to get value, and then stores it.
func Load(ctx context.Context, key string, loader Loader, opts ...Option) (loadType LoadType, result Result, _ error) {
arg := OptionArg{}
for _, opt := range opts {
opt(&arg)
}
l := func(ctx context.Context, key string) (Result, error) {
v, err := loader(ctx, key)
if err != nil {
return nil, err
}
return NewValueResult(v), nil
}
m := Cache.Sharding(key)
return Engine.Load(ctx, m, key, l, arg)
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/go-spring2/spring-base.git
git@gitee.com:go-spring2/spring-base.git
go-spring2
spring-base
spring-base
v1.1.3

搜索帮助