X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/231a86fd3f7e30e9f66d71d92ad7c26578637e37..601b2fc51374b4ae678fc515ecabebf33f49fa70:/services/keep-web/server.go diff --git a/services/keep-web/server.go b/services/keep-web/server.go index 167fbbe5b8..586f6b8057 100644 --- a/services/keep-web/server.go +++ b/services/keep-web/server.go @@ -6,10 +6,12 @@ package main import ( "context" + "net" "net/http" - "git.curoverse.com/arvados.git/sdk/go/ctxlog" - "git.curoverse.com/arvados.git/sdk/go/httpserver" + "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" ) @@ -19,14 +21,26 @@ type server struct { Config *Config } -func (srv *server) Start() error { +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(), logrus.StandardLogger()) - mh := httpserver.Instrument(reg, nil, httpserver.HandlerWithContext(ctx, httpserver.AddRequestIDs(httpserver.LogRequests(h)))) - h.MetricsAPI = mh.ServeAPI(h.Config.ManagementToken, http.NotFoundHandler()) + // Warning: when updating this to use Command() from + // lib/service, make sure to implement an exemption in + // httpserver.HandlerWithDeadline() so large file uploads are + // allowed to take longer than the usual API.RequestTimeout. + // See #13697. + mh := httpserver.Instrument(reg, logger, httpserver.AddRequestIDs(httpserver.LogRequests(h))) + h.MetricsAPI = mh.ServeAPI(h.Config.cluster.ManagementToken, http.NotFoundHandler()) srv.Handler = mh - srv.Addr = srv.Config.Listen + srv.BaseContext = func(net.Listener) context.Context { return ctxlog.Context(context.Background(), logger) } + 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() }