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

Defer remote components to avoid OkHttp class-loading side-effects #8131

Merged
merged 8 commits into from
Dec 30, 2024

Conversation

mcculls
Copy link
Contributor

@mcculls mcculls commented Dec 28, 2024

What Does This Do

  1. Add ability to pause remote components until SharedCommunicationObjects is ready for remote I/O

  2. Use this to install tracer and logs-intake as soon as necessary, but still defer any remote components until when use of OkHttp is allowed

  3. Remove exemption where we didn't defer if the custom logging manager or JMX builder was on the system classpath (because previously the main thread would find it there if OkHttp triggered initialization of JUL.)

    We now make OkHttp calls from our own background threads to avoid blocking the main thread, but our threads are isolated from the system classloader - so this exemption no longer makes sense and should be removed

Motivation

Resolves some spurious failures in the log-injection smoke tests for the IBM Java 8 JDK.

Contributor Checklist

Jira ticket: [PROJ-IDENT]

@mcculls mcculls added type: enhancement comp: core Tracer core run-tests: ibm8 Run tests using IBM 8 JDK run-tests: all Run all tests labels Dec 28, 2024
or JMX builder was on the system classpath (because the main thread
would find it there if OkHttp triggered initialization of JUL.).

We now make OkHttp calls from our own background threads, which are
isolated from the system classloader, not the main thread - so this
exemption no longer makes sense.
@pr-commenter
Copy link

pr-commenter bot commented Dec 28, 2024

Benchmarks

Startup

Parameters

Baseline Candidate
baseline_or_candidate baseline candidate
git_branch master mcculls/defer-remote-components
git_commit_date 1734944119 1735430036
git_commit_sha 46b5986 c9cf18f
release_version 1.45.0-SNAPSHOT~46b5986f6a 1.45.0-SNAPSHOT~c9cf18f149
See matching parameters
Baseline Candidate
application insecure-bank insecure-bank
ci_job_date 1735432355 1735432355
ci_job_id 750502259 750502259
ci_pipeline_id 51874502 51874502
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 1 performance improvements and 1 performance regressions! Performance is the same for 54 metrics, 7 unstable metrics.

scenario Δ mean execution_time candidate mean execution_time baseline mean execution_time
scenario:startup:petclinic:tracing:AppSec better
[-6.188ms; -1.799ms] or [-10.456%; -3.040%]
55.189ms 59.182ms
scenario:startup:petclinic:tracing:Remote Config worse
[+14.487µs; +42.259µs] or [+2.139%; +6.238%]
705.789µs 677.416µs
Startup time reports for insecure-bank
gantt
    title insecure-bank - global startup overhead: candidate=1.45.0-SNAPSHOT~c9cf18f149, baseline=1.45.0-SNAPSHOT~46b5986f6a

    dateFormat X
    axisFormat %s
section tracing
Agent [baseline] (1.054 s) : 0, 1054030
Total [baseline] (8.616 s) : 0, 8616440
Agent [candidate] (1.051 s) : 0, 1051164
Total [candidate] (8.651 s) : 0, 8651367
section iast
Agent [baseline] (1.179 s) : 0, 1178984
Total [baseline] (9.239 s) : 0, 9239308
Agent [candidate] (1.185 s) : 0, 1185391
Total [candidate] (9.247 s) : 0, 9247323
section iast_HARDCODED_SECRET_DISABLED
Agent [baseline] (1.185 s) : 0, 1184923
Total [baseline] (9.251 s) : 0, 9250611
Agent [candidate] (1.176 s) : 0, 1176348
Total [candidate] (9.182 s) : 0, 9182369
section iast_TELEMETRY_OFF
Agent [baseline] (1.171 s) : 0, 1171436
Total [baseline] (9.212 s) : 0, 9211835
Agent [candidate] (1.175 s) : 0, 1174694
Total [candidate] (9.174 s) : 0, 9174424
Loading
  • baseline results
