Skip to content

Commit

Permalink
server,autoconfig: automatic configuration via config tasks
Browse files Browse the repository at this point in the history
This change introduces "auto config tasks", a mechanism through which
configuration payloads ("tasks") can be injected into a running SQL
service.

This is driven via the "auto config runner" job that was introduced in
the previous commit. The job listens for the arrival of new
environment/task definitions via a `Provider` interface. When new
environments are known, it spans "env runner" jobs; each waiting for
its own tasks. When new tasks are known, and previous tasks have
completed, the "env runner" job creates a new separate job for the
first next task.

Release note: None
  • Loading branch information
knz committed Mar 11, 2023
1 parent 416beb7 commit 846eba0
Show file tree
Hide file tree
Showing 27 changed files with 1,651 additions and 21 deletions.
1 change: 1 addition & 0 deletions docs/generated/http/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ genrule(
"//pkg/multitenant/mtinfopb:mtinfopb_proto",
"//pkg/multitenant/tenantcapabilities/tenantcapabilitiespb:tenantcapabilitiespb_proto",
"//pkg/roachpb:roachpb_proto",
"//pkg/server/autoconfig/autoconfigpb:autoconfigpb_proto",
"//pkg/server/diagnostics/diagnosticspb:diagnosticspb_proto",
"//pkg/server/serverpb:serverpb_proto",
"//pkg/server/status/statuspb:statuspb_proto",
Expand Down
6 changes: 6 additions & 0 deletions pkg/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -277,6 +277,7 @@ ALL_TESTS = [
"//pkg/security/username:username_disallowed_imports_test",
"//pkg/security/username:username_test",
"//pkg/security:security_test",
"//pkg/server/autoconfig:autoconfig_test",
"//pkg/server/debug/goroutineui:goroutineui_test",
"//pkg/server/debug/pprofui:pprofui_test",
"//pkg/server/debug:debug_test",
Expand Down Expand Up @@ -1432,7 +1433,10 @@ GO_TARGETS = [
"//pkg/security/username:username_test",
"//pkg/security:security",
"//pkg/security:security_test",
"//pkg/server/autoconfig/acprovider:acprovider",
"//pkg/server/autoconfig/autoconfigpb:autoconfigpb",
"//pkg/server/autoconfig:autoconfig",
"//pkg/server/autoconfig:autoconfig_test",
"//pkg/server/debug/goroutineui:goroutineui",
"//pkg/server/debug/goroutineui:goroutineui_test",
"//pkg/server/debug/pprofui:pprofui",
Expand Down Expand Up @@ -2815,6 +2819,8 @@ GET_X_DATA_TARGETS = [
"//pkg/security/username:get_x_data",
"//pkg/server:get_x_data",
"//pkg/server/autoconfig:get_x_data",
"//pkg/server/autoconfig/acprovider:get_x_data",
"//pkg/server/autoconfig/autoconfigpb:get_x_data",
"//pkg/server/debug:get_x_data",
"//pkg/server/debug/goroutineui:get_x_data",
"//pkg/server/debug/pprofui:get_x_data",
Expand Down
1 change: 1 addition & 0 deletions pkg/base/testing_knobs.go
Original file line number Diff line number Diff line change
Expand Up @@ -56,4 +56,5 @@ type TestingKnobs struct {
LOQRecovery ModuleTestingKnobs
KeyVisualizer ModuleTestingKnobs
TenantCapabilitiesTestingKnobs ModuleTestingKnobs
AutoConfig ModuleTestingKnobs
}
1 change: 1 addition & 0 deletions pkg/gen/protobuf.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ PROTOBUF_SRCS = [
"//pkg/repstream/streampb:streampb_go_proto",
"//pkg/roachpb:roachpb_go_proto",
"//pkg/rpc:rpc_go_proto",
"//pkg/server/autoconfig/autoconfigpb:autoconfigpb_go_proto",
"//pkg/server/diagnostics/diagnosticspb:diagnosticspb_go_proto",
"//pkg/server/serverpb:serverpb_go_proto",
"//pkg/server/status/statuspb:statuspb_go_proto",
Expand Down
2 changes: 2 additions & 0 deletions pkg/jobs/jobspb/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ proto_library(
"//pkg/kv/kvpb:kvpb_proto",
"//pkg/multitenant/mtinfopb:mtinfopb_proto",
"//pkg/roachpb:roachpb_proto",
"//pkg/server/autoconfig/autoconfigpb:autoconfigpb_proto",
"//pkg/sql/catalog/descpb:descpb_proto",
"//pkg/sql/sessiondatapb:sessiondatapb_proto",
"//pkg/util/hlc:hlc_proto",
Expand All @@ -54,6 +55,7 @@ go_proto_library(
"//pkg/multitenant/mtinfopb",
"//pkg/roachpb",
"//pkg/security/username", # keep
"//pkg/server/autoconfig/autoconfigpb",
"//pkg/sql/catalog/catpb", # keep
"//pkg/sql/catalog/descpb",
"//pkg/sql/sem/tree", # keep
Expand Down
24 changes: 23 additions & 1 deletion pkg/jobs/jobspb/jobs.proto
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ import "sql/sessiondatapb/session_data.proto";
import "util/hlc/timestamp.proto";
import "clusterversion/cluster_version.proto";
import "google/protobuf/timestamp.proto";
import "server/autoconfig/autoconfigpb/autoconfig.proto";

enum EncryptionMode {
Passphrase = 0;
Expand Down Expand Up @@ -1177,6 +1178,21 @@ message AutoConfigRunnerDetails {
message AutoConfigRunnerProgress {
}

message AutoConfigEnvRunnerDetails {
string env_id = 1 [(gogoproto.customname) = "EnvID", (gogoproto.casttype) = "github.com/cockroachdb/cockroach/pkg/server/autoconfig/autoconfigpb.EnvironmentID"];
}

message AutoConfigEnvRunnerProgress {
}

message AutoConfigTaskDetails {
string env_id = 1 [(gogoproto.customname) = "EnvID", (gogoproto.casttype) = "github.com/cockroachdb/cockroach/pkg/server/autoconfig/autoconfigpb.EnvironmentID"];
cockroach.server.autoconfig.autoconfigpb.Task task = 2 [(gogoproto.nullable) = false];
}

message AutoConfigTaskProgress {
}

message Payload {
string description = 1;
// If empty, the description is assumed to be the statement.
Expand Down Expand Up @@ -1236,6 +1252,8 @@ message Payload {
PollJobsStatsDetails poll_jobs_stats = 39;

AutoConfigRunnerDetails auto_config_runner = 41;
AutoConfigEnvRunnerDetails auto_config_env_runner = 42;
AutoConfigTaskDetails auto_config_task = 43;
}
reserved 26;
// PauseReason is used to describe the reason that the job is currently paused
Expand Down Expand Up @@ -1263,7 +1281,7 @@ message Payload {
// specifies how old such record could get before this job is canceled.
int64 maximum_pts_age = 40 [(gogoproto.casttype) = "time.Duration", (gogoproto.customname) = "MaximumPTSAge"];

// NEXT ID: 42
// NEXT ID: 44
}

message Progress {
Expand Down Expand Up @@ -1306,6 +1324,8 @@ message Progress {
KeyVisualizerProgress keyVisualizerProgress = 27;
PollJobsStatsProgress pollJobsStats = 28;
AutoConfigRunnerProgress auto_config_runner = 29;
AutoConfigEnvRunnerProgress auto_config_env_runner = 30;
AutoConfigTaskProgress auto_config_task = 31;
}

uint64 trace_id = 21 [(gogoproto.nullable) = false, (gogoproto.customname) = "TraceID", (gogoproto.customtype) = "github.com/cockroachdb/cockroach/pkg/util/tracing/tracingpb.TraceID"];
Expand Down Expand Up @@ -1338,6 +1358,8 @@ enum Type {
KEY_VISUALIZER = 18 [(gogoproto.enumvalue_customname) = "TypeKeyVisualizer"];
POLL_JOBS_STATS = 19 [(gogoproto.enumvalue_customname) = "TypePollJobsStats"];
AUTO_CONFIG_RUNNER = 20 [(gogoproto.enumvalue_customname) = "TypeAutoConfigRunner"];
AUTO_CONFIG_ENV_RUNNER = 21 [(gogoproto.enumvalue_customname) = "TypeAutoConfigEnvRunner"];
AUTO_CONFIG_TASK = 22 [(gogoproto.enumvalue_customname) = "TypeAutoConfigTask"];
}

message Job {
Expand Down
30 changes: 29 additions & 1 deletion pkg/jobs/jobspb/wrap.go
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,8 @@ var (
_ Details = SchemaTelemetryDetails{}
_ Details = KeyVisualizerDetails{}
_ Details = AutoConfigRunnerDetails{}
_ Details = AutoConfigEnvRunnerDetails{}
_ Details = AutoConfigTaskDetails{}
)

// ProgressDetails is a marker interface for job progress details proto structs.
Expand All @@ -70,6 +72,8 @@ var (
_ ProgressDetails = SchemaTelemetryProgress{}
_ ProgressDetails = KeyVisualizerProgress{}
_ ProgressDetails = AutoConfigRunnerProgress{}
_ ProgressDetails = AutoConfigEnvRunnerProgress{}
_ ProgressDetails = AutoConfigTaskProgress{}
)

// Type returns the payload's job type and panics if the type is invalid.
Expand Down Expand Up @@ -149,6 +153,8 @@ var AutomaticJobTypes = [...]Type{
TypeAutoSchemaTelemetry,
TypePollJobsStats,
TypeAutoConfigRunner,
TypeAutoConfigEnvRunner,
TypeAutoConfigTask,
TypeKeyVisualizer,
}

Expand Down Expand Up @@ -197,6 +203,10 @@ func DetailsType(d isPayload_Details) (Type, error) {
return TypePollJobsStats, nil
case *Payload_AutoConfigRunner:
return TypeAutoConfigRunner, nil
case *Payload_AutoConfigEnvRunner:
return TypeAutoConfigEnvRunner, nil
case *Payload_AutoConfigTask:
return TypeAutoConfigTask, nil
default:
return TypeUnspecified, errors.Newf("Payload.Type called on a payload with an unknown details type: %T", d)
}
Expand Down Expand Up @@ -238,6 +248,8 @@ var JobDetailsForEveryJobType = map[Type]Details{
TypeKeyVisualizer: KeyVisualizerDetails{},
TypePollJobsStats: PollJobsStatsDetails{},
TypeAutoConfigRunner: AutoConfigRunnerDetails{},
TypeAutoConfigEnvRunner: AutoConfigEnvRunnerDetails{},
TypeAutoConfigTask: AutoConfigTaskDetails{},
}

// WrapProgressDetails wraps a ProgressDetails object in the protobuf wrapper
Expand Down Expand Up @@ -287,6 +299,10 @@ func WrapProgressDetails(details ProgressDetails) interface {
return &Progress_PollJobsStats{PollJobsStats: &d}
case AutoConfigRunnerProgress:
return &Progress_AutoConfigRunner{AutoConfigRunner: &d}
case AutoConfigEnvRunnerProgress:
return &Progress_AutoConfigEnvRunner{AutoConfigEnvRunner: &d}
case AutoConfigTaskProgress:
return &Progress_AutoConfigTask{AutoConfigTask: &d}
default:
panic(errors.AssertionFailedf("WrapProgressDetails: unknown progress type %T", d))
}
Expand Down Expand Up @@ -334,6 +350,10 @@ func (p *Payload) UnwrapDetails() Details {
return *d.PollJobsStats
case *Payload_AutoConfigRunner:
return *d.AutoConfigRunner
case *Payload_AutoConfigEnvRunner:
return *d.AutoConfigEnvRunner
case *Payload_AutoConfigTask:
return *d.AutoConfigTask
default:
return nil
}
Expand Down Expand Up @@ -381,6 +401,10 @@ func (p *Progress) UnwrapDetails() ProgressDetails {
return *d.PollJobsStats
case *Progress_AutoConfigRunner:
return *d.AutoConfigRunner
case *Progress_AutoConfigEnvRunner:
return *d.AutoConfigEnvRunner
case *Progress_AutoConfigTask:
return *d.AutoConfigTask
default:
return nil
}
Expand Down Expand Up @@ -452,6 +476,10 @@ func WrapPayloadDetails(details Details) interface {
return &Payload_PollJobsStats{PollJobsStats: &d}
case AutoConfigRunnerDetails:
return &Payload_AutoConfigRunner{AutoConfigRunner: &d}
case AutoConfigEnvRunnerDetails:
return &Payload_AutoConfigEnvRunner{AutoConfigEnvRunner: &d}
case AutoConfigTaskDetails:
return &Payload_AutoConfigTask{AutoConfigTask: &d}
default:
panic(errors.AssertionFailedf("jobs.WrapPayloadDetails: unknown details type %T", d))
}
Expand Down Expand Up @@ -487,7 +515,7 @@ const (
func (Type) SafeValue() {}

// NumJobTypes is the number of jobs types.
const NumJobTypes = 21
const NumJobTypes = 23

// ChangefeedDetailsMarshaler allows for dependency injection of
// cloud.SanitizeExternalStorageURI to avoid the dependency from this
Expand Down
1 change: 1 addition & 0 deletions pkg/server/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -160,6 +160,7 @@ go_library(
"//pkg/security/securityassets",
"//pkg/security/username",
"//pkg/server/autoconfig",
"//pkg/server/autoconfig/acprovider",
"//pkg/server/debug",
"//pkg/server/diagnostics",
"//pkg/server/diagnostics/diagnosticspb",
Expand Down
48 changes: 46 additions & 2 deletions pkg/server/autoconfig/BUILD.bazel
Original file line number Diff line number Diff line change
@@ -1,16 +1,60 @@
load("//build/bazelutil/unused_checker:unused.bzl", "get_x_data")
load("@io_bazel_rules_go//go:def.bzl", "go_library")
load("@io_bazel_rules_go//go:def.bzl", "go_library", "go_test")

go_library(
name = "autoconfig",
srcs = ["auto_config.go"],
srcs = [
"auto_config.go",
"auto_config_env_runner.go",
"auto_config_task.go",
"doc.go",
"task_markers.go",
"testing_knobs.go",
],
importpath = "github.com/cockroachdb/cockroach/pkg/server/autoconfig",
visibility = ["//visibility:public"],
deps = [
"//pkg/jobs",
"//pkg/jobs/jobspb",
"//pkg/security/username",
"//pkg/server/autoconfig/acprovider",
"//pkg/server/autoconfig/autoconfigpb",
"//pkg/settings/cluster",
"//pkg/sql",
"//pkg/sql/isql",
"//pkg/sql/sessiondata",
"//pkg/util/encoding",
"//pkg/util/log",
"@com_github_cockroachdb_errors//:errors",
"@com_github_cockroachdb_logtags//:logtags",
],
)

go_test(
name = "autoconfig_test",
srcs = [
"auto_config_test.go",
"main_test.go",
"task_markers_test.go",
],
args = ["-test.timeout=295s"],
deps = [
":autoconfig",
"//pkg/base",
"//pkg/clusterversion",
"//pkg/jobs",
"//pkg/security/securityassets",
"//pkg/security/securitytest",
"//pkg/security/username",
"//pkg/server",
"//pkg/server/autoconfig/acprovider",
"//pkg/server/autoconfig/autoconfigpb",
"//pkg/testutils",
"//pkg/testutils/serverutils",
"//pkg/testutils/testcluster",
"//pkg/util/leaktest",
"//pkg/util/randutil",
"@com_github_stretchr_testify//require",
],
)

Expand Down
12 changes: 12 additions & 0 deletions pkg/server/autoconfig/acprovider/BUILD.bazel
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
load("//build/bazelutil/unused_checker:unused.bzl", "get_x_data")
load("@io_bazel_rules_go//go:def.bzl", "go_library")

go_library(
name = "acprovider",
srcs = ["provider.go"],
importpath = "github.com/cockroachdb/cockroach/pkg/server/autoconfig/acprovider",
visibility = ["//visibility:public"],
deps = ["//pkg/server/autoconfig/autoconfigpb"],
)

get_x_data(name = "get_x_data")
78 changes: 78 additions & 0 deletions pkg/server/autoconfig/acprovider/provider.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
// Copyright 2023 The Cockroach Authors.
//
// Use of this software is governed by the Business Source License
// included in the file licenses/BSL.txt.
//
// As of the Change Date specified in that file, in accordance with
// the Business Source License, use of this software will be governed
// by the Apache License, Version 2.0, included in the file
// licenses/APL.txt.

package acprovider

import (
"context"

"github.com/cockroachdb/cockroach/pkg/server/autoconfig/autoconfigpb"
)

// Provider is an interface through which the auto config runner
// can receive new tasks to run.
// For more details, see the package-level documentation for
// package "autoconfig".
type Provider interface {
// EnvUpdate returns a channel that receives a message any time the
// current set of environments change. The channel receives an
// initial event immediately.
EnvUpdate() <-chan struct{}

// ActiveEnvironments returns the IDs of environments that have
// tasks available for execution.
ActiveEnvironments() []autoconfigpb.EnvironmentID

// Peek will block waiting for the first task the provider believes
// still needs to be run for the given environment. It will return
// an error if the context is canceled while waiting. It will
// return ErrNoMoreTasks to indicate the caller does not need
// to process tasks for this environment any more.
Peek(ctx context.Context, env autoconfigpb.EnvironmentID) (autoconfigpb.Task, error)

// Pop will report the completion of all tasks with ID up to
// completed for the given environment.
Pop(ctx context.Context, env autoconfigpb.EnvironmentID, completed autoconfigpb.TaskID) error
}

type errNoMoreTasks struct{}

func (errNoMoreTasks) Error() string { return "no more tasks" }

// ErrNoMoreTasks can be checked with errors.Is on the result of Peek
// when an environment is not providing tasks for the foreseeable future.
var ErrNoMoreTasks error = errNoMoreTasks{}

// NoTaskProvider is a stub provider which delivers no tasks.
type NoTaskProvider struct{}

var _ Provider = NoTaskProvider{}

// EnvUpdate is part of the Provider interface.
func (NoTaskProvider) EnvUpdate() <-chan struct{} {
ch := make(chan struct{}, 1)
ch <- struct{}{}
return ch
}

// ActiveEnvironments is part of the Provider interface.
func (NoTaskProvider) ActiveEnvironments() []autoconfigpb.EnvironmentID { return nil }

// Peek is part of the Provider interface.
func (NoTaskProvider) Peek(
ctx context.Context, _ autoconfigpb.EnvironmentID,
) (autoconfigpb.Task, error) {
return autoconfigpb.Task{}, ErrNoMoreTasks
}

// Pop is part of the Provider interface.
func (NoTaskProvider) Pop(context.Context, autoconfigpb.EnvironmentID, autoconfigpb.TaskID) error {
return nil
}
Loading

0 comments on commit 846eba0

Please sign in to comment.