From 9186c90bd834caa39a7ef1be798dd0566a51ecb8 Mon Sep 17 00:00:00 2001 From: Christian Richter Date: Tue, 15 Oct 2024 13:41:06 +0200 Subject: [PATCH 1/9] refactor checker Signed-off-by: Christian Richter --- ocis-pkg/handlers/checker.go | 32 +++++++++++++++++--------------- ocis-pkg/handlers/checkhttp.go | 22 ++++++++++++++++++++++ 2 files changed, 39 insertions(+), 15 deletions(-) create mode 100644 ocis-pkg/handlers/checkhttp.go diff --git a/ocis-pkg/handlers/checker.go b/ocis-pkg/handlers/checker.go index b12825c2b38..d8902897898 100644 --- a/ocis-pkg/handlers/checker.go +++ b/ocis-pkg/handlers/checker.go @@ -17,8 +17,9 @@ type check func(ctx context.Context) error // CheckHandlerConfiguration defines the configuration for the CheckHandler. type CheckHandlerConfiguration struct { + Checks map[string]check + logger log.Logger - checks map[string]check limit int statusFailed int statusSuccess int @@ -27,7 +28,8 @@ type CheckHandlerConfiguration struct { // NewCheckHandlerConfiguration initializes a new CheckHandlerConfiguration. func NewCheckHandlerConfiguration() CheckHandlerConfiguration { return CheckHandlerConfiguration{ - checks: make(map[string]check), + Checks: make(map[string]check), + limit: -1, statusFailed: http.StatusInternalServerError, statusSuccess: http.StatusOK, @@ -42,17 +44,17 @@ func (c CheckHandlerConfiguration) WithLogger(l log.Logger) CheckHandlerConfigur // WithCheck sets a check for the CheckHandlerConfiguration. func (c CheckHandlerConfiguration) WithCheck(name string, f check) CheckHandlerConfiguration { - if _, ok := c.checks[name]; ok { + if _, ok := c.Checks[name]; ok { c.logger.Panic().Str("check", name).Msg("check already exists") } - c.checks[name] = f + c.Checks[name] = f return c } // WithInheritedChecksFrom appends the checks from another CheckHandlerConfiguration. func (c CheckHandlerConfiguration) WithInheritedChecksFrom(other CheckHandlerConfiguration) CheckHandlerConfiguration { - for name, check := range other.checks { + for name, check := range other.Checks { c.WithCheck(name, check) } @@ -79,27 +81,27 @@ func (c CheckHandlerConfiguration) WithStatusSuccess(status int) CheckHandlerCon // CheckHandler is a http Handler that performs different checks. type CheckHandler struct { - conf CheckHandlerConfiguration + Conf CheckHandlerConfiguration } // NewCheckHandler initializes a new CheckHandler. func NewCheckHandler(c CheckHandlerConfiguration) *CheckHandler { - c.checks = maps.Clone(c.checks) // prevent check duplication after initialization + c.Checks = maps.Clone(c.Checks) // prevent check duplication after initialization return &CheckHandler{ - conf: c, + Conf: c, } } // AddCheck adds a check to the CheckHandler. func (h *CheckHandler) AddCheck(name string, c check) { - h.conf.WithCheck(name, c) + h.Conf.WithCheck(name, c) } func (h *CheckHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) { g, ctx := errgroup.WithContext(r.Context()) - g.SetLimit(h.conf.limit) + g.SetLimit(h.Conf.limit) - for name, check := range h.conf.checks { + for name, check := range h.Conf.Checks { checker := check checkerName := name g.Go(func() error { // https://go.dev/blog/loopvar-preview per iteration scope since go 1.22 @@ -111,16 +113,16 @@ func (h *CheckHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) { }) } - status := h.conf.statusSuccess + status := h.Conf.statusSuccess if err := g.Wait(); err != nil { - status = h.conf.statusFailed - h.conf.logger.Error().Err(err).Msg("check failed") + status = h.Conf.statusFailed + h.Conf.logger.Error().Err(err).Msg("check failed") } w.Header().Set("Content-Type", "text/plain") w.WriteHeader(status) if _, err := io.WriteString(w, http.StatusText(status)); err != nil { // io.WriteString should not fail, but if it does, we want to know. - h.conf.logger.Panic().Err(err).Msg("failed to write response") + h.Conf.logger.Panic().Err(err).Msg("failed to write response") } } diff --git a/ocis-pkg/handlers/checkhttp.go b/ocis-pkg/handlers/checkhttp.go new file mode 100644 index 00000000000..a23e5076ffb --- /dev/null +++ b/ocis-pkg/handlers/checkhttp.go @@ -0,0 +1,22 @@ +package handlers + +import ( + "context" + "fmt" + "net/http" + "time" +) + +// NewHttpCheck checks the reachability of a http server. +func NewHTTPCheck(url string) func(context.Context) error { + return func(_ context.Context) error { + c := http.Client{ + Timeout: 3 * time.Second, + } + _, err := c.Get(url) + if err != nil { + return fmt.Errorf("could not connect to http server: %v", err) + } + return nil + } +} From c11b18c833a85d3c45426360bdfbe3d9200058cc Mon Sep 17 00:00:00 2001 From: Christian Richter Date: Tue, 15 Oct 2024 13:41:31 +0200 Subject: [PATCH 2/9] refactor web & activitylog checks Signed-off-by: Christian Richter --- .../activitylog/pkg/server/debug/server.go | 6 ++++-- services/web/pkg/server/debug/server.go | 21 ++----------------- 2 files changed, 6 insertions(+), 21 deletions(-) diff --git a/services/activitylog/pkg/server/debug/server.go b/services/activitylog/pkg/server/debug/server.go index 09218a407bd..20a332f7863 100644 --- a/services/activitylog/pkg/server/debug/server.go +++ b/services/activitylog/pkg/server/debug/server.go @@ -14,13 +14,15 @@ func Server(opts ...Option) (*http.Server, error) { healthHandler := handlers.NewCheckHandler( handlers.NewCheckHandlerConfiguration(). - WithLogger(options.Logger), + WithLogger(options.Logger). + WithCheck("http reachability", handlers.NewHTTPCheck(options.Config.HTTP.Addr)), ) readyHandler := handlers.NewCheckHandler( handlers.NewCheckHandlerConfiguration(). WithLogger(options.Logger). - WithCheck("nats reachability", handlers.NewNatsCheck(options.Config.Events.Cluster)), + WithCheck("nats reachability", handlers.NewNatsCheck(options.Config.Events.Cluster)). + WithInheritedChecksFrom(healthHandler.Conf), ) return debug.NewService( diff --git a/services/web/pkg/server/debug/server.go b/services/web/pkg/server/debug/server.go index f5c6bd5a9b8..77810811d17 100644 --- a/services/web/pkg/server/debug/server.go +++ b/services/web/pkg/server/debug/server.go @@ -1,14 +1,10 @@ package debug import ( - "context" - "fmt" - "net" - "net/http" - "github.com/owncloud/ocis/v2/ocis-pkg/handlers" "github.com/owncloud/ocis/v2/ocis-pkg/service/debug" "github.com/owncloud/ocis/v2/ocis-pkg/version" + "net/http" ) // Server initializes the debug service and server. @@ -17,20 +13,7 @@ func Server(opts ...Option) (*http.Server, error) { checkHandler := handlers.NewCheckHandler( handlers.NewCheckHandlerConfiguration(). - WithLogger(options.Logger).WithCheck("web reachability", func(ctx context.Context) error { - conn, err := net.Dial("tcp", options.Config.HTTP.Addr) - defer func(conn net.Conn) { - err := conn.Close() - if err != nil { - return - } - }(conn) - if err != nil { - return fmt.Errorf("could not connect to web server: %v", err) - } - - return nil - }), + WithLogger(options.Logger).WithCheck("web reachability", handlers.NewHTTPCheck(options.Config.HTTP.Addr)), ) return debug.NewService( From 80d619cb8f10d2e5a4afd7cc5aa196a6b506e0ab Mon Sep 17 00:00:00 2001 From: Christian Richter Date: Tue, 15 Oct 2024 13:47:39 +0200 Subject: [PATCH 3/9] add http checks to idp & graph Signed-off-by: Christian Richter --- services/graph/pkg/server/debug/server.go | 3 ++- services/idp/pkg/server/debug/server.go | 15 +++++++++++---- 2 files changed, 13 insertions(+), 5 deletions(-) diff --git a/services/graph/pkg/server/debug/server.go b/services/graph/pkg/server/debug/server.go index 85136a94de8..8d1462a72ac 100644 --- a/services/graph/pkg/server/debug/server.go +++ b/services/graph/pkg/server/debug/server.go @@ -14,7 +14,8 @@ func Server(opts ...Option) (*http.Server, error) { checkHandler := handlers.NewCheckHandler( handlers.NewCheckHandlerConfiguration(). - WithLogger(options.Logger), + WithLogger(options.Logger). + WithCheck("web reachability", handlers.NewHTTPCheck(options.Config.HTTP.Addr)), ) return debug.NewService( diff --git a/services/idp/pkg/server/debug/server.go b/services/idp/pkg/server/debug/server.go index 9d733267855..a06c37c3aef 100644 --- a/services/idp/pkg/server/debug/server.go +++ b/services/idp/pkg/server/debug/server.go @@ -14,7 +14,13 @@ import ( func Server(opts ...Option) (*http.Server, error) { options := newOptions(opts...) - checkHandler := handlers.NewCheckHandler( + healthHandler := handlers.NewCheckHandler( + handlers.NewCheckHandlerConfiguration(). + WithLogger(options.Logger). + WithCheck("http reachability", handlers.NewHTTPCheck(options.Config.HTTP.Addr)), + ) + + readinessHandler := handlers.NewCheckHandler( handlers.NewCheckHandlerConfiguration(). WithLogger(options.Logger). WithCheck("tcp-check", func(ctx context.Context) error { @@ -28,7 +34,8 @@ func Server(opts ...Option) (*http.Server, error) { } return handlers.NewTCPCheck(tcpURL)(ctx) - }), + }). + WithInheritedChecksFrom(healthHandler.Conf), ) return debug.NewService( @@ -39,7 +46,7 @@ func Server(opts ...Option) (*http.Server, error) { debug.Token(options.Config.Debug.Token), debug.Pprof(options.Config.Debug.Pprof), debug.Zpages(options.Config.Debug.Zpages), - debug.Health(checkHandler), - debug.Ready(checkHandler), + debug.Health(healthHandler), + debug.Ready(readinessHandler), ), nil } From 3defed1bc42b5e3fe9c8021fe921e23552fb964d Mon Sep 17 00:00:00 2001 From: Christian Richter Date: Tue, 15 Oct 2024 13:49:22 +0200 Subject: [PATCH 4/9] add http checks to invitations & ocs Signed-off-by: Christian Richter --- services/invitations/pkg/server/debug/server.go | 3 ++- services/ocs/pkg/server/debug/server.go | 3 ++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/services/invitations/pkg/server/debug/server.go b/services/invitations/pkg/server/debug/server.go index e6d7c3b0765..99179d7d48b 100644 --- a/services/invitations/pkg/server/debug/server.go +++ b/services/invitations/pkg/server/debug/server.go @@ -14,7 +14,8 @@ func Server(opts ...Option) (*http.Server, error) { checkHandler := handlers.NewCheckHandler( handlers.NewCheckHandlerConfiguration(). - WithLogger(options.Logger), + WithLogger(options.Logger). + WithCheck("web reachability", handlers.NewHTTPCheck(options.Config.HTTP.Addr)), ) return debug.NewService( diff --git a/services/ocs/pkg/server/debug/server.go b/services/ocs/pkg/server/debug/server.go index e6d7c3b0765..99179d7d48b 100644 --- a/services/ocs/pkg/server/debug/server.go +++ b/services/ocs/pkg/server/debug/server.go @@ -14,7 +14,8 @@ func Server(opts ...Option) (*http.Server, error) { checkHandler := handlers.NewCheckHandler( handlers.NewCheckHandlerConfiguration(). - WithLogger(options.Logger), + WithLogger(options.Logger). + WithCheck("web reachability", handlers.NewHTTPCheck(options.Config.HTTP.Addr)), ) return debug.NewService( From 535df48b54b0f1f1c27dffe807de1eb5e2a5ef54 Mon Sep 17 00:00:00 2001 From: Christian Richter Date: Tue, 15 Oct 2024 13:54:47 +0200 Subject: [PATCH 5/9] add http checks to proxy & settings Signed-off-by: Christian Richter --- services/proxy/pkg/server/debug/server.go | 3 ++- services/settings/pkg/server/debug/server.go | 3 ++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/services/proxy/pkg/server/debug/server.go b/services/proxy/pkg/server/debug/server.go index f7368549624..216135910a6 100644 --- a/services/proxy/pkg/server/debug/server.go +++ b/services/proxy/pkg/server/debug/server.go @@ -18,7 +18,8 @@ func Server(opts ...Option) (*http.Server, error) { checkHandler := handlers.NewCheckHandler( handlers.NewCheckHandlerConfiguration(). - WithLogger(options.Logger), + WithLogger(options.Logger). + WithCheck("web reachability", handlers.NewHTTPCheck(options.Config.HTTP.Addr)), ) var configDumpFunc http.HandlerFunc = configDump(options.Config) diff --git a/services/settings/pkg/server/debug/server.go b/services/settings/pkg/server/debug/server.go index e6d7c3b0765..99179d7d48b 100644 --- a/services/settings/pkg/server/debug/server.go +++ b/services/settings/pkg/server/debug/server.go @@ -14,7 +14,8 @@ func Server(opts ...Option) (*http.Server, error) { checkHandler := handlers.NewCheckHandler( handlers.NewCheckHandlerConfiguration(). - WithLogger(options.Logger), + WithLogger(options.Logger). + WithCheck("web reachability", handlers.NewHTTPCheck(options.Config.HTTP.Addr)), ) return debug.NewService( From dcce0bc9bc4e043da964856995e136a1b198e802 Mon Sep 17 00:00:00 2001 From: Christian Richter Date: Tue, 15 Oct 2024 13:57:39 +0200 Subject: [PATCH 6/9] add http checks to sse & thumbnails Signed-off-by: Christian Richter --- services/sse/pkg/server/debug/server.go | 3 ++- services/thumbnails/pkg/server/debug/server.go | 3 ++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/services/sse/pkg/server/debug/server.go b/services/sse/pkg/server/debug/server.go index 85136a94de8..8d1462a72ac 100644 --- a/services/sse/pkg/server/debug/server.go +++ b/services/sse/pkg/server/debug/server.go @@ -14,7 +14,8 @@ func Server(opts ...Option) (*http.Server, error) { checkHandler := handlers.NewCheckHandler( handlers.NewCheckHandlerConfiguration(). - WithLogger(options.Logger), + WithLogger(options.Logger). + WithCheck("web reachability", handlers.NewHTTPCheck(options.Config.HTTP.Addr)), ) return debug.NewService( diff --git a/services/thumbnails/pkg/server/debug/server.go b/services/thumbnails/pkg/server/debug/server.go index e6d7c3b0765..99179d7d48b 100644 --- a/services/thumbnails/pkg/server/debug/server.go +++ b/services/thumbnails/pkg/server/debug/server.go @@ -14,7 +14,8 @@ func Server(opts ...Option) (*http.Server, error) { checkHandler := handlers.NewCheckHandler( handlers.NewCheckHandlerConfiguration(). - WithLogger(options.Logger), + WithLogger(options.Logger). + WithCheck("web reachability", handlers.NewHTTPCheck(options.Config.HTTP.Addr)), ) return debug.NewService( From d5ef26c912d0b5debdede6727747d88361bcdfef Mon Sep 17 00:00:00 2001 From: Christian Richter Date: Tue, 15 Oct 2024 14:27:49 +0200 Subject: [PATCH 7/9] add http checks to userlog & webdav Signed-off-by: Christian Richter --- services/userlog/pkg/server/debug/server.go | 3 ++- services/webdav/pkg/server/debug/server.go | 3 ++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/services/userlog/pkg/server/debug/server.go b/services/userlog/pkg/server/debug/server.go index 85136a94de8..8d1462a72ac 100644 --- a/services/userlog/pkg/server/debug/server.go +++ b/services/userlog/pkg/server/debug/server.go @@ -14,7 +14,8 @@ func Server(opts ...Option) (*http.Server, error) { checkHandler := handlers.NewCheckHandler( handlers.NewCheckHandlerConfiguration(). - WithLogger(options.Logger), + WithLogger(options.Logger). + WithCheck("web reachability", handlers.NewHTTPCheck(options.Config.HTTP.Addr)), ) return debug.NewService( diff --git a/services/webdav/pkg/server/debug/server.go b/services/webdav/pkg/server/debug/server.go index e6d7c3b0765..99179d7d48b 100644 --- a/services/webdav/pkg/server/debug/server.go +++ b/services/webdav/pkg/server/debug/server.go @@ -14,7 +14,8 @@ func Server(opts ...Option) (*http.Server, error) { checkHandler := handlers.NewCheckHandler( handlers.NewCheckHandlerConfiguration(). - WithLogger(options.Logger), + WithLogger(options.Logger). + WithCheck("web reachability", handlers.NewHTTPCheck(options.Config.HTTP.Addr)), ) return debug.NewService( From e1fb51ea9dae660b69f7d6b16bbe46245bd7453f Mon Sep 17 00:00:00 2001 From: Christian Richter Date: Tue, 15 Oct 2024 14:28:54 +0200 Subject: [PATCH 8/9] add http checks to webfinger Signed-off-by: Christian Richter --- services/webfinger/pkg/server/debug/server.go | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/services/webfinger/pkg/server/debug/server.go b/services/webfinger/pkg/server/debug/server.go index e6d7c3b0765..99179d7d48b 100644 --- a/services/webfinger/pkg/server/debug/server.go +++ b/services/webfinger/pkg/server/debug/server.go @@ -14,7 +14,8 @@ func Server(opts ...Option) (*http.Server, error) { checkHandler := handlers.NewCheckHandler( handlers.NewCheckHandlerConfiguration(). - WithLogger(options.Logger), + WithLogger(options.Logger). + WithCheck("web reachability", handlers.NewHTTPCheck(options.Config.HTTP.Addr)), ) return debug.NewService( From dd59a36344b9e6d122adddbee77428fcf6930916 Mon Sep 17 00:00:00 2001 From: Christian Richter Date: Tue, 15 Oct 2024 14:30:20 +0200 Subject: [PATCH 9/9] fix bug in checkhttp.go Signed-off-by: Christian Richter --- ocis-pkg/handlers/checkhttp.go | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/ocis-pkg/handlers/checkhttp.go b/ocis-pkg/handlers/checkhttp.go index a23e5076ffb..a2af7c14cf7 100644 --- a/ocis-pkg/handlers/checkhttp.go +++ b/ocis-pkg/handlers/checkhttp.go @@ -13,10 +13,11 @@ func NewHTTPCheck(url string) func(context.Context) error { c := http.Client{ Timeout: 3 * time.Second, } - _, err := c.Get(url) + resp, err := c.Get(url) if err != nil { return fmt.Errorf("could not connect to http server: %v", err) } + _ = resp.Body.Close() return nil } }