Module Variant Duration Δ tracing
Agent tracing 1.054 s -
Agent iast 1.179 s 124.953 ms (11.9%)
Agent iast_HARDCODED_SECRET_DISABLED 1.185 s 130.892 ms (12.4%)
Agent iast_TELEMETRY_OFF 1.171 s 117.405 ms (11.1%)
Total tracing 8.616 s -
Total iast 9.239 s 622.868 ms (7.2%)
Total iast_HARDCODED_SECRET_DISABLED 9.251 s 634.171 ms (7.4%)
Total iast_TELEMETRY_OFF 9.212 s 595.395 ms (6.9%)
  • candidate results
Module Variant Duration Δ tracing
Agent tracing 1.051 s -
Agent iast 1.185 s 134.226 ms (12.8%)
Agent iast_HARDCODED_SECRET_DISABLED 1.176 s 125.184 ms (11.9%)
Agent iast_TELEMETRY_OFF 1.175 s 123.53 ms (11.8%)
Total tracing 8.651 s -
Total iast 9.247 s 595.956 ms (6.9%)
Total iast_HARDCODED_SECRET_DISABLED 9.182 s 531.002 ms (6.1%)
Total iast_TELEMETRY_OFF 9.174 s 523.056 ms (6.0%)
gantt
    title insecure-bank - break down per module: candidate=1.45.0-SNAPSHOT~c9cf18f149, baseline=1.45.0-SNAPSHOT~46b5986f6a

    dateFormat X
    axisFormat %s
section tracing
BytebuddyAgent [baseline] (711.252 ms) : 0, 711252
BytebuddyAgent [candidate] (711.825 ms) : 0, 711825
GlobalTracer [baseline] (256.947 ms) : 0, 256947
GlobalTracer [candidate] (256.073 ms) : 0, 256073
AppSec [baseline] (56.793 ms) : 0, 56793
AppSec [candidate] (54.845 ms) : 0, 54845
Remote Config [baseline] (697.454 µs) : 0, 697
Remote Config [candidate] (705.571 µs) : 0, 706
Telemetry [baseline] (13.506 ms) : 0, 13506
Telemetry [candidate] (12.73 ms) : 0, 12730
section iast
BytebuddyAgent [baseline] (828.783 ms) : 0, 828783
BytebuddyAgent [candidate] (833.53 ms) : 0, 833530
GlobalTracer [baseline] (247.197 ms) : 0, 247197
GlobalTracer [candidate] (247.646 ms) : 0, 247646
AppSec [baseline] (57.656 ms) : 0, 57656
AppSec [candidate] (58.125 ms) : 0, 58125
IAST [baseline] (21.316 ms) : 0, 21316
IAST [candidate] (21.614 ms) : 0, 21614
Remote Config [baseline] (644.524 µs) : 0, 645
Remote Config [candidate] (661.98 µs) : 0, 662
Telemetry [baseline] (8.464 ms) : 0, 8464
Telemetry [candidate] (8.699 ms) : 0, 8699
section iast_HARDCODED_SECRET_DISABLED
BytebuddyAgent [baseline] (833.622 ms) : 0, 833622
BytebuddyAgent [candidate] (826.363 ms) : 0, 826363
GlobalTracer [baseline] (247.596 ms) : 0, 247596
GlobalTracer [candidate] (246.385 ms) : 0, 246385
AppSec [baseline] (58.316 ms) : 0, 58316
AppSec [candidate] (58.249 ms) : 0, 58249
IAST [baseline] (21.256 ms) : 0, 21256
IAST [candidate] (21.158 ms) : 0, 21158
Remote Config [baseline] (655.442 µs) : 0, 655
Remote Config [candidate] (705.179 µs) : 0, 705
Telemetry [baseline] (8.524 ms) : 0, 8524
Telemetry [candidate] (8.522 ms) : 0, 8522
section iast_TELEMETRY_OFF
BytebuddyAgent [baseline] (823.532 ms) : 0, 823532
BytebuddyAgent [candidate] (825.243 ms) : 0, 825243
GlobalTracer [baseline] (245.852 ms) : 0, 245852
GlobalTracer [candidate] (246.698 ms) : 0, 246698
AppSec [baseline] (57.557 ms) : 0, 57557
AppSec [candidate] (57.863 ms) : 0, 57863
IAST [baseline] (20.694 ms) : 0, 20694
IAST [candidate] (20.886 ms) : 0, 20886
Remote Config [baseline] (651.519 µs) : 0, 652
Remote Config [candidate] (656.967 µs) : 0, 657
Telemetry [baseline] (8.277 ms) : 0, 8277
Telemetry [candidate] (8.379 ms) : 0, 8379
Loading
Startup time reports for petclinic
gantt
    title petclinic - global startup overhead: candidate=1.45.0-SNAPSHOT~c9cf18f149, baseline=1.45.0-SNAPSHOT~46b5986f6a

    dateFormat X
    axisFormat %s
section tracing
Agent [baseline] (1.054 s) : 0, 1054222
Total [baseline] (10.366 s) : 0, 10365926
Agent [candidate] (1.052 s) : 0, 1051540
Total [candidate] (10.434 s) : 0, 10434404
section appsec
Agent [baseline] (1.185 s) : 0, 1184964
Total [baseline] (10.716 s) : 0, 10716196
Agent [candidate] (1.188 s) : 0, 1188164
Total [candidate] (10.71 s) : 0, 10710184
section iast
Agent [baseline] (1.179 s) : 0, 1179028
Total [baseline] (10.894 s) : 0, 10893991
Agent [candidate] (1.179 s) : 0, 1178699
Total [candidate] (10.924 s) : 0, 10924085
section profiling
Agent [baseline] (1.272 s) : 0, 1271527
Total [baseline] (10.826 s) : 0, 10825952
Agent [candidate] (1.275 s) : 0, 1275136
Total [candidate] (10.795 s) : 0, 10795264
Loading
  • baseline results
Module Variant Duration Δ tracing
Agent tracing 1.054 s -
Agent appsec 1.185 s 130.743 ms (12.4%)
Agent iast 1.179 s 124.806 ms (11.8%)
Agent profiling 1.272 s 217.305 ms (20.6%)
Total tracing 10.366 s -
Total appsec 10.716 s 350.269 ms (3.4%)
Total iast 10.894 s 528.064 ms (5.1%)
Total profiling 10.826 s 460.026 ms (4.4%)
  • candidate results
Module Variant Duration Δ tracing
Agent tracing 1.052 s -
Agent appsec 1.188 s 136.624 ms (13.0%)
Agent iast 1.179 s 127.159 ms (12.1%)
Agent profiling 1.275 s 223.596 ms (21.3%)
Total tracing 10.434 s -
Total appsec 10.71 s 275.781 ms (2.6%)
Total iast 10.924 s 489.682 ms (4.7%)
Total profiling 10.795 s 360.86 ms (3.5%)
gantt
    title petclinic - break down per module: candidate=1.45.0-SNAPSHOT~c9cf18f149, baseline=1.45.0-SNAPSHOT~46b5986f6a

    dateFormat X
    axisFormat %s
