mirror of
https://github.com/zeromicro/go-zero.git
synced 2025-01-23 17:20:24 +08:00
34 lines
611 B
Go
34 lines
611 B
Go
package rescue
|
|
|
|
import (
|
|
"context"
|
|
"runtime/debug"
|
|
|
|
"github.com/zeromicro/go-zero/core/logx"
|
|
)
|
|
|
|
// Recover is used with defer to do cleanup on panics.
|
|
// Use it like:
|
|
//
|
|
// defer Recover(func() {})
|
|
func Recover(cleanups ...func()) {
|
|
for _, cleanup := range cleanups {
|
|
cleanup()
|
|
}
|
|
|
|
if p := recover(); p != nil {
|
|
logx.ErrorStack(p)
|
|
}
|
|
}
|
|
|
|
// RecoverCtx is used with defer to do cleanup on panics.
|
|
func RecoverCtx(ctx context.Context, cleanups ...func()) {
|
|
for _, cleanup := range cleanups {
|
|
cleanup()
|
|
}
|
|
|
|
if p := recover(); p != nil {
|
|
logx.WithContext(ctx).Errorf("%+v\n%s", p, debug.Stack())
|
|
}
|
|
}
|