Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

PMM-12712 Shards collector. #2701

Merged
merged 35 commits into from
Jan 15, 2024
Merged
Show file tree
Hide file tree
Changes from 30 commits
Commits
Show all changes
35 commits
Select commit Hold shift + click to select a range
8a5b5a5
PMM-12712 Add sharded collection into HR resolution.
JiriCtvrtka Dec 15, 2023
0979dfe
PMM-12712 Sharded collector.
JiriCtvrtka Dec 18, 2023
746b96b
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Dec 18, 2023
575646a
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Dec 18, 2023
35ec24d
PMM-12712 Fix tests.
JiriCtvrtka Dec 18, 2023
b8e4a40
Merge remote-tracking branch 'origin/PMM-12712-shards-info' into PMM-…
JiriCtvrtka Dec 18, 2023
6c15ddd
PMM-12712 Fix VM test.
JiriCtvrtka Dec 18, 2023
29d859b
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Dec 19, 2023
c7fa173
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Dec 21, 2023
8eae688
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Dec 22, 2023
56c55ef
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Jan 2, 2024
3905c4f
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Jan 8, 2024
0a70d19
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Jan 8, 2024
45d6ceb
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Jan 8, 2024
84b92c4
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Jan 8, 2024
67f8380
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Jan 8, 2024
16c1f11
PMM-12712 Renaming.
JiriCtvrtka Jan 8, 2024
7383ea4
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Jan 9, 2024
513da6b
PMM-12712 Remove unclear comments.
JiriCtvrtka Jan 9, 2024
d3d6c57
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Jan 9, 2024
fe1f0cb
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Jan 9, 2024
7dbdb0d
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Jan 10, 2024
28bb907
PMM-12712 Check for 2.41.1 version.
JiriCtvrtka Jan 10, 2024
a09134a
PMM-12712 Small change.
JiriCtvrtka Jan 10, 2024
9769e95
PMM-12712 Version check for scrape config for VM.
JiriCtvrtka Jan 10, 2024
a28a6cb
PMM-12712 VM test.
JiriCtvrtka Jan 10, 2024
3b2a67a
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Jan 10, 2024
cb9eb30
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Jan 10, 2024
4d52e5c
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Jan 10, 2024
5885134
PMM-12712 Fix version check for QA versions.
JiriCtvrtka Jan 10, 2024
8e05324
PMM-12712 Small renaming.
JiriCtvrtka Jan 10, 2024
19ea041
PMM-12712 Few more versions in test.
JiriCtvrtka Jan 10, 2024
3b64632
PMM-12712 Lint.
JiriCtvrtka Jan 10, 2024
6121ff2
PMM-12712 Simplify check.
JiriCtvrtka Jan 10, 2024
cde1aa1
Merge branch 'main' into PMM-12712-shards-info
JiriCtvrtka Jan 15, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 8 additions & 4 deletions managed/services/agents/mongodb.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ var (
newMongoExporterPMMVersion = version.MustParse("2.9.99")
v2_24_99 = version.MustParse("2.24.99")
v2_25_99 = version.MustParse("2.25.99")
v2_41_2 = version.MustParse("2.41.2")
)

