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

Reading USDT Probes is a O(n^2) operation #5161

Open
ttreyer opened this issue Nov 27, 2024 · 1 comment
Open

Reading USDT Probes is a O(n^2) operation #5161

ttreyer opened this issue Nov 27, 2024 · 1 comment

Comments

@ttreyer
Copy link

ttreyer commented Nov 27, 2024

Hello 🙂 The function Context::add_probe iterates through the entire list of probes_ every times it is called. It is looking for an existing Probe with matching provider+name, so the new probe entry can be added as a location to the existing probe.
This makes reading a large amount of USDT probes particularly slow!

I'm using bpftrace on a binary with about 400,000 USDT entries and am experiencing hang-up of ~1min. I could track the issue back to Context::add_probe and could confirm the wait was due to the many String comparisons done during the probes_ traversal. The long wait time makes using bpftrace non-interactive and prevents quickly iterating through ideas.

A possible solution could be to add a std::unordered_map as an index to quickly lookup a probe using its name. I was able to confirm the performance improvement with the following draft: fast-usdt.patch.

Another idea could be to use a reverse iterator when searching through the list of probes_, so that contiguous USDT entries that share the same name would find a match on their first iteration. On my end, I can sort the USDT entries by name to take advantage of that property.

@yonghong-song
Copy link
Collaborator

Thanks @ttreyer. I guess existing bcc tools do not have use case to probe large number of usdt probes so the probe lookup algorithm is really rudimentary. We will try to improve it later based on your suggestion.

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

No branches or pull requests

2 participants