section tracing
BytebuddyAgent [baseline] (712.306 ms) : 0, 712306
BytebuddyAgent [candidate] (710.866 ms) : 0, 710866
GlobalTracer [baseline] (256.071 ms) : 0, 256071
GlobalTracer [candidate] (256.177 ms) : 0, 256177
AppSec [baseline] (59.182 ms) : 0, 59182
AppSec [candidate] (55.189 ms) : 0, 55189
Remote Config [baseline] (677.416 µs) : 0, 677
Remote Config [candidate] (705.789 µs) : 0, 706
Telemetry [baseline] (11.06 ms) : 0, 11060
Telemetry [candidate] (13.576 ms) : 0, 13576
section appsec
BytebuddyAgent [baseline] (728.429 ms) : 0, 728429
BytebuddyAgent [candidate] (730.547 ms) : 0, 730547
GlobalTracer [baseline] (252.843 ms) : 0, 252843
GlobalTracer [candidate] (253.2 ms) : 0, 253200
AppSec [baseline] (170.204 ms) : 0, 170204
AppSec [candidate] (170.659 ms) : 0, 170659
IAST [baseline] (19.335 ms) : 0, 19335
IAST [candidate] (20.125 ms) : 0, 20125
Remote Config [baseline] (649.577 µs) : 0, 650
Remote Config [candidate] (659.369 µs) : 0, 659
Telemetry [baseline] (8.299 ms) : 0, 8299
Telemetry [candidate] (7.998 ms) : 0, 7998
section iast
BytebuddyAgent [baseline] (829.303 ms) : 0, 829303
BytebuddyAgent [candidate] (828.821 ms) : 0, 828821
GlobalTracer [baseline] (246.734 ms) : 0, 246734
GlobalTracer [candidate] (246.648 ms) : 0, 246648
AppSec [baseline] (57.846 ms) : 0, 57846
AppSec [candidate] (57.862 ms) : 0, 57862
IAST [baseline] (21.092 ms) : 0, 21092
IAST [candidate] (21.155 ms) : 0, 21155
Remote Config [baseline] (644.318 µs) : 0, 644
Remote Config [candidate] (652.136 µs) : 0, 652
Telemetry [baseline] (8.5 ms) : 0, 8500
Telemetry [candidate] (8.515 ms) : 0, 8515
section profiling
BytebuddyAgent [baseline] (701.077 ms) : 0, 701077
BytebuddyAgent [candidate] (702.558 ms) : 0, 702558
GlobalTracer [baseline] (370.553 ms) : 0, 370553
GlobalTracer [candidate] (372.442 ms) : 0, 372442
AppSec [baseline] (54.027 ms) : 0, 54027
AppSec [candidate] (54.243 ms) : 0, 54243
Remote Config [baseline] (655.908 µs) : 0, 656
Remote Config [candidate] (671.064 µs) : 0, 671
Telemetry [baseline] (7.817 ms) : 0, 7817
Telemetry [candidate] (7.832 ms) : 0, 7832
ProfilingAgent [baseline] (95.731 ms) : 0, 95731
ProfilingAgent [candidate] (95.497 ms) : 0, 95497
Profiling [baseline] (95.758 ms) : 0, 95758
Profiling [candidate] (95.526 ms) : 0, 95526
Loading

Load

Parameters

Baseline Candidate
baseline_or_candidate baseline candidate
end_time 2024-12-29T00:02:57 2024-12-29T00:09:57
git_branch master mcculls/defer-remote-components
git_commit_date 1734944119 1735430036
git_commit_sha 46b5986 c9cf18f
release_version 1.45.0-SNAPSHOT~46b5986f6a 1.45.0-SNAPSHOT~c9cf18f149
start_time 2024-12-29T00:02:43 2024-12-29T00:09:43
See matching parameters
Baseline Candidate
application insecure-bank insecure-bank
ci_job_date 1735431351 1735431351
ci_job_id 750502260 750502260
ci_pipeline_id 51874502 51874502
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~c9cf18f149, baseline=1.45.0-SNAPSHOT~46b5986f6a
    dateFormat X
    axisFormat %s
section baseline
no_agent (1.358 ms) : 1338, 1377
.   : milestone, 1358,
appsec (1.765 ms) : 1741, 1789
.   : milestone, 1765,
appsec_no_iast (1.752 ms) : 1726, 1778
.   : milestone, 1752,
iast (1.505 ms) : 1482, 1528
.   : milestone, 1505,
profiling (1.567 ms) : 1543, 1592
.   : milestone, 1567,
tracing (1.476 ms) : 1451, 1501
.   : milestone, 1476,
section candidate
no_agent (1.372 ms) : 1351, 1392
.   : milestone, 1372,
appsec (1.769 ms) : 1746, 1793
.   : milestone, 1769,
appsec_no_iast (1.776 ms) : 1752, 1801
.   : milestone, 1776,
iast (1.512 ms) : 1489, 1534
.   : milestone, 1512,
profiling (1.515 ms) : 1491, 1539
.   : milestone, 1515,
tracing (1.499 ms) : 1475, 1523
.   : milestone, 1499,
Loading
  • baseline results
Variant Request duration [CI 0.99] Δ no_agent
no_agent 1.358 ms [1.338 ms, 1.377 ms] -
appsec 1.765 ms [1.741 ms, 1.789 ms] 407.876 µs (30.0%)
appsec_no_iast 1.752 ms [1.726 ms, 1.778 ms] 394.059 µs (29.0%)
iast 1.505 ms [1.482 ms, 1.528 ms] 147.209 µs (10.8%)
profiling 1.567 ms [1.543 ms, 1.592 ms] 209.83 µs (15.5%)
tracing 1.476 ms [1.451 ms, 1.501 ms] 118.682 µs (8.7%)
  • candidate results
Variant Request duration [CI 0.99] Δ no_agent
no_agent 1.372 ms [1.351 ms, 1.392 ms] -
appsec 1.769 ms [1.746 ms, 1.793 ms] 397.434 µs (29.0%)
appsec_no_iast 1.776 ms [1.752 ms, 1.801 ms] 404.674 µs (29.5%)
iast 1.512 ms [1.489 ms, 1.534 ms] 139.903 µs (10.2%)
profiling 1.515 ms [1.491 ms, 1.539 ms] 142.876 µs (10.4%)
tracing 1.499 ms [1.475 ms, 1.523 ms] 127.327 µs (9.3%)
Request duration reports for insecure-bank
gantt
    title insecure-bank - request duration [CI 0.99] : candidate=1.45.0-SNAPSHOT~c9cf18f149, baseline=1.45.0-SNAPSHOT~46b5986f6a
    dateFormat X
    axisFormat %s
section baseline
no_agent (378.296 µs) : 357, 400
.   : milestone, 378,
iast (495.821 µs) : 474, 518
.   : milestone, 496,
iast_FULL (657.279 µs) : 636, 679
.   : milestone, 657,
iast_GLOBAL (525.683 µs) : 504, 547
.   : milestone, 526,
iast_HARDCODED_SECRET_DISABLED (493.715 µs) : 472, 515
.   : milestone, 494,
iast_INACTIVE (452.718 µs) : 431, 474
.   : milestone, 453,
iast_TELEMETRY_OFF (480.982 µs) : 460, 502
.   : milestone, 481,
tracing (460.925 µs) : 440, 482
.   : milestone, 461,
section candidate
no_agent (387.95 µs) : 368, 408
.   : milestone, 388,
iast (494.661 µs) : 473, 516
.   : milestone, 495,
iast_FULL (660.087 µs) : 638, 682
.   : milestone, 660,
iast_GLOBAL (524.412 µs) : 502, 547
.   : milestone, 524,
iast_HARDCODED_SECRET_DISABLED (496.012 µs) : 474, 518
.   : milestone, 496,
iast_INACTIVE (452.058 µs) : 431, 473
.   : milestone, 452,
iast_TELEMETRY_OFF (481.591 µs) : 460, 503
.   : milestone, 482,
tracing (455.045 µs) : 434, 476
.   : milestone, 455,
Loading
  • baseline results
Variant Request duration [CI 0.99] Δ no_agent
no_agent 378.296 µs [357.025 µs, 399.568 µs] -
iast 495.821 µs [474.092 µs, 517.551 µs] 117.525 µs (31.1%)
iast_FULL 657.279 µs [635.529 µs, 679.029 µs] 278.982 µs (73.7%)
iast_GLOBAL 525.683 µs [503.87 µs, 547.495 µs] 147.386 µs (39.0%)
iast_HARDCODED_SECRET_DISABLED 493.715 µs [471.997 µs, 515.432 µs] 115.418 µs (30.5%)
iast_INACTIVE 452.718 µs [431.231 µs, 474.204 µs] 74.421 µs (19.7%)
iast_TELEMETRY_OFF 480.982 µs [459.571 µs, 502.394 µs] 102.686 µs (27.1%)
tracing 460.925 µs [439.948 µs, 481.903 µs] 82.629 µs (21.8%)
  • candidate results
Variant Request duration [CI 0.99] Δ no_agent
no_agent 387.95 µs [368.342 µs, 407.559 µs] -
iast 494.661 µs [472.892 µs, 516.431 µs] 106.711 µs (27.5%)
iast_FULL 660.087 µs [638.449 µs, 681.726 µs] 272.137 µs (70.1%)
iast_GLOBAL 524.412 µs [502.191 µs, 546.632 µs] 136.461 µs (35.2%)
iast_HARDCODED_SECRET_DISABLED 496.012 µs [474.416 µs, 517.607 µs] 108.061 µs (27.9%)
iast_INACTIVE 452.058 µs [431.134 µs, 472.983 µs] 64.108 µs (16.5%)
iast_TELEMETRY_OFF 481.591 µs [460.078 µs, 503.104 µs] 93.641 µs (24.1%)
tracing 455.045 µs [434.209 µs, 475.88 µs] 67.094 µs (17.3%)

