代码拉取完成,页面将自动刷新
package service
import (
"context"
"errors"
"gitee.com/up-zero/redis-desktop-client/internal/define"
"gitee.com/up-zero/redis-desktop-client/internal/helper"
"strconv"
"strings"
)
// DbList 数据库列表
func DbList(identity string) ([]*define.DbItem, error) {
if identity == "" {
return nil, errors.New("连接唯一标识不能为空")
}
rdb, err := helper.GetRedisClient(identity, 0)
if err != nil {
return nil, err
}
// info 获取数据库键的个数
keySpace, err := rdb.Info(context.Background(), "keyspace").Result()
if err != nil {
return nil, err
}
// keyspace 数据格式
// # Keyspace
// db0:keys=2,avg_ttl...
//
m := make(map[string]int)
v := strings.Split(keySpace, "\n")
for i := 1; i < len(v)-1; i++ {
databases := strings.Split(v[i], ":")
if len(databases) < 2 {
continue
}
vv := strings.Split(databases[1], ",")
if len(vv) < 1 {
continue
}
keyNumber := strings.Split(vv[0], "=")
if len(keyNumber) < 2 {
continue
}
num, err := strconv.Atoi(keyNumber[1])
if err != nil {
continue
}
m[databases[0]] = num
}
// config get 获取数据库的个数
databasesRes, err := rdb.ConfigGet(context.Background(), "databases").Result()
if err != nil {
return nil, err
}
if len(databasesRes) < 2 {
return nil, errors.New("连接数据异常")
}
dbNum, err := strconv.Atoi(databasesRes[1].(string))
if err != nil {
return nil, err
}
data := make([]*define.DbItem, 0)
for i := 0; i < dbNum; i++ {
item := &define.DbItem{
Key: "db" + strconv.Itoa(i),
}
if n, ok := m["db"+strconv.Itoa(i)]; ok {
item.Number = n
}
data = append(data, item)
}
return data, nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。