// mongodbExporterConfig returns desired configuration of mongodb_exporter process.
Expand All @@ -54,7 +55,14 @@ func mongodbExporterConfig(node *models.Node, service *models.Service, exporter
// Starting with PMM 2.25.0, we change the discovering-mode making it to discover all databases.
// Until now, discovering mode was not working properly and was enabled only if mongodb.collstats-colls=
// was specified in the command line.
// Starting with PMM 2.41.1 we added shards collector.
switch {
case strings.Contains(pmmAgentVersion.String(), "2.41.1") || !pmmAgentVersion.Less(v2_41_2): // >= 2.41.1
args = v226Args(exporter, tdp, listenAddress)

if exporter.MongoDBOptions != nil && exporter.MongoDBOptions.EnableAllCollectors {
args = append(args, "--collector.shards")
}
case !pmmAgentVersion.Less(v2_25_99): // >= 2.26
args = v226Args(exporter, tdp, listenAddress)
case !pmmAgentVersion.Less(v2_24_99): // >= 2.25
Expand Down Expand Up @@ -232,22 +240,18 @@ func defaultCollectors(collectAll bool) map[string]collectorArgs {
enabled: true,
enableParam: "--collector.replicasetstatus",
},
// disabled until we have better information on the resources usage impact
"collstats": {
enabled: collectAll,
enableParam: "--collector.collstats",
},
// disabled until we have better information on the resources usage impact
"dbstats": {
enabled: collectAll,
enableParam: "--collector.dbstats",
},
// disabled until we have better information on the resources usage impact
"indexstats": {
enabled: collectAll,
enableParam: "--collector.indexstats",
},
// disabled until we have better information on the resources usage impact
"topmetrics": {
enabled: collectAll,
enableParam: "--collector.topmetrics",
Expand Down
193 changes: 193 additions & 0 deletions managed/services/agents/mongodb_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -231,6 +231,199 @@ func TestMongodbExporterConfig226(t *testing.T) {
})
}

func Test241PatchVersion(t *testing.T) {
versions := map[string]bool{
"2.43.0": true,
"2.42.2": true,
"2.41.1": true,
"2.41.1-HEAD-xyz": true,
"2.41.0": false,
}
for pmmVersion, shardsCompatibility := range versions {
pmmAgentVersion := version.MustParse(pmmVersion)
node := &models.Node{
Address: "1.2.3.4",
}
mongodb := &models.Service{
Address: pointer.ToString("1.2.3.4"),
Port: pointer.ToUint16(27017),
}
exporter := &models.Agent{
AgentID: "agent-id",
AgentType: models.MongoDBExporterType,
Username: pointer.ToString("username"),
Password: pointer.ToString("s3cur3 p@$$w0r4."),
AgentPassword: pointer.ToString("agent-password"),
}
exporter.MongoDBOptions = &models.MongoDBOptions{
EnableAllCollectors: true,
}
actual, err := mongodbExporterConfig(node, mongodb, exporter, exposeSecrets, pmmAgentVersion)
require.NoError(t, err)
if shardsCompatibility {
require.Contains(t, actual.Args, "--collector.shards")
} else {
require.NotContains(t, actual.Args, "--collector.shards")
}

JiriCtvrtka marked this conversation as resolved.
Show resolved Hide resolved
JiriCtvrtka marked this conversation as resolved.
Show resolved Hide resolved
}
}

func TestMongodbExporterConfig2411(t *testing.T) {
pmmAgentVersion := version.MustParse("2.41.1")
BupycHuk marked this conversation as resolved.
Show resolved Hide resolved
node := &models.Node{
Address: "1.2.3.4",
}
mongodb := &models.Service{
Address: pointer.ToString("1.2.3.4"),
Port: pointer.ToUint16(27017),
}
exporter := &models.Agent{
AgentID: "agent-id",
AgentType: models.MongoDBExporterType,
Username: pointer.ToString("username"),
Password: pointer.ToString("s3cur3 p@$$w0r4."),
AgentPassword: pointer.ToString("agent-password"),
}
actual, err := mongodbExporterConfig(node, mongodb, exporter, redactSecrets, pmmAgentVersion)
expected := &agentpb.SetStateRequest_AgentProcess{
Type: inventorypb.AgentType_MONGODB_EXPORTER,
TemplateLeftDelim: "{{",
TemplateRightDelim: "}}",
Args: []string{
"--collector.diagnosticdata",
"--collector.replicasetstatus",
"--compatible-mode",
"--discovering-mode",
"--mongodb.global-conn-pool",
"--web.listen-address=0.0.0.0:{{ .listen_port }}",
"--web.config={{ .TextFiles.webConfigPlaceholder }}",
},
Env: []string{
"MONGODB_URI=mongodb://username:s3cur3%20p%[email protected]:27017/?connectTimeoutMS=1000&directConnection=true&serverSelectionTimeoutMS=1000",
},
RedactWords: []string{"s3cur3 p@$$w0r4.", "agent-password"},
TextFiles: map[string]string{
"webConfigPlaceholder": "basic_auth_users:\n pmm: agent-password\n",
},
}
require.NoError(t, err)
requireNoDuplicateFlags(t, actual.Args)
require.Equal(t, expected.Args, actual.Args)
require.Equal(t, expected.Env, actual.Env)
require.Equal(t, expected, actual)

t.Run("Having collstats limit", func(t *testing.T) {
exporter.MongoDBOptions = &models.MongoDBOptions{
StatsCollections: []string{"col1", "col2", "col3"},
CollectionsLimit: 79014,
}
expected.Args = []string{
"--collector.collstats-limit=79014",
"--collector.diagnosticdata",
"--collector.replicasetstatus",
"--compatible-mode",
"--discovering-mode",
"--mongodb.collstats-colls=col1,col2,col3",
"--mongodb.global-conn-pool",
"--mongodb.indexstats-colls=col1,col2,col3",
"--web.listen-address=0.0.0.0:{{ .listen_port }}",
"--web.config={{ .TextFiles.webConfigPlaceholder }}",
}
actual, err := mongodbExporterConfig(node, mongodb, exporter, exposeSecrets, pmmAgentVersion)
require.NoError(t, err)
require.Equal(t, expected.Args, actual.Args)
})

t.Run("Enabling all collectors with non zero limit", func(t *testing.T) {
exporter.MongoDBOptions = &models.MongoDBOptions{
StatsCollections: []string{"col1", "col2", "col3"},
CollectionsLimit: 79014,
EnableAllCollectors: true,
}

expected.Args = []string{
"--collector.collstats",
"--collector.collstats-limit=79014",
"--collector.dbstats",
"--collector.diagnosticdata",
"--collector.indexstats",
"--collector.replicasetstatus",
"--collector.shards",
"--collector.topmetrics",
"--compatible-mode",
"--discovering-mode",
"--mongodb.collstats-colls=col1,col2,col3",
"--mongodb.global-conn-pool",
"--mongodb.indexstats-colls=col1,col2,col3",
"--web.listen-address=0.0.0.0:{{ .listen_port }}",
"--web.config={{ .TextFiles.webConfigPlaceholder }}",
}
actual, err := mongodbExporterConfig(node, mongodb, exporter, exposeSecrets, pmmAgentVersion)
require.NoError(t, err)
require.Equal(t, expected.Args, actual.Args)
})

t.Run("Enabling all collectors", func(t *testing.T) {
exporter.MongoDBOptions = &models.MongoDBOptions{
EnableAllCollectors: true,
StatsCollections: []string{"db1.col1.one", "db2.col2", "db3"},
}

expected.Args = []string{
"--collector.collstats",
"--collector.collstats-limit=0",
"--collector.dbstats",
"--collector.diagnosticdata",
"--collector.indexstats",
"--collector.replicasetstatus",
"--collector.shards",
"--collector.topmetrics",
"--compatible-mode",
"--discovering-mode",
// this should be here even if limit=0 because it could be used to filter dbstats
// since dbstats is not depending the number of collections present in the db.
"--mongodb.collstats-colls=db1.col1.one,db2.col2,db3",
"--mongodb.global-conn-pool",
"--mongodb.indexstats-colls=db1.col1.one,db2.col2,db3",
"--web.listen-address=0.0.0.0:{{ .listen_port }}",
"--web.config={{ .TextFiles.webConfigPlaceholder }}",
}
actual, err := mongodbExporterConfig(node, mongodb, exporter, exposeSecrets, pmmAgentVersion)
require.NoError(t, err)
require.Equal(t, expected.Args, actual.Args)
})

t.Run("collstats-limit=-1 -> automatically set the limit", func(t *testing.T) {
exporter.MongoDBOptions = &models.MongoDBOptions{
EnableAllCollectors: true,
StatsCollections: []string{"db1.col1.one", "db2.col2", "db3"},
CollectionsLimit: -1,
}

expected.Args = []string{
"--collector.collstats",
"--collector.collstats-limit=200", // 200 is the default for auto-set
"--collector.dbstats",
"--collector.diagnosticdata",
"--collector.indexstats",
"--collector.replicasetstatus",
"--collector.shards",
"--collector.topmetrics",
"--compatible-mode",
"--discovering-mode",
"--mongodb.collstats-colls=db1.col1.one,db2.col2,db3",
"--mongodb.global-conn-pool",
"--mongodb.indexstats-colls=db1.col1.one,db2.col2,db3",
"--web.listen-address=0.0.0.0:{{ .listen_port }}",
"--web.config={{ .TextFiles.webConfigPlaceholder }}",
}
actual, err := mongodbExporterConfig(node, mongodb, exporter, exposeSecrets, pmmAgentVersion)
require.NoError(t, err)
require.Equal(t, expected.Args, actual.Args)
})
}

func TestMongodbExporterConfig(t *testing.T) {
pmmAgentVersion := version.MustParse("2.0.0")
node := &models.Node{
Expand Down
9 changes: 7 additions & 2 deletions managed/services/victoriametrics/scrape_configs.go
Original file line number Diff line number Diff line change
Expand Up @@ -398,11 +398,16 @@ func scrapeConfigsForMongoDBExporter(s *models.MetricsResolutions, params *scrap
r = append(r, hr)
}
if params.agent.MongoDBOptions != nil && params.agent.MongoDBOptions.EnableAllCollectors {
lr, err := scrapeConfigForStandardExporter("lr", s.LR, params, []string{
defaultCollectors := []string{
"dbstats",
"indexstats",
"collstats",
})
}
if params.pmmAgentVersion != nil && (strings.Contains(params.pmmAgentVersion.String(), "2.41.1") || !params.pmmAgentVersion.Less(version.MustParse("2.41.2"))) {
defaultCollectors = append(defaultCollectors, "shards")
}

lr, err := scrapeConfigForStandardExporter("lr", s.LR, params, defaultCollectors)
if err != nil {
return nil, err
}
Expand Down
4 changes: 2 additions & 2 deletions managed/services/victoriametrics/scrape_configs_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -752,7 +752,7 @@ func TestScrapeConfig(t *testing.T) {
ScrapeTimeout: scrapeTimeout(s.LR),
MetricsPath: "/metrics",
Params: map[string][]string{
"collect[]": {"collstats", "dbstats", "indexstats"},
"collect[]": {"collstats", "dbstats", "indexstats", "shards"},
},
HTTPClientConfig: config.HTTPClientConfig{
BasicAuth: &config.BasicAuth{
Expand Down Expand Up @@ -784,7 +784,7 @@ func TestScrapeConfig(t *testing.T) {
node: node,
service: service,
agent: agent,
pmmAgentVersion: version.MustParse("2.26.0"),
pmmAgentVersion: version.MustParse("2.41.1"),
})
require.NoError(t, err)
require.Len(t, actual, len(expected))
Expand Down
Loading