45 lines
1.0 KiB
Go
45 lines
1.0 KiB
Go
|
|
package helper
|
|||
|
|
|
|||
|
|
import (
|
|||
|
|
"fmt"
|
|||
|
|
"runtime"
|
|||
|
|
"runtime/debug"
|
|||
|
|
"strings"
|
|||
|
|
|
|||
|
|
"github.com/go-admin-team/go-admin-core/logger"
|
|||
|
|
)
|
|||
|
|
|
|||
|
|
// SafeGo 安全地启动一个 goroutine,捕获 panic
|
|||
|
|
func SafeGo(fn func()) {
|
|||
|
|
go func() {
|
|||
|
|
defer func() {
|
|||
|
|
if r := recover(); r != nil {
|
|||
|
|
// 记录 Goroutine ID、panic 信息和堆栈
|
|||
|
|
logger.Error(fmt.Sprintf("Recovered from panic in Goroutine %s: %v\nStack Trace:\n%s", GetGoroutineID(), r, string(debug.Stack())))
|
|||
|
|
}
|
|||
|
|
}()
|
|||
|
|
fn()
|
|||
|
|
}()
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// 获取 Goroutine ID
|
|||
|
|
func GetGoroutineID() string {
|
|||
|
|
buf := make([]byte, 64)
|
|||
|
|
n := runtime.Stack(buf, false)
|
|||
|
|
stack := string(buf[:n])
|
|||
|
|
// 提取 Goroutine ID
|
|||
|
|
id := strings.Split(stack, " ")[1]
|
|||
|
|
return id
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
func SafeGoParam[T any](fn func(T), param T) {
|
|||
|
|
go func() {
|
|||
|
|
defer func() {
|
|||
|
|
if r := recover(); r != nil {
|
|||
|
|
logger.Error(fmt.Sprintf(" SafeGoParam Recovered from panic in Goroutine %s: %v\nStack Trace:\n%s", GetGoroutineID(), r, string(debug.Stack())))
|
|||
|
|
}
|
|||
|
|
}()
|
|||
|
|
fn(param) // 执行传入的函数
|
|||
|
|
}()
|
|||
|
|
}
|