mirror of
https://github.com/go-gitea/gitea.git
synced 2025-10-24 09:59:54 +02:00
1. Add a OpenTelemetry-like shim-layer to collect traces 2. Add a simple builtin trace collector and exporter, end users could download the diagnosis report to get the traces. This PR's design is quite lightweight, no hard-dependency, and it is easy to improve or remove. We can try it on gitea.com first to see whether it works well, and fine tune the details. --------- Co-authored-by: silverwind <me@silverwind.io>
54 lines
1.7 KiB
Go
54 lines
1.7 KiB
Go
// Copyright 2023 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package admin
|
|
|
|
import (
|
|
"net/http"
|
|
"runtime"
|
|
|
|
"code.gitea.io/gitea/modules/process"
|
|
"code.gitea.io/gitea/modules/setting"
|
|
"code.gitea.io/gitea/services/context"
|
|
)
|
|
|
|
func monitorTraceCommon(ctx *context.Context) {
|
|
ctx.Data["Title"] = ctx.Tr("admin.monitor")
|
|
ctx.Data["PageIsAdminMonitorTrace"] = true
|
|
// Hide the performance trace tab in production, because it shows a lot of SQLs and is not that useful for end users.
|
|
// To avoid confusing end users, do not let them know this tab. End users should "download diagnosis report" instead.
|
|
ctx.Data["ShowAdminPerformanceTraceTab"] = !setting.IsProd
|
|
}
|
|
|
|
// Stacktrace show admin monitor goroutines page
|
|
func Stacktrace(ctx *context.Context) {
|
|
monitorTraceCommon(ctx)
|
|
|
|
ctx.Data["GoroutineCount"] = runtime.NumGoroutine()
|
|
|
|
show := ctx.FormString("show")
|
|
ctx.Data["ShowGoroutineList"] = show
|
|
// by default, do not do anything which might cause server errors, to avoid unnecessary 500 pages.
|
|
// this page is the entrance of the chance to collect diagnosis report.
|
|
if show != "" {
|
|
showNoSystem := show == "process"
|
|
processStacks, processCount, _, err := process.GetManager().ProcessStacktraces(false, showNoSystem)
|
|
if err != nil {
|
|
ctx.ServerError("GoroutineStacktrace", err)
|
|
return
|
|
}
|
|
|
|
ctx.Data["ProcessStacks"] = processStacks
|
|
ctx.Data["ProcessCount"] = processCount
|
|
}
|
|
|
|
ctx.HTML(http.StatusOK, tplStacktrace)
|
|
}
|
|
|
|
// StacktraceCancel cancels a process
|
|
func StacktraceCancel(ctx *context.Context) {
|
|
pid := ctx.PathParam("pid")
|
|
process.GetManager().Cancel(process.IDType(pid))
|
|
ctx.JSONRedirect(setting.AppSubURL + "/-/admin/monitor/stacktrace")
|
|
}
|