Dacapo

Parameters

Baseline Candidate
baseline_or_candidate baseline candidate
git_branch master mcculls/defer-remote-components
git_commit_date 1734944119 1735430036
git_commit_sha 46b5986 c9cf18f
release_version 1.45.0-SNAPSHOT~46b5986f6a 1.45.0-SNAPSHOT~c9cf18f149
See matching parameters
Baseline Candidate
application biojava biojava
ci_job_date 1735432081 1735432081
ci_job_id 750502261 750502261
ci_pipeline_id 51874502 51874502
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 tomcat
gantt
    title tomcat - execution time [CI 0.99] : candidate=1.45.0-SNAPSHOT~c9cf18f149, baseline=1.45.0-SNAPSHOT~46b5986f6a
    dateFormat X
    axisFormat %s
section baseline
no_agent (1.464 ms) : 1453, 1476
.   : milestone, 1464,
appsec (2.344 ms) : 2302, 2386
.   : milestone, 2344,
iast (2.084 ms) : 2032, 2137
.   : milestone, 2084,
iast_GLOBAL (2.126 ms) : 2073, 2180
.   : milestone, 2126,
profiling (1.93 ms) : 1889, 1972
.   : milestone, 1930,
tracing (1.926 ms) : 1886, 1967
.   : milestone, 1926,
section candidate
no_agent (1.471 ms) : 1460, 1483
.   : milestone, 1471,
appsec (2.339 ms) : 2297, 2380
.   : milestone, 2339,
iast (2.075 ms) : 2022, 2127
.   : milestone, 2075,
iast_GLOBAL (2.135 ms) : 2081, 2188
.   : milestone, 2135,
profiling (1.969 ms) : 1926, 2012
.   : milestone, 1969,
tracing (1.923 ms) : 1883, 1964
.   : milestone, 1923,
Loading
  • baseline results
Variant Execution Time [CI 0.99] Δ no_agent
no_agent 1.464 ms [1.453 ms, 1.476 ms] -
appsec 2.344 ms [2.302 ms, 2.386 ms] 880.201 µs (60.1%)
iast 2.084 ms [2.032 ms, 2.137 ms] 620.338 µs (42.4%)
iast_GLOBAL 2.126 ms [2.073 ms, 2.18 ms] 662.257 µs (45.2%)
profiling 1.93 ms [1.889 ms, 1.972 ms] 466.274 µs (31.8%)
tracing 1.926 ms [1.886 ms, 1.967 ms] 462.031 µs (31.6%)
  • candidate results
Variant Execution Time [CI 0.99] Δ no_agent
no_agent 1.471 ms [1.46 ms, 1.483 ms] -
appsec 2.339 ms [2.297 ms, 2.38 ms] 867.508 µs (59.0%)
iast 2.075 ms [2.022 ms, 2.127 ms] 603.346 µs (41.0%)
iast_GLOBAL 2.135 ms [2.081 ms, 2.188 ms] 663.442 µs (45.1%)
profiling 1.969 ms [1.926 ms, 2.012 ms] 497.98 µs (33.8%)
tracing 1.923 ms [1.883 ms, 1.964 ms] 451.678 µs (30.7%)
Execution time for biojava
gantt
    title biojava - execution time [CI 0.99] : candidate=1.45.0-SNAPSHOT~c9cf18f149, baseline=1.45.0-SNAPSHOT~46b5986f6a
    dateFormat X
    axisFormat %s
section baseline
no_agent (14.877 s) : 14877000, 14877000
.   : milestone, 14877000,
appsec (14.838 s) : 14838000, 14838000
.   : milestone, 14838000,
iast (18.884 s) : 18884000, 18884000
.   : milestone, 18884000,
iast_GLOBAL (17.833 s) : 17833000, 17833000
.   : milestone, 17833000,
profiling (14.808 s) : 14808000, 14808000
.   : milestone, 14808000,
tracing (14.889 s) : 14889000, 14889000
.   : milestone, 14889000,
section candidate
no_agent (14.694 s) : 14694000, 14694000
.   : milestone, 14694000,
appsec (15.145 s) : 15145000, 15145000
.   : milestone, 15145000,
iast (18.846 s) : 18846000, 18846000
.   : milestone, 18846000,
iast_GLOBAL (17.795 s) : 17795000, 17795000
.   : milestone, 17795000,
profiling (14.922 s) : 14922000, 14922000
.   : milestone, 14922000,
tracing (14.955 s) : 14955000, 14955000
.   : milestone, 14955000,
Loading
  • baseline results
