From 044f6b581de36f43036e154b8de7939b3c510aae Mon Sep 17 00:00:00 2001 From: Brad Davidson Date: Fri, 22 Sep 2023 06:54:03 +0000 Subject: [PATCH] Disable HTTP on main etcd client port Fixes performance issue under load, ref: https://github.com/etcd-io/etcd/issues/15402 and https://github.com/kubernetes/kubernetes/pull/118460 Signed-off-by: Brad Davidson (cherry picked from commit 8c73fd670b4aa953e4011f6d6d8595c1b321939b) Signed-off-by: Brad Davidson --- pkg/daemons/executor/executor.go | 1 + pkg/etcd/etcd.go | 16 ++++++++++++++++ 2 files changed, 17 insertions(+) diff --git a/pkg/daemons/executor/executor.go b/pkg/daemons/executor/executor.go index c8ff45aaff24..e59b81ea99b8 100644 --- a/pkg/daemons/executor/executor.go +++ b/pkg/daemons/executor/executor.go @@ -37,6 +37,7 @@ type ETCDConfig struct { InitialOptions `json:",inline"` Name string `json:"name,omitempty"` ListenClientURLs string `json:"listen-client-urls,omitempty"` + ListenClientHTTPURLs string `json:"listen-client-http-urls,omitempty"` ListenMetricsURLs string `json:"listen-metrics-urls,omitempty"` ListenPeerURLs string `json:"listen-peer-urls,omitempty"` AdvertiseClientURLs string `json:"advertise-client-urls,omitempty"` diff --git a/pkg/etcd/etcd.go b/pkg/etcd/etcd.go index 07dc1bcaccbd..cb21a0a3dfa3 100644 --- a/pkg/etcd/etcd.go +++ b/pkg/etcd/etcd.go @@ -881,6 +881,14 @@ func (e *ETCD) listenMetricsURLs(reset bool) string { return metricsURLs } +// listenClientHTTPURLs returns a list of URLs to bind to for http client connections. +// This should no longer be used, but we must set it in order to free the listen URLs +// for dedicated use by GRPC. +// Ref: https://github.com/etcd-io/etcd/issues/15402 +func (e *ETCD) listenClientHTTPURLs() string { + return fmt.Sprintf("https://%s:2382", e.config.Loopback(true)) +} + // cluster calls the executor to start etcd running with the provided configuration. func (e *ETCD) cluster(ctx context.Context, reset bool, options executor.InitialOptions) error { ctx, e.cancel = context.WithCancel(ctx) @@ -911,6 +919,7 @@ func (e *ETCD) cluster(ctx context.Context, reset bool, options executor.Initial Logger: "zap", LogOutputs: []string{"stderr"}, ExperimentalInitialCorruptCheck: true, + ListenClientHTTPURLs: e.listenClientHTTPURLs(), }, e.config.ExtraEtcdArgs) } @@ -949,10 +958,16 @@ func (e *ETCD) StartEmbeddedTemporary(ctx context.Context) error { endpoints := getEndpoints(e.config) clientURL := endpoints[0] + // peer URL is usually 1 more than client peerURL, err := addPort(endpoints[0], 1) if err != nil { return err } + // client http URL is usually 3 more than client, after peer and metrics + clientHTTPURL, err := addPort(endpoints[0], 3) + if err != nil { + return err + } embedded := executor.Embedded{} ctx, e.cancel = context.WithCancel(ctx) @@ -962,6 +977,7 @@ func (e *ETCD) StartEmbeddedTemporary(ctx context.Context) error { ForceNewCluster: true, AdvertiseClientURLs: clientURL, ListenClientURLs: clientURL, + ListenClientHTTPURLs: clientHTTPURL, ListenPeerURLs: peerURL, Logger: "zap", HeartbeatInterval: 500,