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

DEBUG-3175 DI snapshot/rate limit benchmark #4207

Open
wants to merge 5 commits into
base: master
Choose a base branch
from

Conversation

p-datadog
Copy link
Member

@p-datadog p-datadog commented Dec 9, 2024

What does this PR do?

Adds dynamic instrumentation benchmarks verifying that the rate at which probes can capture, serialize and submit snapshots to the agent are below the rate limits.

It also makes the probe notifier worker queue capacity configurable via an internal setting. With default DI settings, DI will permit no more than 30 snapshots/second on average across all probes which is well short of the 5000/second/probe that this benchmark is aiming to achieve. The benchmark raises the limit (and makes flushes more frequent) to demonstrate theoretical performance of DI implementation, however more work is needed to permit higher limits by default - flushing logic must be carefully written to not starve the application of CPU. The default limits are very conservative in this regard.

Motivation:

We want to ensure that the rate limits we set are achievable, meaning they are not set so high that DI code can starve customer applications of CPU and still not hit rate limits.

Change log entry

None.

Additional Notes:

The benchmarks perform as many invocations of target methods as each probe type would permit (5000/second for basic probes, 1/second for enriched probes). A rate of greater than 1 instruction/second in the benchmark means the rate limit was not reached by the test code and thus DI performance is within expectations.

How to test the change?

N/A

@p-datadog p-datadog requested a review from a team as a code owner December 9, 2024 14:08
Copy link

github-actions bot commented Dec 9, 2024

👋 Hey @p-datadog, please fill "Change log entry" section in the pull request description.

If changes need to be present in CHANGELOG.md you can state it this way

**Change log entry**

Yes. A brief summary to be placed into the CHANGELOG.md

(possible answers Yes/Yep/Yeah)

Or you can opt out like that

**Change log entry**

None.

(possible answers No/Nope/None)

Visited at: 2024-12-09 21:35:47 UTC

@p-datadog p-datadog force-pushed the di-rate-limit-benchmark branch from 2671908 to b5045c8 Compare December 9, 2024 14:22
@pr-commenter
Copy link

pr-commenter bot commented Dec 9, 2024

Benchmarks

Benchmark execution time: 2024-12-12 18:33:52

Comparing candidate commit 54796a5 in PR branch di-rate-limit-benchmark with baseline commit c07a8d4 in branch master.

Found 0 performance improvements and 0 performance regressions! Performance is the same for 31 metrics, 2 unstable metrics.

@codecov-commenter
Copy link

codecov-commenter commented Dec 9, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 97.76%. Comparing base (c07a8d4) to head (c85a791).
Report is 12 commits behind head on master.

Additional details and impacted files
@@            Coverage Diff             @@
##           master    #4207      +/-   ##
==========================================
- Coverage   97.77%   97.76%   -0.01%     
==========================================
  Files        1357     1357              
  Lines       81973    81981       +8     
  Branches     4168     4170       +2     
==========================================
+ Hits        80145    80150       +5     
- Misses       1828     1831       +3     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@github-actions github-actions bot added the dev/testing Involves testing processes (e.g. RSpec) label Dec 9, 2024
@p-datadog p-datadog force-pushed the di-rate-limit-benchmark branch from ca27dae to 4f443b9 Compare December 9, 2024 15:14
@p-datadog p-datadog marked this pull request as draft December 9, 2024 15:20
@p-datadog p-datadog marked this pull request as ready for review December 9, 2024 21:31
@p-datadog p-datadog changed the title DEBUG-3175 DI rate limit benchmark DEBUG-3175 DI snapshot/rate limit benchmark Dec 9, 2024
@p-datadog p-datadog added the dev/internal Other internal work that does not need to be included in the changelog label Dec 9, 2024
@datadog-datadog-prod-us1
Copy link
Contributor

datadog-datadog-prod-us1 bot commented Dec 12, 2024

Datadog Report

Branch report: di-rate-limit-benchmark
Commit report: 54796a5
Test service: dd-trace-rb

✅ 0 Failed, 22056 Passed, 1457 Skipped, 5m 28.91s Total Time

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
dev/internal Other internal work that does not need to be included in the changelog dev/testing Involves testing processes (e.g. RSpec)
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants