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

release 0.43 - 10x increase in memory usage (~50Mb -> ~500Mb) #990

Open
blushingpenguin opened this issue Dec 12, 2024 · 10 comments
Open

release 0.43 - 10x increase in memory usage (~50Mb -> ~500Mb) #990

blushingpenguin opened this issue Dec 12, 2024 · 10 comments

Comments

@blushingpenguin
Copy link

Describe the bug
Release 0.43 increases the memory usage of the metrics container dramatically compared to 0.42

To Reproduce
Just switching the container version reproduces consistently

Expected behavior
Similar memory usage

Logs
image

On the LHS is v0.40, the middle is 0.43, the RHS is 0.42

Environment
This is a percona operator for mongodb managed deployment of mongo 7.0.15 running on microk8s 1.31 on ubuntu 24.04

@BupycHuk
Copy link
Member

Hi, could you share more details about cluster being monitored.
Is it sharded cluster or just replicaset?
Is it mongos, mongod, arbiter or config node?
Did you enable all collectors?
Can you build mongodb_exporter from main and check if the problem fixed on your side? We recently faced similar problem with Mongo 8 and improved performance a bit, but we are not sure that it will fix your problem.

@blushingpenguin
Copy link
Author

Hi, thanks for the swift response.

We have basic mongo replica set with 3 x mongod. (We have 5 mongo clusters which have similar config and I saw the same problem on all of them).

The config for the exporter is:

sidecars:
- image: percona/mongodb_exporter:0.42 # 0.43
  env:
  - name: EXPORTER_USER
    valueFrom:
      secretKeyRef:
        name: mongo-psmdb-db-secrets
        key: MONGODB_CLUSTER_MONITOR_USER
  - name: EXPORTER_PASS
    valueFrom:
      secretKeyRef:
        name: mongo-psmdb-db-secrets
        key: MONGODB_CLUSTER_MONITOR_PASSWORD
  - name: POD_IP
    valueFrom:
      fieldRef:
        fieldPath: status.podIP
  - name: MONGODB_URI
    value: "mongodb://$(EXPORTER_USER):$(EXPORTER_PASS)@$(POD_IP):27017"
  args: ["--discovering-mode", "--compatible-mode", "--collect-all", "--log.level=debug", "--mongodb.uri=$(MONGODB_URI)"]
  name: metrics

I can have a go at building a container, are there some instructions on how to do so? I'm not familiar with go.

@BupycHuk
Copy link
Member

We released v0.43.1, please check if it fixes a problem.
Also would be great to have heap by calling

curl -sK -v http://localhost:42000/debug/pprof/heap > heap.out

replace localhost:42000 with your exporter host and port.

We added more metrics to collstats collector, it could cause your problem as well.

@blushingpenguin
Copy link
Author

It's not really much different:
image

The heap dump as requested:
heap.out.gz

Thanks for looking at it

@BupycHuk
Copy link
Member

Thank you, yeah, I was right, it's because of new metrics in collstats we implemented for #897. Let me think how can we make it configurable.

@BupycHuk
Copy link
Member

If you don't use metrics from collstats instead of enabling all collectors you can enable only the ones you use. How to enable only part of collectors you can find in https://github.com/percona/mongodb_exporter/blob/main/REFERENCE.md.

@BupycHuk
Copy link
Member

@blushingpenguin could you please also share amount of collections and indexes in them?

@weastur
Copy link
Contributor

weastur commented Jan 3, 2025

@BupycHuk Hi. It would be great to make it configurable. Memory usage 50 -> 500 might be much less valuable issue than increasing time series count. I got 10x incresing after upgrade 0.42.0 -> 0.43.1 just because of those changes.

As you can see in #283 which introduced storage stats, portion of stat was ignored exactly to not blow up your metric collector/storage.

This is intentionally filtering out any information from storageStats.wiredTiger and storageStats.indexDetails since it can lead to a high-cardinality issues

		project := bson.D{
			{
				Key: "$project", Value: bson.M{
					"storageStats.wiredTiger":   0,
					"storageStats.indexDetails": 0,
				},
			},
		}

@BupycHuk
Copy link
Member

BupycHuk commented Jan 3, 2025

Hi @psapezhka , I've already created PR for that #997. Currently I'm on vacation will proceed with merging next week

@blushingpenguin
Copy link
Author

@blushingpenguin could you please also share amount of collections and indexes in them?

Sorry for the delay!
We've currently got totals of 17 databases, 327 collections, 522 indexes

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants