2022-10-31 17:26:15 +08:00
|
|
|
package service
|
|
|
|
|
|
|
|
import (
|
2022-11-02 18:30:22 +08:00
|
|
|
"bufio"
|
2022-10-31 23:52:39 +08:00
|
|
|
"encoding/json"
|
2022-10-31 17:26:15 +08:00
|
|
|
"fmt"
|
2022-11-02 18:30:22 +08:00
|
|
|
"io"
|
|
|
|
"os"
|
2022-10-31 23:52:39 +08:00
|
|
|
"strings"
|
2022-10-31 17:26:15 +08:00
|
|
|
|
|
|
|
"github.com/1Panel-dev/1Panel/backend/app/dto"
|
|
|
|
"github.com/go-redis/redis"
|
|
|
|
_ "github.com/go-sql-driver/mysql"
|
|
|
|
)
|
|
|
|
|
|
|
|
type RedisService struct{}
|
|
|
|
|
|
|
|
type IRedisService interface {
|
2022-10-31 23:52:39 +08:00
|
|
|
UpdateConf(req dto.RedisConfUpdate) error
|
|
|
|
|
2022-11-02 16:28:54 +08:00
|
|
|
LoadStatus() (*dto.RedisStatus, error)
|
|
|
|
LoadConf() (*dto.RedisConf, error)
|
|
|
|
LoadPersistenceConf() (*dto.RedisPersistence, error)
|
2022-10-31 17:26:15 +08:00
|
|
|
|
|
|
|
// Backup(db dto.BackupDB) error
|
|
|
|
// Recover(db dto.RecoverDB) error
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewIRedisService() IRedisService {
|
|
|
|
return &RedisService{}
|
|
|
|
}
|
|
|
|
|
2022-11-02 16:28:54 +08:00
|
|
|
func newRedisClient() (*redis.Client, error) {
|
|
|
|
redisInfo, err := mysqlRepo.LoadRedisBaseInfo()
|
2022-10-31 17:26:15 +08:00
|
|
|
if err != nil {
|
2022-10-31 23:52:39 +08:00
|
|
|
return nil, err
|
2022-10-31 17:26:15 +08:00
|
|
|
}
|
|
|
|
client := redis.NewClient(&redis.Options{
|
|
|
|
Addr: fmt.Sprintf("localhost:%v", redisInfo.Port),
|
2022-11-02 16:28:54 +08:00
|
|
|
Password: redisInfo.Password,
|
|
|
|
DB: 0,
|
2022-10-31 17:26:15 +08:00
|
|
|
})
|
2022-10-31 23:52:39 +08:00
|
|
|
return client, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (u *RedisService) UpdateConf(req dto.RedisConfUpdate) error {
|
2022-11-02 18:30:22 +08:00
|
|
|
redisInfo, err := mysqlRepo.LoadRedisBaseInfo()
|
2022-10-31 23:52:39 +08:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2022-11-02 18:30:22 +08:00
|
|
|
file, err := os.OpenFile(fmt.Sprintf("/opt/1Panel/data/apps/redis/%s/conf/redis.conf", redisInfo.Name), os.O_RDWR, 0666)
|
|
|
|
if err != nil {
|
2022-10-31 23:52:39 +08:00
|
|
|
return err
|
|
|
|
}
|
2022-11-02 18:30:22 +08:00
|
|
|
defer file.Close()
|
2022-10-31 23:52:39 +08:00
|
|
|
|
2022-11-02 18:30:22 +08:00
|
|
|
reader := bufio.NewReader(file)
|
|
|
|
pos := int64(0)
|
|
|
|
for {
|
|
|
|
line, err := reader.ReadString('\n')
|
|
|
|
if err != nil {
|
|
|
|
if err == io.EOF {
|
|
|
|
break
|
|
|
|
} else {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if bytes := updateConfFile(line, "timeout", req.Timeout); len(bytes) != 0 {
|
|
|
|
_, _ = file.WriteAt(bytes, pos)
|
|
|
|
}
|
|
|
|
if bytes := updateConfFile(line, "maxclients", req.Maxclients); len(bytes) != 0 {
|
|
|
|
_, _ = file.WriteAt(bytes, pos)
|
|
|
|
}
|
|
|
|
if bytes := updateConfFile(line, "databases", req.Databases); len(bytes) != 0 {
|
|
|
|
_, _ = file.WriteAt(bytes, pos)
|
|
|
|
}
|
|
|
|
if bytes := updateConfFile(line, "requirepass", req.Requirepass); len(bytes) != 0 {
|
|
|
|
_, _ = file.WriteAt(bytes, pos)
|
|
|
|
}
|
|
|
|
if bytes := updateConfFile(line, "maxmemory", req.Maxmemory); len(bytes) != 0 {
|
|
|
|
_, _ = file.WriteAt(bytes, pos)
|
|
|
|
}
|
|
|
|
pos += int64(len(line))
|
|
|
|
}
|
2022-10-31 23:52:39 +08:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2022-11-02 16:28:54 +08:00
|
|
|
func (u *RedisService) LoadStatus() (*dto.RedisStatus, error) {
|
|
|
|
client, err := newRedisClient()
|
2022-10-31 23:52:39 +08:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
stdStr, err := client.Info().Result()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
rows := strings.Split(stdStr, "\r\n")
|
|
|
|
rowMap := make(map[string]string)
|
|
|
|
for _, v := range rows {
|
|
|
|
itemRow := strings.Split(v, ":")
|
|
|
|
if len(itemRow) == 2 {
|
|
|
|
rowMap[itemRow[0]] = itemRow[1]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
var info dto.RedisStatus
|
|
|
|
arr, err := json.Marshal(rowMap)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
_ = json.Unmarshal(arr, &info)
|
|
|
|
return &info, nil
|
|
|
|
}
|
|
|
|
|
2022-11-02 16:28:54 +08:00
|
|
|
func (u *RedisService) LoadConf() (*dto.RedisConf, error) {
|
|
|
|
redisInfo, err := mysqlRepo.LoadRedisBaseInfo()
|
2022-10-31 23:52:39 +08:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2022-11-02 16:28:54 +08:00
|
|
|
client := redis.NewClient(&redis.Options{
|
|
|
|
Addr: fmt.Sprintf("localhost:%v", redisInfo.Port),
|
|
|
|
Password: redisInfo.Password,
|
|
|
|
DB: 0,
|
|
|
|
})
|
2022-10-31 23:52:39 +08:00
|
|
|
var item dto.RedisConf
|
2022-11-02 16:28:54 +08:00
|
|
|
item.ContainerName = redisInfo.ContainerName
|
|
|
|
item.Name = redisInfo.Name
|
2022-10-31 23:52:39 +08:00
|
|
|
item.Timeout = configGetStr(client, "timeout")
|
|
|
|
item.Maxclients = configGetStr(client, "maxclients")
|
|
|
|
item.Databases = configGetStr(client, "databases")
|
|
|
|
item.Requirepass = configGetStr(client, "requirepass")
|
|
|
|
item.Maxmemory = configGetStr(client, "maxmemory")
|
2022-11-02 16:28:54 +08:00
|
|
|
return &item, nil
|
|
|
|
}
|
2022-10-31 23:52:39 +08:00
|
|
|
|
2022-11-02 16:28:54 +08:00
|
|
|
func (u *RedisService) LoadPersistenceConf() (*dto.RedisPersistence, error) {
|
|
|
|
redisInfo, err := mysqlRepo.LoadRedisBaseInfo()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
client := redis.NewClient(&redis.Options{
|
|
|
|
Addr: fmt.Sprintf("localhost:%v", redisInfo.Port),
|
|
|
|
Password: redisInfo.Password,
|
|
|
|
DB: 0,
|
|
|
|
})
|
|
|
|
var item dto.RedisPersistence
|
2022-10-31 23:52:39 +08:00
|
|
|
item.Dir = configGetStr(client, "dir")
|
|
|
|
item.Appendonly = configGetStr(client, "appendonly")
|
|
|
|
item.Appendfsync = configGetStr(client, "appendfsync")
|
|
|
|
item.Save = configGetStr(client, "save")
|
|
|
|
return &item, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func configGetStr(client *redis.Client, param string) string {
|
|
|
|
item, _ := client.ConfigGet(param).Result()
|
|
|
|
if len(item) == 2 {
|
|
|
|
if value, ok := item[1].(string); ok {
|
|
|
|
return value
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return ""
|
|
|
|
}
|
2022-11-02 18:30:22 +08:00
|
|
|
|
|
|
|
func updateConfFile(line, param string, value string) []byte {
|
|
|
|
var bytes []byte
|
|
|
|
if strings.HasPrefix(line, param) || strings.HasPrefix(line, "# "+param) {
|
|
|
|
if len(value) == 0 || value == "0" {
|
|
|
|
bytes = []byte(fmt.Sprintf("# %s", param))
|
|
|
|
} else {
|
|
|
|
bytes = []byte(fmt.Sprintf("%s %v", param, value))
|
|
|
|
}
|
|
|
|
return bytes
|
|
|
|
}
|
|
|
|
return bytes
|
|
|
|
}
|