mirror of
				https://github.com/TeaOSLab/EdgeAdmin.git
				synced 2025-11-04 05:00:25 +08:00 
			
		
		
		
	可以修复单页或者全部服务日志
This commit is contained in:
		@@ -1,19 +1,28 @@
 | 
				
			|||||||
// Copyright 2021 Liuxiangchao iwind.liu@gmail.com. All rights reserved.
 | 
					// Copyright 2021 Liuxiangchao iwind.liu@gmail.com. All rights reserved.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
package servers
 | 
					package logs
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
						"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
 | 
				
			||||||
 | 
						"github.com/iwind/TeaGo/types"
 | 
				
			||||||
 | 
						"strings"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
type FixLogAction struct {
 | 
					type FixAction struct {
 | 
				
			||||||
	actionutils.ParentAction
 | 
						actionutils.ParentAction
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func (this *FixLogAction) RunPost(params struct {
 | 
					func (this *FixAction) RunPost(params struct {
 | 
				
			||||||
	LogIds []int64
 | 
						LogIds []int64
 | 
				
			||||||
}) {
 | 
					}) {
 | 
				
			||||||
 | 
						var logIdStrings = []string{}
 | 
				
			||||||
 | 
						for _, logId := range params.LogIds {
 | 
				
			||||||
 | 
							logIdStrings = append(logIdStrings, types.String(logId))
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						defer this.CreateLogInfo("设置日志 %s 为已修复", strings.Join(logIdStrings, ", "))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	_, err := this.RPC().NodeLogRPC().FixNodeLogs(this.AdminContext(), &pb.FixNodeLogsRequest{NodeLogIds: params.LogIds})
 | 
						_, err := this.RPC().NodeLogRPC().FixNodeLogs(this.AdminContext(), &pb.FixNodeLogsRequest{NodeLogIds: params.LogIds})
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		this.ErrorPage(err)
 | 
							this.ErrorPage(err)
 | 
				
			||||||
							
								
								
									
										25
									
								
								internal/web/actions/default/clusters/logs/fixAll.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								internal/web/actions/default/clusters/logs/fixAll.go
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,25 @@
 | 
				
			|||||||
 | 
					// Copyright 2021 Liuxiangchao iwind.liu@gmail.com. All rights reserved.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					package logs
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import (
 | 
				
			||||||
 | 
						"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
				
			||||||
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type FixAllAction struct {
 | 
				
			||||||
 | 
						actionutils.ParentAction
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (this *FixAllAction) RunPost(params struct {
 | 
				
			||||||
 | 
					}) {
 | 
				
			||||||
 | 
						defer this.CreateLogInfo("设置所有日志为已修复")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						_, err := this.RPC().NodeLogRPC().FixAllNodeLogs(this.AdminContext(), &pb.FixAllNodeLogsRequest{})
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							this.ErrorPage(err)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						this.Success()
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -3,8 +3,10 @@ package logs
 | 
				
			|||||||
import (
 | 
					import (
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeAdmin/internal/utils/nodelogutils"
 | 
						"github.com/TeaOSLab/EdgeAdmin/internal/utils/nodelogutils"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
						"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
				
			||||||
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/configutils"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/nodeconfigs"
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/nodeconfigs"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
 | 
				
			||||||
 | 
						"github.com/iwind/TeaGo/lists"
 | 
				
			||||||
	"github.com/iwind/TeaGo/maps"
 | 
						"github.com/iwind/TeaGo/maps"
 | 
				
			||||||
	timeutil "github.com/iwind/TeaGo/utils/time"
 | 
						timeutil "github.com/iwind/TeaGo/utils/time"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
@@ -14,8 +16,11 @@ type IndexAction struct {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func (this *IndexAction) Init() {
 | 
					func (this *IndexAction) Init() {
 | 
				
			||||||
	if this.ParamString("type") == "unread" {
 | 
						var paramType = this.ParamString("type")
 | 
				
			||||||
 | 
						if paramType == "unread" {
 | 
				
			||||||
		this.FirstMenu("unread")
 | 
							this.FirstMenu("unread")
 | 
				
			||||||
 | 
						} else if paramType == "needFix" {
 | 
				
			||||||
 | 
							this.FirstMenu("needFix")
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
		this.FirstMenu("index")
 | 
							this.FirstMenu("index")
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
@@ -26,7 +31,7 @@ func (this *IndexAction) RunGet(params struct {
 | 
				
			|||||||
	DayTo     string
 | 
						DayTo     string
 | 
				
			||||||
	Keyword   string
 | 
						Keyword   string
 | 
				
			||||||
	Level     string
 | 
						Level     string
 | 
				
			||||||
	Type      string
 | 
						Type      string // unread, needFix
 | 
				
			||||||
	Tag       string
 | 
						Tag       string
 | 
				
			||||||
	ClusterId int64
 | 
						ClusterId int64
 | 
				
			||||||
	NodeId    int64
 | 
						NodeId    int64
 | 
				
			||||||
@@ -40,6 +45,13 @@ func (this *IndexAction) RunGet(params struct {
 | 
				
			|||||||
	this.Data["clusterId"] = params.ClusterId
 | 
						this.Data["clusterId"] = params.ClusterId
 | 
				
			||||||
	this.Data["nodeId"] = params.NodeId
 | 
						this.Data["nodeId"] = params.NodeId
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						var fixedState configutils.BoolState = 0
 | 
				
			||||||
 | 
						var allServers = false
 | 
				
			||||||
 | 
						if params.Type == "needFix" {
 | 
				
			||||||
 | 
							fixedState = configutils.BoolStateNo
 | 
				
			||||||
 | 
							allServers = true
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	// 常见标签
 | 
						// 常见标签
 | 
				
			||||||
	this.Data["tags"] = nodelogutils.FindNodeCommonTags()
 | 
						this.Data["tags"] = nodelogutils.FindNodeCommonTags()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -54,6 +66,18 @@ func (this *IndexAction) RunGet(params struct {
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
	this.Data["countUnreadLogs"] = countUnreadResp.Count
 | 
						this.Data["countUnreadLogs"] = countUnreadResp.Count
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// 需要修复数量
 | 
				
			||||||
 | 
						countNeedFixResp, err := this.RPC().NodeLogRPC().CountNodeLogs(this.AdminContext(), &pb.CountNodeLogsRequest{
 | 
				
			||||||
 | 
							Role:       nodeconfigs.NodeRoleNode,
 | 
				
			||||||
 | 
							AllServers: true,
 | 
				
			||||||
 | 
							FixedState: int32(configutils.BoolStateNo),
 | 
				
			||||||
 | 
						})
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							this.ErrorPage(err)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						this.Data["countNeedFixLogs"] = countNeedFixResp.Count
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	// 日志数量
 | 
						// 日志数量
 | 
				
			||||||
	countResp, err := this.RPC().NodeLogRPC().CountNodeLogs(this.AdminContext(), &pb.CountNodeLogsRequest{
 | 
						countResp, err := this.RPC().NodeLogRPC().CountNodeLogs(this.AdminContext(), &pb.CountNodeLogsRequest{
 | 
				
			||||||
		NodeClusterId: params.ClusterId,
 | 
							NodeClusterId: params.ClusterId,
 | 
				
			||||||
@@ -65,13 +89,15 @@ func (this *IndexAction) RunGet(params struct {
 | 
				
			|||||||
		Level:         params.Level,
 | 
							Level:         params.Level,
 | 
				
			||||||
		IsUnread:      params.Type == "unread",
 | 
							IsUnread:      params.Type == "unread",
 | 
				
			||||||
		Tag:           params.Tag,
 | 
							Tag:           params.Tag,
 | 
				
			||||||
 | 
							FixedState:    int32(fixedState),
 | 
				
			||||||
 | 
							AllServers:    allServers,
 | 
				
			||||||
	})
 | 
						})
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		this.ErrorPage(err)
 | 
							this.ErrorPage(err)
 | 
				
			||||||
		return
 | 
							return
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	count := countResp.Count
 | 
						var count = countResp.Count
 | 
				
			||||||
	page := this.NewPage(count)
 | 
						var page = this.NewPage(count)
 | 
				
			||||||
	this.Data["page"] = page.AsHTML()
 | 
						this.Data["page"] = page.AsHTML()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	logsResp, err := this.RPC().NodeLogRPC().ListNodeLogs(this.AdminContext(), &pb.ListNodeLogsRequest{
 | 
						logsResp, err := this.RPC().NodeLogRPC().ListNodeLogs(this.AdminContext(), &pb.ListNodeLogsRequest{
 | 
				
			||||||
@@ -84,6 +110,8 @@ func (this *IndexAction) RunGet(params struct {
 | 
				
			|||||||
		Level:         params.Level,
 | 
							Level:         params.Level,
 | 
				
			||||||
		IsUnread:      params.Type == "unread",
 | 
							IsUnread:      params.Type == "unread",
 | 
				
			||||||
		Tag:           params.Tag,
 | 
							Tag:           params.Tag,
 | 
				
			||||||
 | 
							FixedState:    int32(fixedState),
 | 
				
			||||||
 | 
							AllServers:    allServers,
 | 
				
			||||||
		Offset:        page.Offset,
 | 
							Offset:        page.Offset,
 | 
				
			||||||
		Size:          page.Size,
 | 
							Size:          page.Size,
 | 
				
			||||||
	})
 | 
						})
 | 
				
			||||||
@@ -92,14 +120,14 @@ func (this *IndexAction) RunGet(params struct {
 | 
				
			|||||||
		return
 | 
							return
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	logs := []maps.Map{}
 | 
						var logs = []maps.Map{}
 | 
				
			||||||
	for _, log := range logsResp.NodeLogs {
 | 
						for _, log := range logsResp.NodeLogs {
 | 
				
			||||||
		// 节点信息
 | 
							// 节点信息
 | 
				
			||||||
		nodeResp, err := this.RPC().NodeRPC().FindEnabledNode(this.AdminContext(), &pb.FindEnabledNodeRequest{NodeId: log.NodeId})
 | 
							nodeResp, err := this.RPC().NodeRPC().FindEnabledNode(this.AdminContext(), &pb.FindEnabledNodeRequest{NodeId: log.NodeId})
 | 
				
			||||||
		if err != nil {
 | 
							if err != nil {
 | 
				
			||||||
			continue
 | 
								continue
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		node := nodeResp.Node
 | 
							var node = nodeResp.Node
 | 
				
			||||||
		if node == nil || node.NodeCluster == nil {
 | 
							if node == nil || node.NodeCluster == nil {
 | 
				
			||||||
			continue
 | 
								continue
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -118,6 +146,11 @@ func (this *IndexAction) RunGet(params struct {
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							var isFixed = true
 | 
				
			||||||
 | 
							if !log.IsFixed && log.ServerId > 0 && lists.ContainsString([]string{"success", "warning", "error"}, log.Level) {
 | 
				
			||||||
 | 
								isFixed = false
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		logs = append(logs, maps.Map{
 | 
							logs = append(logs, maps.Map{
 | 
				
			||||||
			"id":          log.Id,
 | 
								"id":          log.Id,
 | 
				
			||||||
			"tag":         log.Tag,
 | 
								"tag":         log.Tag,
 | 
				
			||||||
@@ -127,6 +160,7 @@ func (this *IndexAction) RunGet(params struct {
 | 
				
			|||||||
			"isToday":     timeutil.FormatTime("Y-m-d", log.CreatedAt) == timeutil.Format("Y-m-d"),
 | 
								"isToday":     timeutil.FormatTime("Y-m-d", log.CreatedAt) == timeutil.Format("Y-m-d"),
 | 
				
			||||||
			"count":       log.Count,
 | 
								"count":       log.Count,
 | 
				
			||||||
			"isRead":      log.IsRead,
 | 
								"isRead":      log.IsRead,
 | 
				
			||||||
 | 
								"isFixed":     isFixed,
 | 
				
			||||||
			"node": maps.Map{
 | 
								"node": maps.Map{
 | 
				
			||||||
				"id": node.Id,
 | 
									"id": node.Id,
 | 
				
			||||||
				"cluster": maps.Map{
 | 
									"cluster": maps.Map{
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -16,6 +16,8 @@ func init() {
 | 
				
			|||||||
			Get("", new(IndexAction)).
 | 
								Get("", new(IndexAction)).
 | 
				
			||||||
			Post("/readLogs", new(ReadLogsAction)).
 | 
								Post("/readLogs", new(ReadLogsAction)).
 | 
				
			||||||
			Post("/readAllLogs", new(ReadAllLogsAction)).
 | 
								Post("/readAllLogs", new(ReadAllLogsAction)).
 | 
				
			||||||
 | 
								Post("/fix", new(FixAction)).
 | 
				
			||||||
 | 
								Post("/fixAll", new(FixAllAction)).
 | 
				
			||||||
			EndAll()
 | 
								EndAll()
 | 
				
			||||||
	})
 | 
						})
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,7 +5,6 @@ import (
 | 
				
			|||||||
	"github.com/TeaOSLab/EdgeAdmin/internal/configloaders"
 | 
						"github.com/TeaOSLab/EdgeAdmin/internal/configloaders"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
						"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/configutils"
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/configutils"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/nodeconfigs"
 | 
					 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
 | 
				
			||||||
	"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs"
 | 
						"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs"
 | 
				
			||||||
	"github.com/iwind/TeaGo/maps"
 | 
						"github.com/iwind/TeaGo/maps"
 | 
				
			||||||
@@ -260,72 +259,16 @@ func (this *IndexAction) RunGet(params struct {
 | 
				
			|||||||
	// 是否有用户管理权限
 | 
						// 是否有用户管理权限
 | 
				
			||||||
	this.Data["canVisitUser"] = configloaders.AllowModule(this.AdminId(), configloaders.AdminModuleCodeUser)
 | 
						this.Data["canVisitUser"] = configloaders.AllowModule(this.AdminId(), configloaders.AdminModuleCodeUser)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	// 显示服务相关的日志
 | 
						// 显示服务需要修复的日志数量
 | 
				
			||||||
	errorLogsResp, err := this.RPC().NodeLogRPC().ListNodeLogs(this.AdminContext(), &pb.ListNodeLogsRequest{
 | 
						countNeedFixLogsResp, err := this.RPC().NodeLogRPC().CountNodeLogs(this.AdminContext(), &pb.CountNodeLogsRequest{
 | 
				
			||||||
		NodeId:     0,
 | 
					 | 
				
			||||||
		Role:       nodeconfigs.NodeRoleNode,
 | 
					 | 
				
			||||||
		Offset:     0,
 | 
					 | 
				
			||||||
		Size:       20,
 | 
					 | 
				
			||||||
		Level:      "error,success,warning",
 | 
					 | 
				
			||||||
		FixedState: int32(configutils.BoolStateNo),
 | 
					 | 
				
			||||||
		AllServers: true,
 | 
							AllServers: true,
 | 
				
			||||||
 | 
							FixedState: int32(configutils.BoolStateNo),
 | 
				
			||||||
	})
 | 
						})
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		this.ErrorPage(err)
 | 
							this.ErrorPage(err)
 | 
				
			||||||
		return
 | 
							return
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	errorLogMaps := []maps.Map{}
 | 
						this.Data["countNeedFixLogs"] = countNeedFixLogsResp.Count
 | 
				
			||||||
	for _, errorLog := range errorLogsResp.NodeLogs {
 | 
					 | 
				
			||||||
		serverResp, err := this.RPC().ServerRPC().FindEnabledUserServerBasic(this.AdminContext(), &pb.FindEnabledUserServerBasicRequest{ServerId: errorLog.ServerId})
 | 
					 | 
				
			||||||
		if err != nil {
 | 
					 | 
				
			||||||
			this.ErrorPage(err)
 | 
					 | 
				
			||||||
			return
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		// 服务
 | 
					 | 
				
			||||||
		var server = serverResp.Server
 | 
					 | 
				
			||||||
		if server == nil {
 | 
					 | 
				
			||||||
			// 设置为已修复
 | 
					 | 
				
			||||||
			_, err = this.RPC().NodeLogRPC().FixNodeLogs(this.AdminContext(), &pb.FixNodeLogsRequest{NodeLogIds: []int64{errorLog.Id}})
 | 
					 | 
				
			||||||
			if err != nil {
 | 
					 | 
				
			||||||
				this.ErrorPage(err)
 | 
					 | 
				
			||||||
				return
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			continue
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		// 节点
 | 
					 | 
				
			||||||
		nodeResp, err := this.RPC().NodeRPC().FindEnabledNode(this.AdminContext(), &pb.FindEnabledNodeRequest{NodeId: errorLog.NodeId})
 | 
					 | 
				
			||||||
		if err != nil {
 | 
					 | 
				
			||||||
			this.ErrorPage(err)
 | 
					 | 
				
			||||||
			return
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
		var node = nodeResp.Node
 | 
					 | 
				
			||||||
		if node == nil || node.NodeCluster == nil {
 | 
					 | 
				
			||||||
			// 设置为已修复
 | 
					 | 
				
			||||||
			_, err = this.RPC().NodeLogRPC().FixNodeLogs(this.AdminContext(), &pb.FixNodeLogsRequest{NodeLogIds: []int64{errorLog.Id}})
 | 
					 | 
				
			||||||
			if err != nil {
 | 
					 | 
				
			||||||
				this.ErrorPage(err)
 | 
					 | 
				
			||||||
				return
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
			continue
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		errorLogMaps = append(errorLogMaps, maps.Map{
 | 
					 | 
				
			||||||
			"id":          errorLog.Id,
 | 
					 | 
				
			||||||
			"description": errorLog.Description,
 | 
					 | 
				
			||||||
			"createdTime": timeutil.FormatTime("Y-m-d H:i:s", errorLog.CreatedAt),
 | 
					 | 
				
			||||||
			"serverId":    errorLog.ServerId,
 | 
					 | 
				
			||||||
			"level":       errorLog.Level,
 | 
					 | 
				
			||||||
			"serverName":  server.Name,
 | 
					 | 
				
			||||||
			"nodeId":      node.Id,
 | 
					 | 
				
			||||||
			"nodeName":    node.Name,
 | 
					 | 
				
			||||||
			"clusterId":   node.NodeCluster.Id,
 | 
					 | 
				
			||||||
		})
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	this.Data["errorLogs"] = errorLogMaps
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	this.Show()
 | 
						this.Show()
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -17,7 +17,6 @@ func init() {
 | 
				
			|||||||
			Get("", new(IndexAction)).
 | 
								Get("", new(IndexAction)).
 | 
				
			||||||
			GetPost("/create", new(CreateAction)).
 | 
								GetPost("/create", new(CreateAction)).
 | 
				
			||||||
			GetPost("/update", new(UpdateAction)).
 | 
								GetPost("/update", new(UpdateAction)).
 | 
				
			||||||
			Post("/fixLog", new(FixLogAction)).
 | 
					 | 
				
			||||||
			Post("/nearby", new(NearbyAction)).
 | 
								Post("/nearby", new(NearbyAction)).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			//
 | 
								//
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,5 @@
 | 
				
			|||||||
<first-menu>
 | 
					<first-menu>
 | 
				
			||||||
    <menu-item href="/clusters/logs" code="index">所有</menu-item>
 | 
					    <menu-item href="/clusters/logs" code="index">所有</menu-item>
 | 
				
			||||||
    <menu-item href="/clusters/logs?type=unread" code="unread">未读<span :class="{red: countUnreadLogs > 0}">({{countUnreadLogs}})</span></menu-item>
 | 
					    <menu-item href="/clusters/logs?type=unread" code="unread">未读<span :class="{red: countUnreadLogs > 0}">({{countUnreadLogs}})</span></menu-item>
 | 
				
			||||||
 | 
					    <menu-item href="/clusters/logs?type=needFix" code="needFix">需修复<span :class="{red: countNeedFixLogs > 0}">({{countNeedFixLogs}})</span></menu-item>
 | 
				
			||||||
</first-menu>
 | 
					</first-menu>
 | 
				
			||||||
@@ -46,6 +46,7 @@
 | 
				
			|||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
</form>
 | 
					</form>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<!-- 未读操作 -->
 | 
				
			||||||
<div v-if="type == 'unread'">
 | 
					<div v-if="type == 'unread'">
 | 
				
			||||||
    <div class="ui divider" style="margin-bottom: 0"></div>
 | 
					    <div class="ui divider" style="margin-bottom: 0"></div>
 | 
				
			||||||
    <second-menu v-if="logs.length > 0">
 | 
					    <second-menu v-if="logs.length > 0">
 | 
				
			||||||
@@ -54,7 +55,17 @@
 | 
				
			|||||||
    </second-menu>
 | 
					    </second-menu>
 | 
				
			||||||
</div>
 | 
					</div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<p class="comment" v-if="logs.length == 0">暂时还没有日志。</p>
 | 
					<!-- 未修复操作 -->
 | 
				
			||||||
 | 
					<div v-if="type == 'needFix'">
 | 
				
			||||||
 | 
					    <div class="ui divider" style="margin-bottom: 0"></div>
 | 
				
			||||||
 | 
					    <second-menu v-if="logs.length > 0">
 | 
				
			||||||
 | 
					        <a href="" class="item" @click.prevent="fixPageLogs()">[本页已修复]</a>
 | 
				
			||||||
 | 
					        <a href="" class="item" @click.prevent="fixAllLogs()">[全部已修复]</a>
 | 
				
			||||||
 | 
					    </second-menu>
 | 
				
			||||||
 | 
					    <p class="ui message" v-if="logs.length > 0">已合并重复内容,当前显示数据和总数量可能不一致。</p>
 | 
				
			||||||
 | 
					</div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<p class="comment" v-if="logs.length == 0">暂时还没有<span v-if="type == 'unread'">未读</span><span v-if="type == 'needFix'">需修复</span>日志。</p>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<table class="ui table selectable celled" v-if="logs.length > 0">
 | 
					<table class="ui table selectable celled" v-if="logs.length > 0">
 | 
				
			||||||
    <thead>
 | 
					    <thead>
 | 
				
			||||||
@@ -62,7 +73,7 @@
 | 
				
			|||||||
            <th>集群</th>
 | 
					            <th>集群</th>
 | 
				
			||||||
            <th>节点</th>
 | 
					            <th>节点</th>
 | 
				
			||||||
            <th>信息</th>
 | 
					            <th>信息</th>
 | 
				
			||||||
            <th class="one op">操作</th>
 | 
					            <th style="width: 5em">操作</th>
 | 
				
			||||||
        </tr>
 | 
					        </tr>
 | 
				
			||||||
    </thead>
 | 
					    </thead>
 | 
				
			||||||
    <tr v-for="log in logs">
 | 
					    <tr v-for="log in logs">
 | 
				
			||||||
@@ -72,7 +83,8 @@
 | 
				
			|||||||
            <node-log-row :v-log="log" :v-keyword="keyword"></node-log-row>
 | 
					            <node-log-row :v-log="log" :v-keyword="keyword"></node-log-row>
 | 
				
			||||||
        </td>
 | 
					        </td>
 | 
				
			||||||
        <td>
 | 
					        <td>
 | 
				
			||||||
            <a href="" @click.prevent="updateRead(log.id)" v-if="!log.isRead">已读</a>
 | 
					            <a href="" v-if="!log.isFixed" @click.prevent="fixLog(log.id)">已修复</a>
 | 
				
			||||||
 | 
					            <a href="" @click.prevent="updateRead(log.id)" v-if="log.isFixed && !log.isRead">已读</a>
 | 
				
			||||||
        </td>
 | 
					        </td>
 | 
				
			||||||
    </tr>
 | 
					    </tr>
 | 
				
			||||||
</table>
 | 
					</table>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -18,8 +18,43 @@ Tea.context(function () {
 | 
				
			|||||||
		let logIds = this.logs.map(function (v) {
 | 
							let logIds = this.logs.map(function (v) {
 | 
				
			||||||
			return v.id
 | 
								return v.id
 | 
				
			||||||
		})
 | 
							})
 | 
				
			||||||
		teaweb.confirm("确定要设置本页日志为已读吗?", function () {
 | 
							this.$post(".readLogs")
 | 
				
			||||||
			this.$post(".readLogs")
 | 
								.params({
 | 
				
			||||||
 | 
									logIds: logIds
 | 
				
			||||||
 | 
								})
 | 
				
			||||||
 | 
								.success(function () {
 | 
				
			||||||
 | 
									teaweb.reload()
 | 
				
			||||||
 | 
								})
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						this.updateAllRead = function () {
 | 
				
			||||||
 | 
							this.$post(".readAllLogs")
 | 
				
			||||||
 | 
								.params({})
 | 
				
			||||||
 | 
								.success(function () {
 | 
				
			||||||
 | 
									teaweb.reload()
 | 
				
			||||||
 | 
								})
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						this.changeCluster = function (clusterId) {
 | 
				
			||||||
 | 
							this.clusterId = clusterId
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						this.fixLog = function (logId) {
 | 
				
			||||||
 | 
							this.$post(".fixLogs")
 | 
				
			||||||
 | 
								.params({
 | 
				
			||||||
 | 
									logIds: [logId]
 | 
				
			||||||
 | 
								})
 | 
				
			||||||
 | 
								.success(function () {
 | 
				
			||||||
 | 
									teaweb.reload()
 | 
				
			||||||
 | 
								})
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						this.fixPageLogs = function () {
 | 
				
			||||||
 | 
							let logIds = this.logs.map(function (v) {
 | 
				
			||||||
 | 
								return v.id
 | 
				
			||||||
 | 
							})
 | 
				
			||||||
 | 
							teaweb.confirm("确定已修复并消除当前页的问题?", function () {
 | 
				
			||||||
 | 
								this.$post(".fix")
 | 
				
			||||||
				.params({
 | 
									.params({
 | 
				
			||||||
					logIds: logIds
 | 
										logIds: logIds
 | 
				
			||||||
				})
 | 
									})
 | 
				
			||||||
@@ -29,17 +64,12 @@ Tea.context(function () {
 | 
				
			|||||||
		})
 | 
							})
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	this.updateAllRead = function () {
 | 
						this.fixAllLogs = function () {
 | 
				
			||||||
		teaweb.confirm("确定要设置所有日志为已读吗?", function () {
 | 
							teaweb.confirm("确定已修复并消除所有的问题?", function () {
 | 
				
			||||||
			this.$post(".readAllLogs")
 | 
								this.$post(".fixAll")
 | 
				
			||||||
				.params({})
 | 
					 | 
				
			||||||
				.success(function () {
 | 
									.success(function () {
 | 
				
			||||||
					teaweb.reload()
 | 
										teaweb.reload()
 | 
				
			||||||
				})
 | 
									})
 | 
				
			||||||
		})
 | 
							})
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					 | 
				
			||||||
	this.changeCluster = function (clusterId) {
 | 
					 | 
				
			||||||
		this.clusterId = clusterId
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
@@ -2,24 +2,12 @@
 | 
				
			|||||||
{$template "menu"}
 | 
					{$template "menu"}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<!-- 错误日志 -->
 | 
					<!-- 错误日志 -->
 | 
				
			||||||
<div v-if="errorLogs.length > 0">
 | 
					<div v-if="countNeedFixLogs > 0">
 | 
				
			||||||
    <div class="margin"></div>
 | 
					    <div class="margin"></div>
 | 
				
			||||||
    <div class="ui menu tabular attached">
 | 
					
 | 
				
			||||||
        <span class="ui item active"><span class="red">需要修复的错误   <a href="" title="本页已修复" @click.prevent="fixPageLogs"><i class="icon remove small"></i> </a></span></span>
 | 
					    <div class="ui icon message small error">
 | 
				
			||||||
    </div>
 | 
					        <i class="icon warning circle"></i>
 | 
				
			||||||
    <div class="ui segment attached node-logs-box">
 | 
					        <div class="content"><a href="/clusters/logs?type=needFix">有{{countNeedFixLogs}}个网站服务相关的错误需要修复。</a></div>
 | 
				
			||||||
        <div class="ui icon message small" v-for="log in errorLogs" :class="{error: log.level == 'error', success: log.level == 'success'}">
 | 
					 | 
				
			||||||
            <i class="icon warning circle"></i>
 | 
					 | 
				
			||||||
            <div class="content">
 | 
					 | 
				
			||||||
                [{{log.createdTime}}]
 | 
					 | 
				
			||||||
                <a :href="'/clusters/cluster/node?clusterId=' + log.clusterId + '&nodeId=' + log.nodeId">[节点:{{log.nodeName}}]</a>
 | 
					 | 
				
			||||||
                <a :href="'/servers/server/settings?serverId=' + log.serverId"><span v-if="log.serverName.length > 0">[服务:{{log.serverName}}]</span><span v-else>[服务]</span></a>
 | 
					 | 
				
			||||||
                <span v-if="log.level == 'error'">[错误]</span>
 | 
					 | 
				
			||||||
                <span v-if="log.level == 'success'">[成功]</span>
 | 
					 | 
				
			||||||
                {{log.description}}
 | 
					 | 
				
			||||||
            </div>
 | 
					 | 
				
			||||||
            <a href="" title="关闭" @click.prevent="fixLog(log.id)"><i class="ui icon remove small"></i></a>
 | 
					 | 
				
			||||||
        </div>
 | 
					 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
</div>
 | 
					</div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -46,41 +46,4 @@ Tea.context(function () {
 | 
				
			|||||||
	this.showLatest = function () {
 | 
						this.showLatest = function () {
 | 
				
			||||||
		this.latestVisible = !this.latestVisible
 | 
							this.latestVisible = !this.latestVisible
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					 | 
				
			||||||
	/**
 | 
					 | 
				
			||||||
	 * 错误日志相关
 | 
					 | 
				
			||||||
	 */
 | 
					 | 
				
			||||||
	this.fixLog = function (logId) {
 | 
					 | 
				
			||||||
		let that = this
 | 
					 | 
				
			||||||
		teaweb.confirm("确定要关闭此错误提示吗?", function () {
 | 
					 | 
				
			||||||
			that.$post(".fixLog")
 | 
					 | 
				
			||||||
				.params({
 | 
					 | 
				
			||||||
					logIds: logId
 | 
					 | 
				
			||||||
				})
 | 
					 | 
				
			||||||
				.success(function () {
 | 
					 | 
				
			||||||
					teaweb.reload()
 | 
					 | 
				
			||||||
				})
 | 
					 | 
				
			||||||
		})
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	this.fixPageLogs = function () {
 | 
					 | 
				
			||||||
		let logIds = this.errorLogs.map(function (v) {
 | 
					 | 
				
			||||||
			return v.id
 | 
					 | 
				
			||||||
		})
 | 
					 | 
				
			||||||
		if (logIds.length == 0) {
 | 
					 | 
				
			||||||
			teaweb.reload()
 | 
					 | 
				
			||||||
			return
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		let that = this
 | 
					 | 
				
			||||||
		teaweb.confirm("确定要关闭此页错误提示吗?", function () {
 | 
					 | 
				
			||||||
			that.$post(".fixLog")
 | 
					 | 
				
			||||||
				.params({
 | 
					 | 
				
			||||||
					logIds: logIds
 | 
					 | 
				
			||||||
				})
 | 
					 | 
				
			||||||
				.success(function () {
 | 
					 | 
				
			||||||
					teaweb.reload()
 | 
					 | 
				
			||||||
				})
 | 
					 | 
				
			||||||
		})
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
		Reference in New Issue
	
	Block a user