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

Introduce a shared context component, independent of tracing. #8117

Merged
merged 5 commits into from
Dec 20, 2024

Conversation

mcculls
Copy link
Contributor

@mcculls mcculls commented Dec 19, 2024

What Does This Do

This is an initial implementation of the Evolving Context RFC.

Contributor Checklist

Jira ticket: APMAPI-958

@mcculls mcculls force-pushed the mcculls/introduce-context-component branch from c083482 to 4863c40 Compare December 19, 2024 12:46
@mcculls mcculls marked this pull request as ready for review December 19, 2024 12:47
@mcculls mcculls requested a review from a team as a code owner December 19, 2024 12:47
@mcculls mcculls force-pushed the mcculls/introduce-context-component branch from 4863c40 to 83176e3 Compare December 19, 2024 12:53
Copy link
Contributor

@PerfectSlayer PerfectSlayer left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Most of the comments are related to documentation or visibility.

Another thing I would like to add is the support of toString() on the Context implementations. I find it very useful for debugging.

components/context/build.gradle.kts Show resolved Hide resolved
/** Immutable context scoped to an execution unit or carrier object. */
public interface Context {

/** Returns the root context. */
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should we define what root context is supposed to be?
Like the default, minimal context, used as based for any other.

<T> T get(ContextKey<T> key);

/**
* Creates a new context with the given key-value mapping.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We should document the expected behavior:

  • This will append values from the current instance,
  • This will replace if the key already exist,
  • What should happen if the value is null?

<T> Context with(ContextKey<T> key, T value);

/**
* Creates a new context with a value that has its own implicit key.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Similarly, we should be document the append with current values behavior and what the replacement if a current value is already present.

@pr-commenter
Copy link

pr-commenter bot commented Dec 19, 2024

Benchmarks

Startup

Parameters

Baseline Candidate
baseline_or_candidate baseline candidate
git_branch master mcculls/introduce-context-component
git_commit_date 1734714029 1734714824
git_commit_sha e8e9292 f93396d
release_version 1.45.0-SNAPSHOT~e8e9292d06 1.45.0-SNAPSHOT~f93396d7b6
See matching parameters
Baseline Candidate
application insecure-bank insecure-bank
ci_job_date 1734717231 1734717231
ci_job_id 747311202 747311202
ci_pipeline_id 51669401 51669401
cpu_model Intel(R) Xeon(R) Platinum 8259CL CPU @ 2.50GHz Intel(R) Xeon(R) Platinum 8259CL CPU @ 2.50GHz
module Agent Agent
parent None None
variant iast iast

Summary

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

Startup time reports for petclinic
gantt
    title petclinic - global startup overhead: candidate=1.45.0-SNAPSHOT~f93396d7b6, baseline=1.45.0-SNAPSHOT~e8e9292d06

    dateFormat X
    axisFormat %s
section tracing
Agent [baseline] (1.059 s) : 0, 1059177
Total [baseline] (10.443 s) : 0, 10443348
Agent [candidate] (1.055 s) : 0, 1055119
Total [candidate] (10.408 s) : 0, 10408049
section appsec
Agent [baseline] (1.193 s) : 0, 1192964
Total [baseline] (10.663 s) : 0, 10662617
Agent [candidate] (1.188 s) : 0, 1188219
Total [candidate] (10.706 s) : 0, 10705503
section iast
Agent [baseline] (1.177 s) : 0, 1176592
Total [baseline] (10.93 s) : 0, 10930144
Agent [candidate] (1.179 s) : 0, 1179175
Total [candidate] (10.958 s) : 0, 10957683
section profiling
Agent [baseline] (1.271 s) : 0, 1271257
Total [baseline] (10.821 s) : 0, 10821443
Agent [candidate] (1.274 s) : 0, 1274387
Total [candidate] (10.832 s) : 0, 10831629
Loading
  • baseline results
Module Variant Duration Δ tracing
Agent tracing 1.059 s -
Agent appsec 1.193 s 133.787 ms (12.6%)
Agent iast 1.177 s 117.415 ms (11.1%)
Agent profiling 1.271 s 212.08 ms (20.0%)
Total tracing 10.443 s -
Total appsec 10.663 s 219.269 ms (2.1%)
Total iast 10.93 s 486.796 ms (4.7%)
Total profiling 10.821 s 378.095 ms (3.6%)
  • candidate results
Module Variant Duration Δ tracing
Agent tracing 1.055 s -
Agent appsec 1.188 s 133.1 ms (12.6%)
Agent iast 1.179 s 124.056 ms (11.8%)
Agent profiling 1.274 s 219.268 ms (20.8%)
Total tracing 10.408 s -
Total appsec 10.706 s 297.455 ms (2.9%)
Total iast 10.958 s 549.635 ms (5.3%)
Total profiling 10.832 s 423.581 ms (4.1%)
gantt
    title petclinic - break down per module: candidate=1.45.0-SNAPSHOT~f93396d7b6, baseline=1.45.0-SNAPSHOT~e8e9292d06

    dateFormat X
    axisFormat %s
section tracing
BytebuddyAgent [baseline] (716.611 ms) : 0, 716611
BytebuddyAgent [candidate] (713.39 ms) : 0, 713390
GlobalTracer [baseline] (257.144 ms) : 0, 257144
GlobalTracer [candidate] (256.591 ms) : 0, 256591
AppSec [baseline] (56.921 ms) : 0, 56921
AppSec [candidate] (56.601 ms) : 0, 56601
Remote Config [baseline] (695.046 µs) : 0, 695
Remote Config [candidate] (684.019 µs) : 0, 684
Telemetry [baseline] (12.835 ms) : 0, 12835
Telemetry [candidate] (12.774 ms) : 0, 12774
section appsec
BytebuddyAgent [baseline] (733.323 ms) : 0, 733323
BytebuddyAgent [candidate] (730.385 ms) : 0, 730385
GlobalTracer [baseline] (254.395 ms) : 0, 254395
GlobalTracer [candidate] (253.624 ms) : 0, 253624
AppSec [baseline] (171.811 ms) : 0, 171811
AppSec [candidate] (170.818 ms) : 0, 170818
Remote Config [baseline] (663.426 µs) : 0, 663
Remote Config [candidate] (659.85 µs) : 0, 660
Telemetry [baseline] (8.016 ms) : 0, 8016
Telemetry [candidate] (8.003 ms) : 0, 8003
IAST [baseline] (19.578 ms) : 0, 19578
IAST [candidate] (19.44 ms) : 0, 19440
section iast
BytebuddyAgent [baseline] (827.426 ms) : 0, 827426
BytebuddyAgent [candidate] (829.493 ms) : 0, 829493
GlobalTracer [baseline] (246.16 ms) : 0, 246160
GlobalTracer [candidate] (246.751 ms) : 0, 246751
AppSec [baseline] (57.661 ms) : 0, 57661
AppSec [candidate] (57.933 ms) : 0, 57933
Remote Config [baseline] (668.994 µs) : 0, 669
Remote Config [candidate] (646.923 µs) : 0, 647
Telemetry [baseline] (8.497 ms) : 0, 8497
Telemetry [candidate] (8.404 ms) : 0, 8404
IAST [baseline] (21.312 ms) : 0, 21312
IAST [candidate] (20.997 ms) : 0, 20997
section profiling
BytebuddyAgent [baseline] (699.941 ms) : 0, 699941
BytebuddyAgent [candidate] (702.371 ms) : 0, 702371
GlobalTracer [baseline] (371.536 ms) : 0, 371536
GlobalTracer [candidate] (372.066 ms) : 0, 372066
AppSec [baseline] (53.968 ms) : 0, 53968
AppSec [candidate] (53.909 ms) : 0, 53909
Remote Config [baseline] (658.084 µs) : 0, 658
Remote Config [candidate] (661.134 µs) : 0, 661
Telemetry [baseline] (7.866 ms) : 0, 7866
Telemetry [candidate] (7.863 ms) : 0, 7863
ProfilingAgent [baseline] (95.674 ms) : 0, 95674
ProfilingAgent [candidate] (95.596 ms) : 0, 95596
Profiling [baseline] (95.698 ms) : 0, 95698
Profiling [candidate] (95.62 ms) : 0, 95620
Loading
Startup time reports for insecure-bank
gantt
    title insecure-bank - global startup overhead: candidate=1.45.0-SNAPSHOT~f93396d7b6, baseline=1.45.0-SNAPSHOT~e8e9292d06

    dateFormat X
    axisFormat %s
section tracing
Agent [baseline] (1.055 s) : 0, 1054882
Total [baseline] (8.578 s) : 0, 8578096
Agent [candidate] (1.057 s) : 0, 1057309
Total [candidate] (8.6 s) : 0, 8599677
section iast
Agent [baseline] (1.177 s) : 0, 1177421
Total [baseline] (9.181 s) : 0, 9181029
Agent [candidate] (1.179 s) : 0, 1178953
Total [candidate] (9.204 s) : 0, 9203876
section iast_HARDCODED_SECRET_DISABLED
Agent [baseline] (1.175 s) : 0, 1175214
Total [baseline] (9.133 s) : 0, 9133261
Agent [candidate] (1.177 s) : 0, 1177239
Total [candidate] (9.179 s) : 0, 9179173
section iast_TELEMETRY_OFF
Agent [baseline] (1.172 s) : 0, 1171684
Total [baseline] (9.159 s) : 0, 9158937
Agent [candidate] (1.174 s) : 0, 1173983
Total [candidate] (9.176 s) : 0, 9175757
Loading
  • baseline results
Module Variant Duration Δ tracing
Agent tracing 1.055 s -
Agent iast 1.177 s 122.538 ms (11.6%)
Agent iast_HARDCODED_SECRET_DISABLED 1.175 s 120.331 ms (11.4%)
Agent iast_TELEMETRY_OFF 1.172 s 116.802 ms (11.1%)
Total tracing 8.578 s -
Total iast 9.181 s 602.933 ms (7.0%)
Total iast_HARDCODED_SECRET_DISABLED 9.133 s 555.165 ms (6.5%)
Total iast_TELEMETRY_OFF 9.159 s 580.841 ms (6.8%)
  • candidate results
Module Variant Duration Δ tracing
Agent tracing 1.057 s -
Agent iast 1.179 s 121.644 ms (11.5%)
Agent iast_HARDCODED_SECRET_DISABLED 1.177 s 119.93 ms (11.3%)
Agent iast_TELEMETRY_OFF 1.174 s 116.674 ms (11.0%)
Total tracing 8.6 s -
Total iast 9.204 s 604.198 ms (7.0%)
Total iast_HARDCODED_SECRET_DISABLED 9.179 s 579.496 ms (6.7%)
Total iast_TELEMETRY_OFF 9.176 s 576.079 ms (6.7%)
gantt
    title insecure-bank - break down per module: candidate=1.45.0-SNAPSHOT~f93396d7b6, baseline=1.45.0-SNAPSHOT~e8e9292d06

    dateFormat X
    axisFormat %s
section tracing
BytebuddyAgent [baseline] (712.097 ms) : 0, 712097
BytebuddyAgent [candidate] (714.765 ms) : 0, 714765
GlobalTracer [baseline] (255.896 ms) : 0, 255896
GlobalTracer [candidate] (257.427 ms) : 0, 257427
AppSec [baseline] (57.872 ms) : 0, 57872
AppSec [candidate] (56.731 ms) : 0, 56731
Remote Config [baseline] (684.568 µs) : 0, 685
Remote Config [candidate] (703.552 µs) : 0, 704
Telemetry [baseline] (13.359 ms) : 0, 13359
Telemetry [candidate] (12.748 ms) : 0, 12748
section iast
BytebuddyAgent [baseline] (828.668 ms) : 0, 828668
BytebuddyAgent [candidate] (829.157 ms) : 0, 829157
GlobalTracer [baseline] (246.155 ms) : 0, 246155
GlobalTracer [candidate] (246.63 ms) : 0, 246630
AppSec [baseline] (57.466 ms) : 0, 57466
AppSec [candidate] (57.657 ms) : 0, 57657
Remote Config [baseline] (658.039 µs) : 0, 658
Remote Config [candidate] (660.402 µs) : 0, 660
Telemetry [baseline] (8.446 ms) : 0, 8446
Telemetry [candidate] (8.518 ms) : 0, 8518
IAST [baseline] (21.041 ms) : 0, 21041
IAST [candidate] (21.388 ms) : 0, 21388
section iast_HARDCODED_SECRET_DISABLED
BytebuddyAgent [baseline] (826.352 ms) : 0, 826352
BytebuddyAgent [candidate] (827.511 ms) : 0, 827511
GlobalTracer [baseline] (246.15 ms) : 0, 246150
GlobalTracer [candidate] (246.565 ms) : 0, 246565
AppSec [baseline] (57.646 ms) : 0, 57646
AppSec [candidate] (57.836 ms) : 0, 57836
Remote Config [baseline] (644.859 µs) : 0, 645
Remote Config [candidate] (661.217 µs) : 0, 661
Telemetry [baseline] (8.483 ms) : 0, 8483
Telemetry [candidate] (8.525 ms) : 0, 8525
IAST [baseline] (21.074 ms) : 0, 21074
IAST [candidate] (21.239 ms) : 0, 21239
section iast_TELEMETRY_OFF
BytebuddyAgent [baseline] (823.284 ms) : 0, 823284
BytebuddyAgent [candidate] (825.03 ms) : 0, 825030
GlobalTracer [baseline] (246.085 ms) : 0, 246085
GlobalTracer [candidate] (246.923 ms) : 0, 246923
AppSec [baseline] (57.739 ms) : 0, 57739
AppSec [candidate] (57.394 ms) : 0, 57394
Remote Config [baseline] (643.208 µs) : 0, 643
Remote Config [candidate] (648.548 µs) : 0, 649
Telemetry [baseline] (8.287 ms) : 0, 8287
Telemetry [candidate] (8.272 ms) : 0, 8272
IAST [baseline] (20.677 ms) : 0, 20677
IAST [candidate] (20.777 ms) : 0, 20777
Loading

Load

Parameters

Baseline Candidate
baseline_or_candidate baseline candidate
end_time 2024-12-20T17:24:17 2024-12-20T17:31:18
git_branch master mcculls/introduce-context-component
git_commit_date 1734714029 1734714824
git_commit_sha e8e9292 f93396d
release_version 1.45.0-SNAPSHOT~e8e9292d06 1.45.0-SNAPSHOT~f93396d7b6
start_time 2024-12-20T17:24:03 2024-12-20T17:31:04
See matching parameters
Baseline Candidate
application insecure-bank insecure-bank
ci_job_date 1734716232 1734716232
ci_job_id 747311203 747311203
ci_pipeline_id 51669401 51669401
cpu_model Intel(R) Xeon(R) Platinum 8259CL CPU @ 2.50GHz Intel(R) Xeon(R) Platinum 8259CL CPU @ 2.50GHz
variant iast iast

Summary

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

Request duration reports for petclinic
gantt
    title petclinic - request duration [CI 0.99] : candidate=1.45.0-SNAPSHOT~f93396d7b6, baseline=1.45.0-SNAPSHOT~e8e9292d06
    dateFormat X
    axisFormat %s
section baseline
no_agent (1.375 ms) : 1355, 1396
.   : milestone, 1375,
appsec (1.742 ms) : 1718, 1766
.   : milestone, 1742,
appsec_no_iast (1.783 ms) : 1759, 1808
.   : milestone, 1783,
iast (1.527 ms) : 1503, 1550
.   : milestone, 1527,
profiling (1.55 ms) : 1524, 1575
.   : milestone, 1550,
tracing (1.483 ms) : 1457, 1508
.   : milestone, 1483,
section candidate
no_agent (1.358 ms) : 1338, 1377
.   : milestone, 1358,
appsec (1.759 ms) : 1735, 1783
.   : milestone, 1759,
appsec_no_iast (1.783 ms) : 1758, 1807
.   : milestone, 1783,
iast (1.511 ms) : 1489, 1533
.   : milestone, 1511,
profiling (1.523 ms) : 1501, 1546
.   : milestone, 1523,
tracing (1.482 ms) : 1457, 1506
.   : milestone, 1482,
Loading
  • baseline results
Variant Request duration [CI 0.99] Δ no_agent
no_agent 1.375 ms [1.355 ms, 1.396 ms] -
appsec 1.742 ms [1.718 ms, 1.766 ms] 367.052 µs (26.7%)
appsec_no_iast 1.783 ms [1.759 ms, 1.808 ms] 408.116 µs (29.7%)
iast 1.527 ms [1.503 ms, 1.55 ms] 151.453 µs (11.0%)
profiling 1.55 ms [1.524 ms, 1.575 ms] 174.346 µs (12.7%)
tracing 1.483 ms [1.457 ms, 1.508 ms] 107.277 µs (7.8%)
  • candidate results
Variant Request duration [CI 0.99] Δ no_agent
no_agent 1.358 ms [1.338 ms, 1.377 ms] -
appsec 1.759 ms [1.735 ms, 1.783 ms] 401.459 µs (29.6%)
appsec_no_iast 1.783 ms [1.758 ms, 1.807 ms] 424.953 µs (31.3%)
iast 1.511 ms [1.489 ms, 1.533 ms] 153.374 µs (11.3%)
profiling 1.523 ms [1.501 ms, 1.546 ms] 165.877 µs (12.2%)
tracing 1.482 ms [1.457 ms, 1.506 ms] 124.007 µs (9.1%)
Request duration reports for insecure-bank
gantt
    title insecure-bank - request duration [CI 0.99] : candidate=1.45.0-SNAPSHOT~f93396d7b6, baseline=1.45.0-SNAPSHOT~e8e9292d06
    dateFormat X
    axisFormat %s
section baseline
no_agent (380.29 µs) : 360, 401
.   : milestone, 380,
iast (503.043 µs) : 482, 524
.   : milestone, 503,
iast_FULL (659.43 µs) : 637, 682
.   : milestone, 659,
iast_GLOBAL (533.864 µs) : 512, 556
.   : milestone, 534,
iast_HARDCODED_SECRET_DISABLED (499.849 µs) : 478, 522
.   : milestone, 500,
iast_INACTIVE (467.282 µs) : 445, 489
.   : milestone, 467,
iast_TELEMETRY_OFF (485.47 µs) : 464, 507
.   : milestone, 485,
tracing (453.034 µs) : 432, 474
.   : milestone, 453,
section candidate
no_agent (384.399 µs) : 365, 404
.   : milestone, 384,
iast (496.318 µs) : 475, 518
.   : milestone, 496,
iast_FULL (658.936 µs) : 637, 681
.   : milestone, 659,
iast_GLOBAL (527.569 µs) : 505, 550
.   : milestone, 528,
iast_HARDCODED_SECRET_DISABLED (495.343 µs) : 474, 517
.   : milestone, 495,
iast_INACTIVE (467.688 µs) : 446, 489
.   : milestone, 468,
iast_TELEMETRY_OFF (494.904 µs) : 473, 517
.   : milestone, 495,
tracing (453.727 µs) : 433, 475
.   : milestone, 454,
Loading
  • baseline results
Variant Request duration [CI 0.99] Δ no_agent
no_agent 380.29 µs [359.8 µs, 400.78 µs] -
iast 503.043 µs [481.772 µs, 524.314 µs] 122.753 µs (32.3%)
iast_FULL 659.43 µs [637.126 µs, 681.734 µs] 279.14 µs (73.4%)
iast_GLOBAL 533.864 µs [511.634 µs, 556.093 µs] 153.574 µs (40.4%)
iast_HARDCODED_SECRET_DISABLED 499.849 µs [477.875 µs, 521.822 µs] 119.559 µs (31.4%)
iast_INACTIVE 467.282 µs [445.073 µs, 489.491 µs] 86.992 µs (22.9%)
iast_TELEMETRY_OFF 485.47 µs [464.257 µs, 506.683 µs] 105.18 µs (27.7%)
tracing 453.034 µs [432.372 µs, 473.695 µs] 72.744 µs (19.1%)
  • candidate results
Variant Request duration [CI 0.99] Δ no_agent
no_agent 384.399 µs [364.747 µs, 404.051 µs] -
iast 496.318 µs [475.118 µs, 517.517 µs] 111.919 µs (29.1%)
iast_FULL 658.936 µs [637.267 µs, 680.605 µs] 274.537 µs (71.4%)
iast_GLOBAL 527.569 µs [504.956 µs, 550.181 µs] 143.17 µs (37.2%)
iast_HARDCODED_SECRET_DISABLED 495.343 µs [474.09 µs, 516.596 µs] 110.944 µs (28.9%)
iast_INACTIVE 467.688 µs [445.983 µs, 489.394 µs] 83.29 µs (21.7%)
iast_TELEMETRY_OFF 494.904 µs [472.982 µs, 516.825 µs] 110.505 µs (28.7%)
tracing 453.727 µs [432.712 µs, 474.743 µs] 69.328 µs (18.0%)

Dacapo

Parameters

Baseline Candidate
baseline_or_candidate baseline candidate
git_branch master mcculls/introduce-context-component
git_commit_date 1734714029 1734714824
git_commit_sha e8e9292 f93396d
release_version 1.45.0-SNAPSHOT~e8e9292d06 1.45.0-SNAPSHOT~f93396d7b6
See matching parameters
Baseline Candidate
application biojava biojava
ci_job_date 1734716805 1734716805
ci_job_id 747311204 747311204
ci_pipeline_id 51669401 51669401
cpu_model Intel(R) Xeon(R) Platinum 8259CL CPU @ 2.50GHz Intel(R) Xeon(R) Platinum 8259CL CPU @ 2.50GHz
variant appsec appsec

Summary

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

Execution time for biojava
gantt
    title biojava - execution time [CI 0.99] : candidate=1.45.0-SNAPSHOT~f93396d7b6, baseline=1.45.0-SNAPSHOT~e8e9292d06
    dateFormat X
    axisFormat %s
section baseline
no_agent (14.948 s) : 14948000, 14948000
.   : milestone, 14948000,
appsec (14.965 s) : 14965000, 14965000
.   : milestone, 14965000,
iast (18.78 s) : 18780000, 18780000
.   : milestone, 18780000,
iast_GLOBAL (17.918 s) : 17918000, 17918000
.   : milestone, 17918000,
profiling (15.054 s) : 15054000, 15054000
.   : milestone, 15054000,
tracing (14.92 s) : 14920000, 14920000
.   : milestone, 14920000,
section candidate
no_agent (15.582 s) : 15582000, 15582000
.   : milestone, 15582000,
appsec (15.136 s) : 15136000, 15136000
.   : milestone, 15136000,
iast (19.005 s) : 19005000, 19005000
.   : milestone, 19005000,
iast_GLOBAL (17.811 s) : 17811000, 17811000
.   : milestone, 17811000,
profiling (15.185 s) : 15185000, 15185000
.   : milestone, 15185000,
tracing (14.883 s) : 14883000, 14883000
.   : milestone, 14883000,
Loading
  • baseline results
Variant Execution Time [CI 0.99] Δ no_agent
no_agent 14.948 s [14.948 s, 14.948 s] -
appsec 14.965 s [14.965 s, 14.965 s] 17.0 ms (0.1%)
iast 18.78 s [18.78 s, 18.78 s] 3.832 s (25.6%)
iast_GLOBAL 17.918 s [17.918 s, 17.918 s] 2.97 s (19.9%)
profiling 15.054 s [15.054 s, 15.054 s] 106.0 ms (0.7%)
tracing 14.92 s [14.92 s, 14.92 s] -28.0 ms (-0.2%)
  • candidate results
Variant Execution Time [CI 0.99] Δ no_agent
no_agent 15.582 s [15.582 s, 15.582 s] -
appsec 15.136 s [15.136 s, 15.136 s] -446.0 ms (-2.9%)
iast 19.005 s [19.005 s, 19.005 s] 3.423 s (22.0%)
iast_GLOBAL 17.811 s [17.811 s, 17.811 s] 2.229 s (14.3%)
profiling 15.185 s [15.185 s, 15.185 s] -397.0 ms (-2.5%)
tracing 14.883 s [14.883 s, 14.883 s] -699.0 ms (-4.5%)
Execution time for tomcat
gantt
    title tomcat - execution time [CI 0.99] : candidate=1.45.0-SNAPSHOT~f93396d7b6, baseline=1.45.0-SNAPSHOT~e8e9292d06
    dateFormat X
    axisFormat %s
section baseline
no_agent (1.467 ms) : 1456, 1479
.   : milestone, 1467,
appsec (2.349 ms) : 2307, 2391
.   : milestone, 2349,
iast (2.087 ms) : 2034, 2139
.   : milestone, 2087,
iast_GLOBAL (2.135 ms) : 2081, 2189
.   : milestone, 2135,
profiling (1.973 ms) : 1930, 2017
.   : milestone, 1973,
tracing (1.926 ms) : 1886, 1966
.   : milestone, 1926,
section candidate
no_agent (1.468 ms) : 1456, 1479
.   : milestone, 1468,
appsec (2.343 ms) : 2301, 2384
.   : milestone, 2343,
iast (2.082 ms) : 2030, 2135
.   : milestone, 2082,
iast_GLOBAL (2.124 ms) : 2071, 2177
.   : milestone, 2124,
profiling (1.954 ms) : 1911, 1997
.   : milestone, 1954,
tracing (1.935 ms) : 1894, 1976
.   : milestone, 1935,
Loading
  • baseline results
Variant Execution Time [CI 0.99] Δ no_agent
no_agent 1.467 ms [1.456 ms, 1.479 ms] -
appsec 2.349 ms [2.307 ms, 2.391 ms] 881.571 µs (60.1%)
iast 2.087 ms [2.034 ms, 2.139 ms] 619.674 µs (42.2%)
iast_GLOBAL 2.135 ms [2.081 ms, 2.189 ms] 667.845 µs (45.5%)
profiling 1.973 ms [1.93 ms, 2.017 ms] 506.208 µs (34.5%)
tracing 1.926 ms [1.886 ms, 1.966 ms] 458.646 µs (31.3%)
  • candidate results
Variant Execution Time [CI 0.99] Δ no_agent
no_agent 1.468 ms [1.456 ms, 1.479 ms] -
appsec 2.343 ms [2.301 ms, 2.384 ms] 875.231 µs (59.6%)
iast 2.082 ms [2.03 ms, 2.135 ms] 614.727 µs (41.9%)
iast_GLOBAL 2.124 ms [2.071 ms, 2.177 ms] 656.088 µs (44.7%)
profiling 1.954 ms [1.911 ms, 1.997 ms] 486.726 µs (33.2%)
tracing 1.935 ms [1.894 ms, 1.976 ms] 467.266 µs (31.8%)

Copy link
Contributor

@PerfectSlayer PerfectSlayer left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good 👍
It does not target project/context but it should be okay as it is not included in any module for now.

We can merge it and iterate on the doc (want to add package level documentation too) and start building context propagation API too.

@mcculls mcculls force-pushed the mcculls/introduce-context-component branch 2 times, most recently from f65e403 to a416c70 Compare December 20, 2024 14:08
@mcculls mcculls force-pushed the mcculls/introduce-context-component branch from 08487fb to f93396d Compare December 20, 2024 17:13
@mcculls mcculls merged commit 37acd7b into master Dec 20, 2024
148 checks passed
@mcculls mcculls deleted the mcculls/introduce-context-component branch December 20, 2024 20:40
@github-actions github-actions bot added this to the 1.45.0 milestone Dec 20, 2024
svc-squareup-copybara pushed a commit to cashapp/misk that referenced this pull request Jan 9, 2025
| Package | Type | Package file | Manager | Update | Change |
|---|---|---|---|---|---|
|
[com.google.api.grpc:proto-google-common-protos](https://github.com/googleapis/sdk-platform-java)
| dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.50.0` -> `2.50.1` |
|
[com.google.cloud:google-cloud-core-http](https://github.com/googleapis/sdk-platform-java)
| dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.49.0` -> `2.49.1` |
|
[com.google.cloud:google-cloud-core](https://github.com/googleapis/sdk-platform-java)
| dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.49.0` -> `2.49.1` |
| [com.google.api:gax](https://github.com/googleapis/sdk-platform-java)
| dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.59.0` -> `2.59.1` |
| [com.datadoghq:dd-trace-api](https://github.com/datadog/dd-trace-java)
| dependencies | misk/gradle/libs.versions.toml | gradle | minor |
`1.44.1` -> `1.45.0` |
| [com.datadoghq:dd-trace-ot](https://github.com/datadog/dd-trace-java)
| dependencies | misk/gradle/libs.versions.toml | gradle | minor |
`1.44.1` -> `1.45.0` |
| [software.amazon.awssdk:sdk-core](https://aws.amazon.com/sdkforjava) |
dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.29.47` -> `2.29.48` |
|
[software.amazon.awssdk:dynamodb-enhanced](https://aws.amazon.com/sdkforjava)
| dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.29.47` -> `2.29.48` |
| [software.amazon.awssdk:dynamodb](https://aws.amazon.com/sdkforjava) |
dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.29.47` -> `2.29.48` |
| [software.amazon.awssdk:aws-core](https://aws.amazon.com/sdkforjava) |
dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.29.47` -> `2.29.48` |
| [software.amazon.awssdk:bom](https://aws.amazon.com/sdkforjava) |
dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.29.47` -> `2.29.48` |
| [software.amazon.awssdk:auth](https://aws.amazon.com/sdkforjava) |
dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.29.47` -> `2.29.48` |

---

### Release Notes

<details>
<summary>datadog/dd-trace-java (com.datadoghq:dd-trace-api)</summary>

###
[`v1.45.0`](https://github.com/DataDog/dd-trace-java/releases/tag/v1.45.0):
1.45.0

##### Breaking changes

> \[!WARNING]\
> Support for custom scope manager using OpenTelemetry tracer artifact
(`dd-trace-ot`) is dropped.
> Tracing with OpenTracing API and custom scope manager will continue to
work on 1.44.x releases.

##### Components

##### Application Security Management (IAST)

- ✨ Add propagation to URI#toURL method
([#&#8203;8146](DataDog/dd-trace-java#8146) -
[@&#8203;manuel-alvarez-alvarez](https://github.com/manuel-alvarez-alvarez))
- ✨ Increase IAST propagation to StringBuilder setLength
([#&#8203;8119](DataDog/dd-trace-java#8119) -
[@&#8203;Mariovido](https://github.com/Mariovido))
- ✨ Increase IAST propagation to StringBuffer append
([#&#8203;8082](DataDog/dd-trace-java#8082) -
[@&#8203;Mariovido](https://github.com/Mariovido))
- ✨ Handle IAST security controls custom validation and
sanitization methods
([#&#8203;7997](DataDog/dd-trace-java#7997) -
[@&#8203;jandro996](https://github.com/jandro996))

##### Application Security Management (WAF)

- ✨ Update user lifecycle tracking to V3
([#&#8203;8108](DataDog/dd-trace-java#8108) -
[@&#8203;manuel-alvarez-alvarez](https://github.com/manuel-alvarez-alvarez))
- ✨ Exploit prevention for Shell Injection / Command Injection
([#&#8203;7615](DataDog/dd-trace-java#7615) -
[@&#8203;jandro996](https://github.com/jandro996))

##### Build & Tooling

- 💡 Support instrumentation of repackaged libraries
([#&#8203;8153](DataDog/dd-trace-java#8153) -
[@&#8203;mcculls](https://github.com/mcculls))
- ✨ Configure native image build setting for JDK-22 based
GraalVM
([#&#8203;8092](DataDog/dd-trace-java#8092) -
[@&#8203;MattAlp](https://github.com/MattAlp))

##### Database Monitoring

- ✨ Add full APM/DBM mode for Oracle
([#&#8203;8090](DataDog/dd-trace-java#8090) -
[@&#8203;nenadnoveljic](https://github.com/nenadnoveljic))

##### Dynamic Instrumentation

- 🐛 make local var hoisting disabled by default
([#&#8203;8158](DataDog/dd-trace-java#8158) -
[@&#8203;jpbempel](https://github.com/jpbempel))
- 🐛 Fix var hoisting issue when no previous store
([#&#8203;8122](DataDog/dd-trace-java#8122) -
[@&#8203;jpbempel](https://github.com/jpbempel))
- ✨ Only decorate spans without code origin information
([#&#8203;8105](DataDog/dd-trace-java#8105) -
[@&#8203;evanchooly](https://github.com/evanchooly))
- 🐛 Fix suspend Kotlin methods instrumentation
([#&#8203;8080](DataDog/dd-trace-java#8080) -
[@&#8203;jpbempel](https://github.com/jpbempel))
- 🐛 Fix class file version detection
([#&#8203;8057](DataDog/dd-trace-java#8057) -
[@&#8203;jpbempel](https://github.com/jpbempel))

##### GraalVM native-image

- ✨ Configure native image build setting for JDK-22 based
GraalVM
([#&#8203;8092](DataDog/dd-trace-java#8092) -
[@&#8203;MattAlp](https://github.com/MattAlp))

##### ML Observability (LLMObs)

- ✨🧪 Add LLMObs configuration
([#&#8203;8076](DataDog/dd-trace-java#8076) -
[@&#8203;gary-huang](https://github.com/gary-huang))

##### Metrics

- Bump integrations-core submodule to 7.60.0
([#&#8203;8098](DataDog/dd-trace-java#8098) -
[@&#8203;mcculls](https://github.com/mcculls))
- Upgrade to java-dogstatsd-client v4.4.3
([#&#8203;8096](DataDog/dd-trace-java#8096) -
[@&#8203;mcculls](https://github.com/mcculls))

##### OpenTracing

- ⚠️🧹 Remove custom scope manager support
([#&#8203;8164](DataDog/dd-trace-java#8164) -
[@&#8203;PerfectSlayer](https://github.com/PerfectSlayer))

##### Telemetry

- ✨ Retry telemetry requests if CI Visibility is enabled
([#&#8203;8147](DataDog/dd-trace-java#8147) -
[@&#8203;nikita-tkachenko-datadog](https://github.com/nikita-tkachenko-datadog))
- ✨ Add configurable Dependency service resolution period
([#&#8203;8079](DataDog/dd-trace-java#8079) -
[@&#8203;jandro996](https://github.com/jandro996))

##### Testing

- 🐛 Remove restriction to not run vertx4 latest tests on java 17
([#&#8203;8133](DataDog/dd-trace-java#8133) -
[@&#8203;vandonr](https://github.com/vandonr))

##### Tracer core

- ✨ Defer remote components to avoid OkHttp class-loading
side-effects
([#&#8203;8131](DataDog/dd-trace-java#8131) -
[@&#8203;mcculls](https://github.com/mcculls))
- ✨ Improve Context API null handling and Javadoc
([#&#8203;8129](DataDog/dd-trace-java#8129) -
[@&#8203;PerfectSlayer](https://github.com/PerfectSlayer))
- 🐛⚡ Avoid performing blocking I/O operation on application
thread
([#&#8203;8120](DataDog/dd-trace-java#8120) -
[@&#8203;mcculls](https://github.com/mcculls))
- 💡 Introduce a shared context component, independent of tracing
([#&#8203;8117](DataDog/dd-trace-java#8117) -
[@&#8203;mcculls](https://github.com/mcculls))
- ✨ Improves ServiceNameCollector
([#&#8203;8109](DataDog/dd-trace-java#8109) -
[@&#8203;amarziali](https://github.com/amarziali))
- Upgrade to ASM 9.7.1 (adds new constant for Java 24)
([#&#8203;8097](DataDog/dd-trace-java#8097) -
[@&#8203;mcculls](https://github.com/mcculls))
- 🐛 Dynamically evaluate service name for message consumers
([#&#8203;8088](DataDog/dd-trace-java#8088) -
[@&#8203;amarziali](https://github.com/amarziali))

##### Serverless

- 🐛 Add avoid double instrumenting lambda non-streaming handlers.
([#&#8203;8073](DataDog/dd-trace-java#8073) -
[@&#8203;purple4reina](https://github.com/purple4reina))

##### Instrumentations

##### AWS SDK instrumentation

- 💡 Instrument EMR's relocated AWS SDK
([#&#8203;8157](DataDog/dd-trace-java#8157) -
[@&#8203;mcculls](https://github.com/mcculls))

##### Eclipse Vert.x instrumentation

- 🐛 Remove restriction to not run vertx4 latest tests on java 17
([#&#8203;8133](DataDog/dd-trace-java#8133) -
[@&#8203;vandonr](https://github.com/vandonr))

##### JDBC instrumentation

- ✨ Add full APM/DBM mode for Oracle
([#&#8203;8090](DataDog/dd-trace-java#8090) -
[@&#8203;nenadnoveljic](https://github.com/nenadnoveljic))

##### Jetty instrumentation

- 🐛 Ensure jetty 12 has servlet.path starting with /
([#&#8203;8093](DataDog/dd-trace-java#8093) -
[@&#8203;github-actions](https://github.com/github-actions)\[bot])

##### JMS instrumentation

- 🧹 Re-use `javax` JMS module for `jakarta` namespace
([#&#8203;8155](DataDog/dd-trace-java#8155) -
[@&#8203;mcculls](https://github.com/mcculls))
- 🧹 Group `javax.jms` instrumentations under a single module
([#&#8203;8154](DataDog/dd-trace-java#8154) -
[@&#8203;mcculls](https://github.com/mcculls))

##### Reactor instrumentation

- 🐛 Reactor: early propagate span in context when subscribing
([#&#8203;8166](DataDog/dd-trace-java#8166) -
[@&#8203;amarziali](https://github.com/amarziali))

</details>

---

### Configuration

📅 **Schedule**: Branch creation - "after 6pm every weekday,before 2am
every weekday" in timezone Australia/Melbourne, Automerge - At any time
(no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you
are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the
rebase/retry checkbox.

👻 **Immortal**: This PR will be recreated if closed unmerged. Get
[config help](https://github.com/renovatebot/renovate/discussions) if
that's undesired.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR has been generated by [Renovate
Bot](https://github.com/renovatebot/renovate).

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

Successfully merging this pull request may close these issues.

3 participants