diff --git a/server/embed/config_test.go b/server/embed/config_test.go index cf18a5ec55cf..27505978dfc5 100644 --- a/server/embed/config_test.go +++ b/server/embed/config_test.go @@ -105,6 +105,7 @@ func TestConfigFileFeatureGates(t *testing.T) { expectedFeatures: map[featuregate.Feature]bool{ features.DistributedTracing: false, features.StopGRPCServiceOnDefrag: false, + features.InitialCorruptCheck: false, }, }, { @@ -120,6 +121,7 @@ func TestConfigFileFeatureGates(t *testing.T) { expectedFeatures: map[featuregate.Feature]bool{ features.DistributedTracing: true, features.StopGRPCServiceOnDefrag: true, + features.InitialCorruptCheck: false, }, }, { @@ -128,6 +130,7 @@ func TestConfigFileFeatureGates(t *testing.T) { expectedFeatures: map[featuregate.Feature]bool{ features.StopGRPCServiceOnDefrag: true, features.DistributedTracing: false, + features.InitialCorruptCheck: false, }, }, { @@ -136,6 +139,7 @@ func TestConfigFileFeatureGates(t *testing.T) { expectedFeatures: map[featuregate.Feature]bool{ features.StopGRPCServiceOnDefrag: false, features.DistributedTracing: false, + features.InitialCorruptCheck: false, }, }, { @@ -144,6 +148,7 @@ func TestConfigFileFeatureGates(t *testing.T) { expectedFeatures: map[featuregate.Feature]bool{ features.StopGRPCServiceOnDefrag: true, features.DistributedTracing: false, + features.InitialCorruptCheck: false, }, }, { @@ -152,6 +157,7 @@ func TestConfigFileFeatureGates(t *testing.T) { expectedFeatures: map[featuregate.Feature]bool{ features.StopGRPCServiceOnDefrag: false, features.DistributedTracing: false, + features.InitialCorruptCheck: false, }, }, } diff --git a/server/embed/etcd.go b/server/embed/etcd.go index 2970a804d110..80cc1cc3bf21 100644 --- a/server/embed/etcd.go +++ b/server/embed/etcd.go @@ -48,6 +48,7 @@ import ( "go.etcd.io/etcd/server/v3/etcdserver" "go.etcd.io/etcd/server/v3/etcdserver/api/etcdhttp" "go.etcd.io/etcd/server/v3/etcdserver/api/rafthttp" + "go.etcd.io/etcd/server/v3/features" "go.etcd.io/etcd/server/v3/storage" "go.etcd.io/etcd/server/v3/verify" ) @@ -203,7 +204,6 @@ func StartEtcd(inCfg *Config) (e *Etcd, err error) { TokenTTL: cfg.AuthTokenTTL, CORS: cfg.CORS, HostWhitelist: cfg.HostWhitelist, - InitialCorruptCheck: cfg.ExperimentalInitialCorruptCheck, CorruptCheckTime: cfg.ExperimentalCorruptCheckTime, CompactHashCheckEnabled: cfg.ExperimentalCompactHashCheckEnabled, CompactHashCheckTime: cfg.ExperimentalCompactHashCheckTime, @@ -259,7 +259,7 @@ func StartEtcd(inCfg *Config) (e *Etcd, err error) { // newly started member ("memberInitialized==false") // does not need corruption check - if memberInitialized && srvcfg.InitialCorruptCheck { + if memberInitialized && srvcfg.ServerFeatureGate.Enabled(features.InitialCorruptCheck) { if err = e.Server.CorruptionChecker().InitialCheck(); err != nil { // set "EtcdServer" to nil, so that it does not block on "EtcdServer.Close()" // (nothing to close since rafthttp transports have not been started) diff --git a/server/features/etcd_features.go b/server/features/etcd_features.go index d6804f2d048b..0e5678014c53 100644 --- a/server/features/etcd_features.go +++ b/server/features/etcd_features.go @@ -45,18 +45,25 @@ const ( // alpha: v3.6 // main PR: https://github.com/etcd-io/etcd/pull/18279 StopGRPCServiceOnDefrag featuregate.Feature = "StopGRPCServiceOnDefrag" + // InitialCorruptCheck enable to check data corruption before serving any client/peer traffic. + // owner: @ + // alpha: v3.6 + // main PR: https://github.com/etcd-io/etcd/pull/10524 + InitialCorruptCheck featuregate.Feature = "InitialCorruptCheck" ) var ( DefaultEtcdServerFeatureGates = map[featuregate.Feature]featuregate.FeatureSpec{ DistributedTracing: {Default: false, PreRelease: featuregate.Alpha}, StopGRPCServiceOnDefrag: {Default: false, PreRelease: featuregate.Alpha}, + InitialCorruptCheck: {Default: false, PreRelease: featuregate.Alpha}, } // ExperimentalFlagToFeatureMap is the map from the cmd line flags of experimental features // to their corresponding feature gates. // Deprecated: only add existing experimental features here. DO NOT use for new features. ExperimentalFlagToFeatureMap = map[string]featuregate.Feature{ "experimental-stop-grpc-service-on-defrag": StopGRPCServiceOnDefrag, + "experimental-initial-corrupt-check": InitialCorruptCheck, } )