gf/os/gfile/gfile_cache.go

67 lines
2.0 KiB
Go
Raw Normal View History

// Copyright 2017-2018 gf Author(https://github.com/gogf/gf). All Rights Reserved.
2018-08-21 21:18:56 +08:00
//
// This Source Code Form is subject to the terms of the MIT License.
// If a copy of the MIT was not distributed with this file,
// You can obtain one at https://github.com/gogf/gf.
2018-08-21 21:18:56 +08:00
package gfile
2018-08-21 21:18:56 +08:00
import (
2019-07-29 21:01:19 +08:00
"github.com/gogf/gf/os/gcache"
"github.com/gogf/gf/os/gcmd"
2019-07-29 21:01:19 +08:00
"github.com/gogf/gf/os/gfsnotify"
"time"
2018-08-21 21:18:56 +08:00
)
const (
2019-06-19 09:06:52 +08:00
// Default expire time for file content caching in seconds.
gDEFAULT_CACHE_EXPIRE = time.Minute
2018-08-21 21:18:56 +08:00
)
var (
// Default expire time for file content caching.
cacheExpire = gcmd.GetWithEnv("gf.gfile.cache", gDEFAULT_CACHE_EXPIRE).Duration()
// internalCache is the memory cache for internal usage.
internalCache = gcache.New()
2018-08-21 21:18:56 +08:00
)
2019-06-11 20:57:43 +08:00
// GetContents returns string content of given file by <path> from cache.
// If there's no content in the cache, it will read it from disk file specified by <path>.
// The parameter <expire> specifies the caching time for this file content in seconds.
func GetContentsWithCache(path string, duration ...time.Duration) string {
return string(GetBytesWithCache(path, duration...))
2018-08-21 21:18:56 +08:00
}
2019-06-11 20:57:43 +08:00
// GetBinContents returns []byte content of given file by <path> from cache.
// If there's no content in the cache, it will read it from disk file specified by <path>.
// The parameter <expire> specifies the caching time for this file content in seconds.
func GetBytesWithCache(path string, duration ...time.Duration) []byte {
key := cacheKey(path)
expire := cacheExpire
if len(duration) > 0 {
expire = duration[0]
2019-06-19 09:06:52 +08:00
}
r, _ := internalCache.GetOrSetFuncLock(key, func() (interface{}, error) {
b := GetBytes(path)
2019-06-19 09:06:52 +08:00
if b != nil {
// Adding this <path> to gfsnotify,
// it will clear its cache if there's any changes of the file.
_, _ = gfsnotify.Add(path, func(event *gfsnotify.Event) {
internalCache.Remove(key)
2019-06-19 09:06:52 +08:00
gfsnotify.Exit()
})
}
return b, nil
}, expire)
2019-06-19 09:06:52 +08:00
if r != nil {
return r.([]byte)
}
return nil
2018-08-21 21:18:56 +08:00
}
// cacheKey produces the cache key for gcache.
2019-03-14 23:28:56 +08:00
func cacheKey(path string) string {
2020-07-18 08:32:35 +08:00
return "gf.gfile.cache:" + path
2019-06-19 09:06:52 +08:00
}