Files
x_admin/server/util/redis.go
2025-07-27 15:17:38 +08:00

215 lines
5.6 KiB
Go

package util
import (
"bufio"
"context"
"strings"
"time"
"x_admin/config"
"x_admin/core"
"github.com/redis/go-redis/v9"
)
var RedisUtil = redisUtil{redis: core.Redis}
// redisUtil Redis操作工具类
type redisUtil struct {
redis *redis.Client
}
// stringToLines string拆分多行
func stringToLines(s string) (lines []string, err error) {
scanner := bufio.NewScanner(strings.NewReader(s))
for scanner.Scan() {
lines = append(lines, scanner.Text())
}
err = scanner.Err()
return
}
// stringToKV string拆分key和val
func stringToKV(s string) (string, string) {
ss := strings.Split(s, ":")
if len(ss) < 2 {
return s, ""
}
return ss[0], ss[1]
}
// Info Redis服务信息
func (ru redisUtil) Info(sections ...string) (res map[string]string) {
infoStr, err := ru.redis.Info(context.Background(), sections...).Result()
res = map[string]string{}
if err != nil {
core.Logger.Errorf("redisUtil.Info err: err=[%+v]", err)
return res
}
// string拆分多行
lines, err := stringToLines(infoStr)
if err != nil {
core.Logger.Errorf("stringToLines err: err=[%+v]", err)
return res
}
// 解析成Map
for i := 0; i < len(lines); i++ {
if lines[i] == "" || strings.HasPrefix(lines[i], "# ") {
continue
}
k, v := stringToKV(lines[i])
res[k] = v
}
return res
}
// DBSize 当前数据库key数量
func (ru redisUtil) DBSize() int64 {
size, err := ru.redis.DBSize(context.Background()).Result()
if err != nil {
core.Logger.Errorf("redisUtil.DBSize err: err=[%+v]", err)
return 0
}
return size
}
// Set 设置键值对
func (ru redisUtil) Set(key string, value interface{}, timeSec int) bool {
err := ru.redis.Set(context.Background(),
config.RedisConfig.RedisPrefix+key, value, time.Duration(timeSec)*time.Second).Err()
if err != nil {
core.Logger.Errorf("redisUtil.Set err: err=[%+v]", err)
return false
}
return true
}
// Get 获取key的值
func (ru redisUtil) Get(key string) string {
res, err := ru.redis.Get(context.Background(), config.RedisConfig.RedisPrefix+key).Result()
if err != nil {
core.Logger.Errorf("redisUtil.Get err: err=[%+v]", err)
return ""
}
return res
}
// SSet 将数据放入set缓存
func (ru redisUtil) SSet(key string, values ...interface{}) bool {
err := ru.redis.SAdd(context.Background(), config.RedisConfig.RedisPrefix+key, values...).Err()
if err != nil {
core.Logger.Errorf("redisUtil.SSet err: err=[%+v]", err)
return false
}
return true
}
// SGet 根据key获取Set中的所有值
func (ru redisUtil) SGet(key string) []string {
res, err := ru.redis.SMembers(context.Background(), config.RedisConfig.RedisPrefix+key).Result()
if err != nil {
core.Logger.Errorf("redisUtil.SGet err: err=[%+v]", err)
return []string{}
}
return res
}
// HMSet 设置key, 通过字典的方式设置多个field, value对
func (ru redisUtil) HMSet(key string, mapping map[string]string, timeSec int) bool {
err := ru.redis.HSet(context.Background(), config.RedisConfig.RedisPrefix+key, mapping).Err()
if err != nil {
core.Logger.Errorf("redisUtil.HMSet err: err=[%+v]", err)
return false
}
if timeSec > 0 {
if !ru.Expire(key, timeSec) {
return false
}
}
return true
}
// HSet 向hash表中放入数据,如果不存在将创建
func (ru redisUtil) HSet(key string, field string, value string, timeSec int) bool {
return ru.HMSet(key, map[string]string{field: value}, timeSec)
}
// HGet 获取key中field域的值
func (ru redisUtil) HGet(key string, field string) string {
res, err := ru.redis.HGet(context.Background(), config.RedisConfig.RedisPrefix+key, field).Result()
if err != nil {
core.Logger.Errorf("redisUtil.HGet err: err=[%+v]", err)
return ""
}
return res
}
// HExists 判断key中有没有field域名
func (ru redisUtil) HExists(key string, field string) bool {
res, err := ru.redis.HExists(context.Background(), config.RedisConfig.RedisPrefix+key, field).Result()
if err != nil {
core.Logger.Errorf("redisUtil.HExists err: err=[%+v]", err)
return false
}
return res
}
// HDel 删除hash表中的值
func (ru redisUtil) HDel(key string, fields ...string) bool {
err := ru.redis.HDel(context.Background(), config.RedisConfig.RedisPrefix+key, fields...).Err()
if err != nil {
core.Logger.Errorf("redisUtil.HDel err: err=[%+v]", err)
return false
}
return true
}
// Exists 判断多项key是否存在
func (ru redisUtil) Exists(keys ...string) int64 {
fullKeys := ru.toFullKeys(keys)
cnt, err := ru.redis.Exists(context.Background(), fullKeys...).Result()
if err != nil {
core.Logger.Errorf("redisUtil.Exists err: err=[%+v]", err)
return -1
}
return cnt
}
// Expire 指定缓存失效时间
func (ru redisUtil) Expire(key string, timeSec int) bool {
err := ru.redis.Expire(context.Background(), config.RedisConfig.RedisPrefix+key, time.Duration(timeSec)*time.Second).Err()
if err != nil {
core.Logger.Errorf("redisUtil.Expire err: err=[%+v]", err)
return false
}
return true
}
// TTL 根据key获取过期时间
func (ru redisUtil) TTL(key string) int {
td, err := ru.redis.TTL(context.Background(), config.RedisConfig.RedisPrefix+key).Result()
if err != nil {
core.Logger.Errorf("redisUtil.TTL err: err=[%+v]", err)
return 0
}
return int(td / time.Second)
}
// Del 删除一个或多个键
func (ru redisUtil) Del(keys ...string) bool {
fullKeys := ru.toFullKeys(keys)
err := ru.redis.Del(context.Background(), fullKeys...).Err()
if err != nil {
core.Logger.Errorf("redisUtil.Del err: err=[%+v]", err)
return false
}
return true
}
// toFullKeys 为keys批量增加前缀
func (ru redisUtil) toFullKeys(keys []string) (fullKeys []string) {
for _, k := range keys {
fullKeys = append(fullKeys, config.RedisConfig.RedisPrefix+k)
}
return
}