Variant Execution Time [CI 0.99] Δ no_agent
no_agent 14.877 s [14.877 s, 14.877 s] -
appsec 14.838 s [14.838 s, 14.838 s] -39.0 ms (-0.3%)
iast 18.884 s [18.884 s, 18.884 s] 4.007 s (26.9%)
iast_GLOBAL 17.833 s [17.833 s, 17.833 s] 2.956 s (19.9%)
profiling 14.808 s [14.808 s, 14.808 s] -69.0 ms (-0.5%)
tracing 14.889 s [14.889 s, 14.889 s] 12.0 ms (0.1%)
  • candidate results
Variant Execution Time [CI 0.99] Δ no_agent
no_agent 14.694 s [14.694 s, 14.694 s] -
appsec 15.145 s [15.145 s, 15.145 s] 451.0 ms (3.1%)
iast 18.846 s [18.846 s, 18.846 s] 4.152 s (28.3%)
iast_GLOBAL 17.795 s [17.795 s, 17.795 s] 3.101 s (21.1%)
profiling 14.922 s [14.922 s, 14.922 s] 228.0 ms (1.6%)
tracing 14.955 s [14.955 s, 14.955 s] 261.0 ms (1.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 overall. A bit sad to decrease the code coverage though 😞

This kind of PR reminds me we need to define general components and events as platform… (similar to the ones that would help with CRaC).

@@ -25,7 +25,7 @@ dependencies {
}

ext {
minimumBranchCoverage = 0.6
minimumBranchCoverage = 0.5
Copy link
Contributor

Choose a reason for hiding this comment

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

Is the whole module not testable or it the cost too high?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

It's the double-checked lock that tips things over - attempting to cover all the cases for this piece of code would be very intensive (you'd end up testing the narrow volatile visibility edge.) There are other branches in SharedCommunicationObjects which are not currently tested which is why we're at this boundary to begin with, but adding tests for those unrelated pieces of code in this PR is IMHO confusing for future reviewers.

I could just exclude SharedCommunicationObjects from branch coverage completely, but that feels worse - it's already excluded from instrumentation coverage - so reducing the coverage requirement here by a small amount is the least worst option.

The proper solution is to add tests to increase coverage in a separate PR, as a separate work item.

try {
// remote components were paused for custom log-manager/jmx-builder
// add small delay before resuming remote I/O to help stabilization
Thread.sleep(1_000);
Copy link
Contributor

Choose a reason for hiding this comment

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

Dumb question: is this an empirical delay?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Yes - having no delay or a delay of a few 100ms caused issues because the custom log manager might not have finished its setup by the time the delay expires. The resulting JUL class-loading triggered from this thread via OkHttp could then lead to the logging setup not being complete, which can in turn lead to missing logging.

There's no good class-loader signal to tell us the custom log manager is ready, only when JUL has been touched (and if we try to be too smart then we might miss the signal, which would lead to us never resuming remote I/O)

So this is an empirical practical solution which stabilizes the test locally and on CI. That's also why it's important to install the tracer (and logs-intake collector) early so they can capture data while holding back the remote I/O. That way we avoid triggering JUL issues while not losing trace or log data.

Also note this code path is only used for very specific setups, specifically Java 8 with JFR or IBM JDKs.

@mcculls mcculls merged commit d6e2c2e into master Dec 30, 2024
209 checks passed
@mcculls mcculls deleted the mcculls/defer-remote-components branch December 30, 2024 10:14
@github-actions github-actions bot added this to the 1.45.0 milestone Dec 30, 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
Labels
comp: core Tracer core run-tests: all Run all tests run-tests: ibm8 Run tests using IBM 8 JDK type: enhancement
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants