25 lines
577 B
Go
25 lines
577 B
Go
package server
|
|
|
|
import (
|
|
"bytes"
|
|
"fmt"
|
|
"k8s.io/klog"
|
|
"net/http"
|
|
"runtime"
|
|
)
|
|
|
|
func LogStackOnRecover(panicReason interface{}, httpWriter http.ResponseWriter) {
|
|
var buffer bytes.Buffer
|
|
buffer.WriteString(fmt.Sprintf("recover from panic situation: - %v\r\n", panicReason))
|
|
for i := 2; ; i += 1 {
|
|
_, file, line, ok := runtime.Caller(i)
|
|
if !ok {
|
|
break
|
|
}
|
|
buffer.WriteString(fmt.Sprintf(" %s:%d\r\n", file, line))
|
|
}
|
|
klog.Error(buffer.String())
|
|
httpWriter.WriteHeader(http.StatusInternalServerError)
|
|
httpWriter.Write([]byte("recover from panic situation"))
|
|
}
|