X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/8f76037ba8a37c488612285ffe70d26d0d038124..b39f7a6141ecd5c53531b7705c0496623b4df9e9:/services/keep-web/server.go diff --git a/services/keep-web/server.go b/services/keep-web/server.go index e51376c3bc..8f623c627d 100644 --- a/services/keep-web/server.go +++ b/services/keep-web/server.go @@ -5,7 +5,14 @@ package main import ( - "git.curoverse.com/arvados.git/sdk/go/httpserver" + "context" + "net/http" + + "git.arvados.org/arvados.git/sdk/go/arvados" + "git.arvados.org/arvados.git/sdk/go/ctxlog" + "git.arvados.org/arvados.git/sdk/go/httpserver" + "github.com/prometheus/client_golang/prometheus" + "github.com/sirupsen/logrus" ) type server struct { @@ -13,8 +20,21 @@ type server struct { Config *Config } -func (srv *server) Start() error { - srv.Handler = httpserver.AddRequestIDs(httpserver.LogRequests(nil, &handler{Config: srv.Config})) - srv.Addr = srv.Config.Listen +func (srv *server) Start(logger *logrus.Logger) error { + h := &handler{Config: srv.Config} + reg := prometheus.NewRegistry() + h.Config.Cache.registry = reg + ctx := ctxlog.Context(context.Background(), logger) + mh := httpserver.Instrument(reg, logger, httpserver.HandlerWithContext(ctx, httpserver.AddRequestIDs(httpserver.LogRequests(h)))) + h.MetricsAPI = mh.ServeAPI(h.Config.cluster.ManagementToken, http.NotFoundHandler()) + srv.Handler = mh + var listen arvados.URL + for listen = range srv.Config.cluster.Services.WebDAV.InternalURLs { + break + } + if len(srv.Config.cluster.Services.WebDAV.InternalURLs) > 1 { + logrus.Warn("Services.WebDAV.InternalURLs has more than one key; picked: ", listen) + } + srv.Addr = listen.Host return srv.Server.Start() }