mirror of
https://github.com/1Panel-dev/1Panel.git
synced 2025-01-19 08:19:15 +08:00
fix: daemon.json 路径逻辑调整
This commit is contained in:
parent
5a20546fc6
commit
8674cf0b53
@ -28,22 +28,6 @@ func (b *BaseApi) GetSettingInfo(c *gin.Context) {
|
|||||||
helper.SuccessWithData(c, setting)
|
helper.SuccessWithData(c, setting)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Load daemon.json path
|
|
||||||
// @Tags System Setting
|
|
||||||
// @Summary Load daemon.json path
|
|
||||||
// @Description 加载 docker 配置路径
|
|
||||||
// @Success 200 {string} path
|
|
||||||
// @Security ApiKeyAuth
|
|
||||||
// @Router /settings/daemonjson [get]
|
|
||||||
func (b *BaseApi) GetDaemonjson(c *gin.Context) {
|
|
||||||
value, err := settingService.GetDaemonjson()
|
|
||||||
if err != nil {
|
|
||||||
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
helper.SuccessWithData(c, value)
|
|
||||||
}
|
|
||||||
|
|
||||||
// @Tags System Setting
|
// @Tags System Setting
|
||||||
// @Summary Update system setting
|
// @Summary Update system setting
|
||||||
// @Description 更新系统配置
|
// @Description 更新系统配置
|
||||||
|
@ -7,6 +7,7 @@ type DaemonJsonUpdateByFile struct {
|
|||||||
|
|
||||||
type DaemonJsonConf struct {
|
type DaemonJsonConf struct {
|
||||||
Status string `json:"status"`
|
Status string `json:"status"`
|
||||||
|
Version string `json:"version"`
|
||||||
Mirrors []string `json:"registryMirrors"`
|
Mirrors []string `json:"registryMirrors"`
|
||||||
Registries []string `json:"insecureRegistries"`
|
Registries []string `json:"insecureRegistries"`
|
||||||
LiveRestore bool `json:"liveRestore"`
|
LiveRestore bool `json:"liveRestore"`
|
||||||
|
@ -2,14 +2,17 @@ package service
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"bufio"
|
"bufio"
|
||||||
|
"context"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
|
"path"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/1Panel-dev/1Panel/backend/app/dto"
|
"github.com/1Panel-dev/1Panel/backend/app/dto"
|
||||||
"github.com/1Panel-dev/1Panel/backend/constant"
|
"github.com/1Panel-dev/1Panel/backend/constant"
|
||||||
|
"github.com/1Panel-dev/1Panel/backend/utils/docker"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -53,31 +56,33 @@ func (u *DockerService) LoadDockerConf() *dto.DaemonJsonConf {
|
|||||||
if string(stdout) != "active\n" || err != nil {
|
if string(stdout) != "active\n" || err != nil {
|
||||||
status = constant.Stopped
|
status = constant.Stopped
|
||||||
}
|
}
|
||||||
fileSetting, err := settingRepo.Get(settingRepo.WithByKey("DaemonJsonPath"))
|
version := "-"
|
||||||
|
client, err := docker.NewDockerClient()
|
||||||
|
if err == nil {
|
||||||
|
ctx := context.Background()
|
||||||
|
itemVersion, err := client.ServerVersion(ctx)
|
||||||
|
if err == nil {
|
||||||
|
version = itemVersion.Version
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if _, err := os.Stat(constant.DaemonJsonPath); err != nil {
|
||||||
|
return &dto.DaemonJsonConf{Status: status, Version: version}
|
||||||
|
}
|
||||||
|
file, err := ioutil.ReadFile(constant.DaemonJsonPath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return &dto.DaemonJsonConf{Status: status}
|
return &dto.DaemonJsonConf{Status: status, Version: version}
|
||||||
}
|
|
||||||
if len(fileSetting.Value) == 0 {
|
|
||||||
return &dto.DaemonJsonConf{Status: status}
|
|
||||||
}
|
|
||||||
if _, err := os.Stat(fileSetting.Value); err != nil {
|
|
||||||
return &dto.DaemonJsonConf{Status: status}
|
|
||||||
}
|
|
||||||
file, err := ioutil.ReadFile(fileSetting.Value)
|
|
||||||
if err != nil {
|
|
||||||
return &dto.DaemonJsonConf{Status: status}
|
|
||||||
}
|
}
|
||||||
var conf daemonJsonItem
|
var conf daemonJsonItem
|
||||||
deamonMap := make(map[string]interface{})
|
deamonMap := make(map[string]interface{})
|
||||||
if err := json.Unmarshal(file, &deamonMap); err != nil {
|
if err := json.Unmarshal(file, &deamonMap); err != nil {
|
||||||
return &dto.DaemonJsonConf{Status: status}
|
return &dto.DaemonJsonConf{Status: status, Version: version}
|
||||||
}
|
}
|
||||||
arr, err := json.Marshal(deamonMap)
|
arr, err := json.Marshal(deamonMap)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return &dto.DaemonJsonConf{Status: status}
|
return &dto.DaemonJsonConf{Status: status, Version: version}
|
||||||
}
|
}
|
||||||
if err := json.Unmarshal(arr, &conf); err != nil {
|
if err := json.Unmarshal(arr, &conf); err != nil {
|
||||||
return &dto.DaemonJsonConf{Status: status}
|
return &dto.DaemonJsonConf{Status: status, Version: version}
|
||||||
}
|
}
|
||||||
driver := "cgroupfs"
|
driver := "cgroupfs"
|
||||||
for _, opt := range conf.ExecOpts {
|
for _, opt := range conf.ExecOpts {
|
||||||
@ -88,6 +93,7 @@ func (u *DockerService) LoadDockerConf() *dto.DaemonJsonConf {
|
|||||||
}
|
}
|
||||||
data := dto.DaemonJsonConf{
|
data := dto.DaemonJsonConf{
|
||||||
Status: status,
|
Status: status,
|
||||||
|
Version: version,
|
||||||
Mirrors: conf.Mirrors,
|
Mirrors: conf.Mirrors,
|
||||||
Registries: conf.Registries,
|
Registries: conf.Registries,
|
||||||
LiveRestore: conf.LiveRestore,
|
LiveRestore: conf.LiveRestore,
|
||||||
@ -98,22 +104,16 @@ func (u *DockerService) LoadDockerConf() *dto.DaemonJsonConf {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (u *DockerService) UpdateConf(req dto.DaemonJsonConf) error {
|
func (u *DockerService) UpdateConf(req dto.DaemonJsonConf) error {
|
||||||
fileSetting, err := settingRepo.Get(settingRepo.WithByKey("DaemonJsonPath"))
|
if _, err := os.Stat(constant.DaemonJsonPath); err != nil && os.IsNotExist(err) {
|
||||||
if err != nil {
|
if err = os.MkdirAll(path.Dir(constant.DaemonJsonPath), os.ModePerm); err != nil {
|
||||||
return err
|
|
||||||
}
|
|
||||||
if len(fileSetting.Value) == 0 {
|
|
||||||
return errors.New("error daemon.json path in request")
|
|
||||||
}
|
|
||||||
if _, err := os.Stat(fileSetting.Value); err != nil && os.IsNotExist(err) {
|
|
||||||
if err = os.MkdirAll(fileSetting.Value, os.ModePerm); err != nil {
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
_, _ = os.Create(constant.DaemonJsonPath)
|
||||||
}
|
}
|
||||||
|
|
||||||
file, err := ioutil.ReadFile(fileSetting.Value)
|
file, err := ioutil.ReadFile(constant.DaemonJsonPath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -155,7 +155,7 @@ func (u *DockerService) UpdateConf(req dto.DaemonJsonConf) error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if err := ioutil.WriteFile(fileSetting.Value, newJson, 0640); err != nil {
|
if err := ioutil.WriteFile(constant.DaemonJsonPath, newJson, 0640); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -176,24 +176,17 @@ func (u *ImageRepoService) checkConn(host, user, password string) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (u *ImageRepoService) handleRegistries(newHost, delHost, handle string) error {
|
func (u *ImageRepoService) handleRegistries(newHost, delHost, handle string) error {
|
||||||
fileSetting, err := settingRepo.Get(settingRepo.WithByKey("DaemonJsonPath"))
|
if _, err := os.Stat(constant.DaemonJsonPath); err != nil && os.IsNotExist(err) {
|
||||||
if err != nil {
|
if err = os.MkdirAll(path.Dir(constant.DaemonJsonPath), os.ModePerm); err != nil {
|
||||||
return err
|
|
||||||
}
|
|
||||||
if len(fileSetting.Value) == 0 {
|
|
||||||
return errors.New("error daemon.json in settings")
|
|
||||||
}
|
|
||||||
if _, err := os.Stat(path.Dir(fileSetting.Value)); err != nil && os.IsNotExist(err) {
|
|
||||||
if err = os.MkdirAll(fileSetting.Value, os.ModePerm); err != nil {
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_, _ = os.Create(fileSetting.Value)
|
_, _ = os.Create(constant.DaemonJsonPath)
|
||||||
}
|
}
|
||||||
|
|
||||||
deamonMap := make(map[string]interface{})
|
deamonMap := make(map[string]interface{})
|
||||||
file, err := ioutil.ReadFile(fileSetting.Value)
|
file, err := ioutil.ReadFile(constant.DaemonJsonPath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -229,7 +222,7 @@ func (u *ImageRepoService) handleRegistries(newHost, delHost, handle string) err
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if err := ioutil.WriteFile(fileSetting.Value, newJson, 0640); err != nil {
|
if err := ioutil.WriteFile(constant.DaemonJsonPath, newJson, 0640); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
|
@ -16,7 +16,6 @@ type SettingService struct{}
|
|||||||
|
|
||||||
type ISettingService interface {
|
type ISettingService interface {
|
||||||
GetSettingInfo() (*dto.SettingInfo, error)
|
GetSettingInfo() (*dto.SettingInfo, error)
|
||||||
GetDaemonjson() (string, error)
|
|
||||||
Update(c *gin.Context, key, value string) error
|
Update(c *gin.Context, key, value string) error
|
||||||
UpdatePassword(c *gin.Context, old, new string) error
|
UpdatePassword(c *gin.Context, old, new string) error
|
||||||
HandlePasswordExpired(c *gin.Context, old, new string) error
|
HandlePasswordExpired(c *gin.Context, old, new string) error
|
||||||
@ -47,14 +46,6 @@ func (u *SettingService) GetSettingInfo() (*dto.SettingInfo, error) {
|
|||||||
return &info, err
|
return &info, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *SettingService) GetDaemonjson() (string, error) {
|
|
||||||
setting, err := settingRepo.Get(settingRepo.WithByKey("DaemonJsonPath"))
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
return setting.Value, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (u *SettingService) Update(c *gin.Context, key, value string) error {
|
func (u *SettingService) Update(c *gin.Context, key, value string) error {
|
||||||
if key == "ExpirationDays" {
|
if key == "ExpirationDays" {
|
||||||
timeout, _ := strconv.Atoi(value)
|
timeout, _ := strconv.Atoi(value)
|
||||||
|
@ -16,4 +16,5 @@ const (
|
|||||||
|
|
||||||
TmpDockerBuildDir = "/opt/1Panel/data/docker/build"
|
TmpDockerBuildDir = "/opt/1Panel/data/docker/build"
|
||||||
TmpComposeBuildDir = "/opt/1Panel/data/docker/compose"
|
TmpComposeBuildDir = "/opt/1Panel/data/docker/compose"
|
||||||
|
DaemonJsonPath = "/tmp/docker/daemon.json"
|
||||||
)
|
)
|
||||||
|
@ -114,10 +114,6 @@ var AddTableSetting = &gormigrate.Migration{
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := tx.Create(&model.Setting{Key: "DaemonJsonPath", Value: "/opt/1Panel/docker/conf/daemon.json"}).Error; err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := tx.Create(&model.Setting{Key: "MessageType", Value: "none"}).Error; err != nil {
|
if err := tx.Create(&model.Setting{Key: "MessageType", Value: "none"}).Error; err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -23,7 +23,6 @@ func (s *SettingRouter) InitSettingRouter(Router *gin.RouterGroup) {
|
|||||||
settingRouter.POST("/time/sync", baseApi.SyncTime)
|
settingRouter.POST("/time/sync", baseApi.SyncTime)
|
||||||
settingRouter.POST("/monitor/clean", baseApi.CleanMonitor)
|
settingRouter.POST("/monitor/clean", baseApi.CleanMonitor)
|
||||||
settingRouter.GET("/mfa", baseApi.GetMFA)
|
settingRouter.GET("/mfa", baseApi.GetMFA)
|
||||||
settingRouter.GET("/daemonjson", baseApi.GetDaemonjson)
|
|
||||||
settingRouter.POST("/mfa/bind", baseApi.MFABind)
|
settingRouter.POST("/mfa/bind", baseApi.MFABind)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -236,7 +236,6 @@ export namespace Container {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export interface DaemonJsonUpdateByFile {
|
export interface DaemonJsonUpdateByFile {
|
||||||
path: string;
|
|
||||||
file: string;
|
file: string;
|
||||||
}
|
}
|
||||||
export interface DockerOperate {
|
export interface DockerOperate {
|
||||||
@ -244,6 +243,7 @@ export namespace Container {
|
|||||||
}
|
}
|
||||||
export interface DaemonJsonConf {
|
export interface DaemonJsonConf {
|
||||||
status: string;
|
status: string;
|
||||||
|
version: string;
|
||||||
registryMirrors: Array<string>;
|
registryMirrors: Array<string>;
|
||||||
insecureRegistries: Array<string>;
|
insecureRegistries: Array<string>;
|
||||||
liveRestore: boolean;
|
liveRestore: boolean;
|
||||||
|
@ -359,6 +359,7 @@ export default {
|
|||||||
rdbInfo: 'Rule list has 0 value, please confirm and try again!',
|
rdbInfo: 'Rule list has 0 value, please confirm and try again!',
|
||||||
},
|
},
|
||||||
container: {
|
container: {
|
||||||
|
containerList: 'Container list',
|
||||||
operatorHelper: '{0} will be performed on the selected container. Do you want to continue?',
|
operatorHelper: '{0} will be performed on the selected container. Do you want to continue?',
|
||||||
start: 'Start',
|
start: 'Start',
|
||||||
stop: 'Stop',
|
stop: 'Stop',
|
||||||
|
@ -372,6 +372,7 @@ export default {
|
|||||||
rdbInfo: '规则列表存在 0 值,请确认后重试!',
|
rdbInfo: '规则列表存在 0 值,请确认后重试!',
|
||||||
},
|
},
|
||||||
container: {
|
container: {
|
||||||
|
containerList: '容器列表',
|
||||||
operatorHelper: '将对选中容器进行 {0} 操作,是否继续?',
|
operatorHelper: '将对选中容器进行 {0} 操作,是否继续?',
|
||||||
start: '启动',
|
start: '启动',
|
||||||
stop: '停止',
|
stop: '停止',
|
||||||
|
@ -1,31 +1,42 @@
|
|||||||
<template>
|
<template>
|
||||||
<div v-loading="loading">
|
<div v-loading="loading">
|
||||||
<LayoutContent :header="composeName" back-name="Compose" :reload="true">
|
<div class="app-content" style="margin-top: 20px">
|
||||||
<div v-if="createdBy === '1Panel'">
|
<el-card class="app-card">
|
||||||
<el-card>
|
<el-row :gutter="20">
|
||||||
<template #header>
|
<el-col :lg="3" :xl="2">
|
||||||
<div class="card-header">
|
<div>
|
||||||
<span>{{ $t('container.compose') }}</span>
|
<el-tag effect="dark" type="success">{{ composeName }}</el-tag>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</el-col>
|
||||||
<el-button-group>
|
<el-col :lg="8" :xl="12">
|
||||||
<el-button @click="onComposeOperate('start')">{{ $t('container.start') }}</el-button>
|
<div v-if="createdBy === '1Panel'">
|
||||||
<el-button @click="onComposeOperate('stop')">{{ $t('container.stop') }}</el-button>
|
<el-button link type="primary" @click="onComposeOperate('start')">
|
||||||
<el-button @click="onComposeOperate('down')">
|
{{ $t('container.start') }}
|
||||||
{{ $t('container.remove') }}
|
</el-button>
|
||||||
</el-button>
|
<el-divider direction="vertical" />
|
||||||
</el-button-group>
|
<el-button link type="primary" @click="onComposeOperate('stop')">
|
||||||
</el-card>
|
{{ $t('container.stop') }}
|
||||||
</div>
|
</el-button>
|
||||||
<div v-else>
|
<el-divider direction="vertical" />
|
||||||
<el-alert :closable="false" show-icon :title="$t('container.composeDetailHelper')" type="info" />
|
<el-button link type="primary" @click="onComposeOperate('down')">
|
||||||
</div>
|
{{ $t('container.remove') }}
|
||||||
<el-card style="margin-top: 20px">
|
</el-button>
|
||||||
<template #header>
|
</div>
|
||||||
<div class="card-header">
|
<div v-else>
|
||||||
<span>{{ $t('container.container') }}</span>
|
<el-alert
|
||||||
</div>
|
style="margin-top: -5px"
|
||||||
</template>
|
:closable="false"
|
||||||
|
show-icon
|
||||||
|
:title="$t('container.composeDetailHelper')"
|
||||||
|
type="info"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</el-card>
|
||||||
|
</div>
|
||||||
|
<el-card style="margin-top: 20px">
|
||||||
|
<LayoutContent :header="$t('container.containerList')" back-name="Compose" :reload="true">
|
||||||
<ComplexTable
|
<ComplexTable
|
||||||
:pagination-config="paginationConfig"
|
:pagination-config="paginationConfig"
|
||||||
v-model:selects="selects"
|
v-model:selects="selects"
|
||||||
@ -103,8 +114,8 @@
|
|||||||
<CreateDialog @search="search" ref="dialogCreateRef" />
|
<CreateDialog @search="search" ref="dialogCreateRef" />
|
||||||
<MonitorDialog ref="dialogMonitorRef" />
|
<MonitorDialog ref="dialogMonitorRef" />
|
||||||
<TerminalDialog ref="dialogTerminalRef" />
|
<TerminalDialog ref="dialogTerminalRef" />
|
||||||
</el-card>
|
</LayoutContent>
|
||||||
</LayoutContent>
|
</el-card>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@ -314,3 +325,18 @@ defineExpose({
|
|||||||
acceptParams,
|
acceptParams,
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
<style lang="scss">
|
||||||
|
.app-card {
|
||||||
|
font-size: 14px;
|
||||||
|
height: 60px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.app-content {
|
||||||
|
height: 50px;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
@ -1,6 +1,10 @@
|
|||||||
<template>
|
<template>
|
||||||
<div v-loading="loading">
|
<div v-loading="loading">
|
||||||
<Submenu activeName="compose" />
|
<Submenu activeName="compose" />
|
||||||
|
|
||||||
|
<div v-show="isOnDetail">
|
||||||
|
<ComposeDetial @back="backList" ref="composeDetailRef" />
|
||||||
|
</div>
|
||||||
<el-card width="30%" v-if="dockerStatus != 'Running'" class="mask-prompt">
|
<el-card width="30%" v-if="dockerStatus != 'Running'" class="mask-prompt">
|
||||||
<span style="font-size: 14px">{{ $t('container.serviceUnavailable') }}</span>
|
<span style="font-size: 14px">{{ $t('container.serviceUnavailable') }}</span>
|
||||||
<el-button type="primary" link style="font-size: 14px; margin-bottom: 5px" @click="goSetting">
|
<el-button type="primary" link style="font-size: 14px; margin-bottom: 5px" @click="goSetting">
|
||||||
@ -8,8 +12,8 @@
|
|||||||
</el-button>
|
</el-button>
|
||||||
<span style="font-size: 14px">{{ $t('container.startIn') }}</span>
|
<span style="font-size: 14px">{{ $t('container.startIn') }}</span>
|
||||||
</el-card>
|
</el-card>
|
||||||
<el-card style="margin-top: 20px" :class="{ mask: dockerStatus != 'Running' }">
|
<el-card v-if="!isOnDetail" style="margin-top: 20px" :class="{ mask: dockerStatus != 'Running' }">
|
||||||
<div v-if="!isOnDetail">
|
<div>
|
||||||
<ComplexTable
|
<ComplexTable
|
||||||
:pagination-config="paginationConfig"
|
:pagination-config="paginationConfig"
|
||||||
v-model:selects="selects"
|
v-model:selects="selects"
|
||||||
@ -54,9 +58,6 @@
|
|||||||
/>
|
/>
|
||||||
</ComplexTable>
|
</ComplexTable>
|
||||||
</div>
|
</div>
|
||||||
<div v-show="isOnDetail">
|
|
||||||
<ComposeDetial @back="backList" ref="composeDetailRef" />
|
|
||||||
</div>
|
|
||||||
</el-card>
|
</el-card>
|
||||||
|
|
||||||
<EditDialog ref="dialogEditRef" />
|
<EditDialog ref="dialogEditRef" />
|
||||||
|
@ -1,53 +1,63 @@
|
|||||||
<template>
|
<template>
|
||||||
<div v-loading="loading">
|
<div v-loading="loading">
|
||||||
<Submenu activeName="setting" />
|
<Submenu activeName="setting" />
|
||||||
<el-form :model="form" ref="formRef" label-width="120px">
|
<div class="app-content" style="margin-top: 20px">
|
||||||
<el-card style="margin-top: 20px">
|
<el-card class="app-card">
|
||||||
<el-row style="margin-top: 20px">
|
<el-row :gutter="20">
|
||||||
<el-col :span="1"><br /></el-col>
|
<el-col :lg="3" :xl="2">
|
||||||
<el-col :span="10">
|
<div>
|
||||||
<el-form-item :label="$t('container.dockerStatus')">
|
<el-tag effect="dark" type="success">Docker</el-tag>
|
||||||
<div v-if="form.status === 'Running'">
|
</div>
|
||||||
<el-tag type="success">{{ $t('commons.status.running') }}</el-tag>
|
</el-col>
|
||||||
<el-button type="primary" @click="onOperator('stop')" link style="margin-left: 20px">
|
<el-col :lg="3" :xl="2">
|
||||||
{{ $t('container.stop') }}
|
<div>
|
||||||
</el-button>
|
{{ $t('app.version') }}:
|
||||||
<el-divider direction="vertical" />
|
<el-tag type="info">{{ form.version }}</el-tag>
|
||||||
<el-button type="primary" @click="onOperator('restart')" link>
|
</div>
|
||||||
{{ $t('container.restart') }}
|
</el-col>
|
||||||
</el-button>
|
<el-col :lg="3" :xl="2">
|
||||||
</div>
|
<div>
|
||||||
<div v-if="form.status === 'Stopped'">
|
{{ $t('commons.table.status') }}:
|
||||||
<el-tag type="info">{{ $t('commons.status.stopped') }}</el-tag>
|
<el-tag v-if="form.status === 'Running'" type="success">
|
||||||
<el-button type="primary" @click="onOperator('start')" link style="margin-left: 20px">
|
{{ $t('commons.status.running') }}
|
||||||
{{ $t('container.start') }}
|
</el-tag>
|
||||||
</el-button>
|
<el-tag v-if="form.status === 'Stopped'" type="info">
|
||||||
<el-divider direction="vertical" />
|
{{ $t('commons.status.stopped') }}
|
||||||
<el-button type="primary" @click="onOperator('restart')" link>
|
</el-tag>
|
||||||
{{ $t('container.restart') }}
|
</div>
|
||||||
</el-button>
|
</el-col>
|
||||||
</div>
|
<el-col :lg="4" :xl="6">
|
||||||
</el-form-item>
|
<div v-if="form.status === 'Running'">
|
||||||
<el-form-item :label="$t('container.daemonJsonPath')">
|
<el-button type="primary" @click="onOperator('stop')" link style="margin-left: 20px">
|
||||||
<el-input disabled v-model="daemonJsonPath">
|
{{ $t('container.stop') }}
|
||||||
<template #append>
|
</el-button>
|
||||||
<FileList @choose="loadLoadDir" :dir="false"></FileList>
|
<el-divider direction="vertical" />
|
||||||
</template>
|
<el-button type="primary" @click="onOperator('restart')" link>
|
||||||
</el-input>
|
{{ $t('container.restart') }}
|
||||||
<span class="input-help">{{ $t('container.daemonJsonPathHelper') }}</span>
|
</el-button>
|
||||||
<el-button type="primary" @click="savePath">{{ $t('commons.button.save') }}</el-button>
|
</div>
|
||||||
</el-form-item>
|
<div v-if="form.status === 'Stopped'">
|
||||||
|
<el-button type="primary" @click="onOperator('start')" link style="margin-left: 20px">
|
||||||
|
{{ $t('container.start') }}
|
||||||
|
</el-button>
|
||||||
|
<el-divider direction="vertical" />
|
||||||
|
<el-button type="primary" @click="onOperator('restart')" link>
|
||||||
|
{{ $t('container.restart') }}
|
||||||
|
</el-button>
|
||||||
|
</div>
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
</el-card>
|
</el-card>
|
||||||
<el-card style="margin-top: 10px">
|
</div>
|
||||||
<el-radio-group v-model="confShowType" @change="changeMode">
|
<el-card style="margin-top: 20px">
|
||||||
<el-radio-button label="base">{{ $t('database.baseConf') }}</el-radio-button>
|
<el-radio-group v-model="confShowType" @change="changeMode">
|
||||||
<el-radio-button label="all">{{ $t('database.allConf') }}</el-radio-button>
|
<el-radio-button label="base">{{ $t('database.baseConf') }}</el-radio-button>
|
||||||
</el-radio-group>
|
<el-radio-button label="all">{{ $t('database.allConf') }}</el-radio-button>
|
||||||
<el-row style="margin-top: 20px" v-if="confShowType === 'base'">
|
</el-radio-group>
|
||||||
<el-col :span="1"><br /></el-col>
|
<el-row style="margin-top: 20px" v-if="confShowType === 'base'">
|
||||||
<el-col :span="10">
|
<el-col :span="1"><br /></el-col>
|
||||||
|
<el-col :span="10">
|
||||||
|
<el-form :model="form" ref="formRef" label-width="120px">
|
||||||
<el-form-item :label="$t('container.mirrors')" prop="mirrors">
|
<el-form-item :label="$t('container.mirrors')" prop="mirrors">
|
||||||
<el-input
|
<el-input
|
||||||
type="textarea"
|
type="textarea"
|
||||||
@ -80,30 +90,30 @@
|
|||||||
{{ $t('commons.button.save') }}
|
{{ $t('commons.button.save') }}
|
||||||
</el-button>
|
</el-button>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-form>
|
||||||
</el-row>
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
|
||||||
<div v-if="confShowType === 'all'">
|
<div v-if="confShowType === 'all'">
|
||||||
<codemirror
|
<codemirror
|
||||||
:autofocus="true"
|
:autofocus="true"
|
||||||
placeholder="None data"
|
placeholder="None data"
|
||||||
:indent-with-tab="true"
|
:indent-with-tab="true"
|
||||||
:tabSize="4"
|
:tabSize="4"
|
||||||
style="margin-top: 10px; height: calc(100vh - 380px)"
|
style="margin-top: 10px; height: calc(100vh - 380px)"
|
||||||
:lineWrapping="true"
|
:lineWrapping="true"
|
||||||
:matchBrackets="true"
|
:matchBrackets="true"
|
||||||
theme="cobalt"
|
theme="cobalt"
|
||||||
:styleActiveLine="true"
|
:styleActiveLine="true"
|
||||||
:extensions="extensions"
|
:extensions="extensions"
|
||||||
v-model="dockerConf"
|
v-model="dockerConf"
|
||||||
:readOnly="true"
|
:readOnly="true"
|
||||||
/>
|
/>
|
||||||
<el-button :disabled="loading" type="primary" @click="onSaveFile" style="margin-top: 5px">
|
<el-button :disabled="loading" type="primary" @click="onSaveFile" style="margin-top: 5px">
|
||||||
{{ $t('commons.button.save') }}
|
{{ $t('commons.button.save') }}
|
||||||
</el-button>
|
</el-button>
|
||||||
</div>
|
</div>
|
||||||
</el-card>
|
</el-card>
|
||||||
</el-form>
|
|
||||||
|
|
||||||
<ConfirmDialog ref="confirmDialogRef" @confirm="onSubmitSave"></ConfirmDialog>
|
<ConfirmDialog ref="confirmDialogRef" @confirm="onSubmitSave"></ConfirmDialog>
|
||||||
</div>
|
</div>
|
||||||
@ -111,7 +121,6 @@
|
|||||||
|
|
||||||
<script lang="ts" setup>
|
<script lang="ts" setup>
|
||||||
import { ElMessage, FormInstance } from 'element-plus';
|
import { ElMessage, FormInstance } from 'element-plus';
|
||||||
import FileList from '@/components/file-list/index.vue';
|
|
||||||
import { onMounted, reactive, ref } from 'vue';
|
import { onMounted, reactive, ref } from 'vue';
|
||||||
import Submenu from '@/views/container/index.vue';
|
import Submenu from '@/views/container/index.vue';
|
||||||
import { Codemirror } from 'vue-codemirror';
|
import { Codemirror } from 'vue-codemirror';
|
||||||
@ -121,20 +130,15 @@ import { LoadFile } from '@/api/modules/files';
|
|||||||
import ConfirmDialog from '@/components/confirm-dialog/index.vue';
|
import ConfirmDialog from '@/components/confirm-dialog/index.vue';
|
||||||
import i18n from '@/lang';
|
import i18n from '@/lang';
|
||||||
import { dockerOperate, loadDaemonJson, updateDaemonJson, updateDaemonJsonByfile } from '@/api/modules/container';
|
import { dockerOperate, loadDaemonJson, updateDaemonJson, updateDaemonJsonByfile } from '@/api/modules/container';
|
||||||
import { loadDaemonJsonPath, updateSetting } from '@/api/modules/setting';
|
|
||||||
|
|
||||||
const loading = ref(false);
|
const loading = ref(false);
|
||||||
|
|
||||||
const extensions = [javascript(), oneDark];
|
const extensions = [javascript(), oneDark];
|
||||||
const confShowType = ref('base');
|
const confShowType = ref('base');
|
||||||
|
|
||||||
const daemonJsonPath = ref();
|
|
||||||
const loadLoadDir = async (path: string) => {
|
|
||||||
daemonJsonPath.value = path;
|
|
||||||
};
|
|
||||||
|
|
||||||
const form = reactive({
|
const form = reactive({
|
||||||
status: '',
|
status: '',
|
||||||
|
version: '',
|
||||||
mirrors: '',
|
mirrors: '',
|
||||||
registries: '',
|
registries: '',
|
||||||
liveRestore: false,
|
liveRestore: false,
|
||||||
@ -177,22 +181,9 @@ const onOperator = async (operation: string) => {
|
|||||||
ElMessage.success(i18n.global.t('commons.msg.operationSuccess'));
|
ElMessage.success(i18n.global.t('commons.msg.operationSuccess'));
|
||||||
};
|
};
|
||||||
|
|
||||||
const savePath = async () => {
|
|
||||||
let param = {
|
|
||||||
key: 'DaemonJsonPath',
|
|
||||||
value: daemonJsonPath.value,
|
|
||||||
};
|
|
||||||
await updateSetting(param);
|
|
||||||
changeMode();
|
|
||||||
ElMessage.success(i18n.global.t('commons.msg.operationSuccess'));
|
|
||||||
};
|
|
||||||
|
|
||||||
const onSubmitSave = async () => {
|
const onSubmitSave = async () => {
|
||||||
if (confShowType.value === 'all') {
|
if (confShowType.value === 'all') {
|
||||||
let param = {
|
let param = { file: dockerConf.value };
|
||||||
file: dockerConf.value,
|
|
||||||
path: daemonJsonPath.value,
|
|
||||||
};
|
|
||||||
loading.value = true;
|
loading.value = true;
|
||||||
await updateDaemonJsonByfile(param)
|
await updateDaemonJsonByfile(param)
|
||||||
.then(() => {
|
.then(() => {
|
||||||
@ -208,6 +199,7 @@ const onSubmitSave = async () => {
|
|||||||
let itemRegistries = form.registries.split('\n');
|
let itemRegistries = form.registries.split('\n');
|
||||||
let param = {
|
let param = {
|
||||||
status: form.status,
|
status: form.status,
|
||||||
|
version: '',
|
||||||
registryMirrors: itemMirrors.filter(function (el) {
|
registryMirrors: itemMirrors.filter(function (el) {
|
||||||
return el !== null && el !== '' && el !== undefined;
|
return el !== null && el !== '' && el !== undefined;
|
||||||
}),
|
}),
|
||||||
@ -229,19 +221,14 @@ const onSubmitSave = async () => {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
const loadMysqlConf = async () => {
|
const loadDockerConf = async () => {
|
||||||
const res = await LoadFile({ path: daemonJsonPath.value });
|
const res = await LoadFile({ path: '/etc/docker/daemon.json' });
|
||||||
dockerConf.value = res.data;
|
dockerConf.value = res.data;
|
||||||
};
|
};
|
||||||
|
|
||||||
const loadPath = async () => {
|
|
||||||
const res = await loadDaemonJsonPath();
|
|
||||||
daemonJsonPath.value = res.data;
|
|
||||||
};
|
|
||||||
|
|
||||||
const changeMode = async () => {
|
const changeMode = async () => {
|
||||||
if (confShowType.value === 'all') {
|
if (confShowType.value === 'all') {
|
||||||
loadMysqlConf();
|
loadDockerConf();
|
||||||
} else {
|
} else {
|
||||||
search();
|
search();
|
||||||
}
|
}
|
||||||
@ -250,6 +237,7 @@ const changeMode = async () => {
|
|||||||
const search = async () => {
|
const search = async () => {
|
||||||
const res = await loadDaemonJson();
|
const res = await loadDaemonJson();
|
||||||
form.status = res.data.status;
|
form.status = res.data.status;
|
||||||
|
form.version = res.data.version;
|
||||||
form.cgroupDriver = res.data.cgroupDriver;
|
form.cgroupDriver = res.data.cgroupDriver;
|
||||||
form.liveRestore = res.data.liveRestore;
|
form.liveRestore = res.data.liveRestore;
|
||||||
form.mirrors = res.data.registryMirrors ? res.data.registryMirrors.join('\n') : '';
|
form.mirrors = res.data.registryMirrors ? res.data.registryMirrors.join('\n') : '';
|
||||||
@ -257,7 +245,21 @@ const search = async () => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
loadPath();
|
|
||||||
search();
|
search();
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
<style lang="scss">
|
||||||
|
.app-card {
|
||||||
|
font-size: 14px;
|
||||||
|
height: 60px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.app-content {
|
||||||
|
height: 50px;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user