代码拉取完成,页面将自动刷新
同步操作将从 go-admin-team/go-admin-core 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
package cache
import (
"time"
"github.com/go-redis/redis/v7"
)
// NewRedis redis模式
func NewRedis(client *redis.Client, options *redis.Options) (*Redis, error) {
if client == nil {
client = redis.NewClient(options)
}
r := &Redis{
client: client,
}
err := r.connect()
if err != nil {
return nil, err
}
return r, nil
}
// Redis cache implement
type Redis struct {
client *redis.Client
}
func (*Redis) String() string {
return "redis"
}
// connect connect test
func (r *Redis) connect() error {
var err error
_, err = r.client.Ping().Result()
return err
}
// Get from key
func (r *Redis) Get(key string) (string, error) {
return r.client.Get(key).Result()
}
// Set value with key and expire time
func (r *Redis) Set(key string, val interface{}, expire int) error {
return r.client.Set(key, val, time.Duration(expire)*time.Second).Err()
}
// Del delete key in redis
func (r *Redis) Del(key string) error {
return r.client.Del(key).Err()
}
// HashGet from key
func (r *Redis) HashGet(hk, key string) (string, error) {
return r.client.HGet(hk, key).Result()
}
// HashDel delete key in specify redis's hashtable
func (r *Redis) HashDel(hk, key string) error {
return r.client.HDel(hk, key).Err()
}
// Increase
func (r *Redis) Increase(key string) error {
return r.client.Incr(key).Err()
}
func (r *Redis) Decrease(key string) error {
return r.client.Decr(key).Err()
}
// Set ttl
func (r *Redis) Expire(key string, dur time.Duration) error {
return r.client.Expire(key, dur).Err()
}
// GetClient 暴露原生client
func (r *Redis) GetClient() *redis.Client {
return r.client
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。