mirror of
https://github.com/rancher/norman.git
synced 2025-04-28 03:20:08 +00:00
Log panics as error
The defaul http server logs panics to the server's log handler. That goes to debug level and thus panics are not seen when running rancher at a normal log level. This fixes the problem by catching the panic at the top level norman http handler and logging them as errors there.
This commit is contained in:
parent
5078dd2c63
commit
b694ecb0eb
@ -2,6 +2,7 @@ package api
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
"runtime/debug"
|
||||
"sync"
|
||||
|
||||
"github.com/rancher/norman/api/access"
|
||||
@ -14,6 +15,7 @@ import (
|
||||
"github.com/rancher/norman/parse"
|
||||
"github.com/rancher/norman/store/wrapper"
|
||||
"github.com/rancher/norman/types"
|
||||
"github.com/sirupsen/logrus"
|
||||
)
|
||||
|
||||
type StoreWrapper func(types.Store) types.Store
|
||||
@ -168,6 +170,13 @@ func (s *Server) setupDefaults(schema *types.Schema) {
|
||||
}
|
||||
|
||||
func (s *Server) ServeHTTP(rw http.ResponseWriter, req *http.Request) {
|
||||
defer func() {
|
||||
if err := recover(); err != nil && err != http.ErrAbortHandler {
|
||||
logrus.Error("Panic serving api request: \n" + string(debug.Stack()))
|
||||
rw.WriteHeader(http.StatusInternalServerError)
|
||||
}
|
||||
}()
|
||||
|
||||
if apiResponse, err := s.handle(rw, req); err != nil {
|
||||
s.handleError(apiResponse, err)
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user