Skip to content

Fix early OTel proxy tracers in Cache Components prerenders#95317

Merged
devjiwonchoi merged 2 commits into
canaryfrom
jiwon/test-early-otel-tracer-prerender
Jul 1, 2026
Merged

Fix early OTel proxy tracers in Cache Components prerenders#95317
devjiwonchoi merged 2 commits into
canaryfrom
jiwon/test-early-otel-tracer-prerender

Conversation

@devjiwonchoi

@devjiwonchoi devjiwonchoi commented Jun 30, 2026

Copy link
Copy Markdown
Member

Tip

Best reviewed with hide whitespace.

Why?

Cache Components prerenders can fail when an OpenTelemetry tracer is acquired before provider registration and later resolves through proxy tracer delegation:

Next.js encountered the unstable value `Math.random()` while prerendering

Current behavior: https://github.com/vercel/next.js/actions/runs/28518518762/job/84536475151?pr=95317#step:32:343

How?

Patch proxy tracer delegation to apply the same Cache Components span instrumentation used for normal tracer lookup.

Closes #94753

@github-actions

github-actions Bot commented Jun 30, 2026

Copy link
Copy Markdown
Contributor

Stats from current PR

🟢 1 improvement

Metric Canary PR Change Trend
node_modules Size 514 MB 509 MB 🟢 4.58 MB (-1%) ▄▄▄▄▄
📊 All Metrics
📖 Metrics Glossary

Dev Server Metrics:

  • Listen = TCP port starts accepting connections
  • First Request = HTTP server returns successful response
  • Cold = Fresh build (no cache)
  • Warm = With cached build artifacts

Build Metrics:

  • Fresh = Clean build (no .next directory)
  • Cached = With existing .next directory

Change Thresholds:

  • Time: Changes < 50ms AND < 10%, OR < 2% are insignificant
  • Size: Changes < 1KB AND < 1% are insignificant
  • All other changes are flagged to catch regressions

⚡ Dev Server

Metric Canary PR Change Trend
Cold (Listen) 762ms 761ms ▃▃▃▂▃
Cold (Ready in log) 762ms 767ms ▂▂▂▁▂
Cold (First Request) 1.285s 1.299s ▂▃▃▂▃
Warm (Listen) 762ms 764ms ▃▃▃▂▃
Warm (Ready in log) 757ms 765ms ▂▂▂▁▂
Warm (First Request) 595ms 598ms ▁▁▁▁▂
📦 Dev Server (Webpack) (Legacy)

📦 Dev Server (Webpack)

Metric Canary PR Change Trend
Cold (Listen) 812ms 812ms ▆▇█▆▆
Cold (Ready in log) 768ms 782ms ▇▇█▇▇
Cold (First Request) 3.331s 3.415s ▇███▇
Warm (Listen) 813ms 813ms ▆██▇▆
Warm (Ready in log) 772ms 779ms ▆▇█▇▇
Warm (First Request) 3.370s 3.371s ▇████

⚡ Production Builds

Metric Canary PR Change Trend
Fresh Build 4.896s 4.853s ▁▂▂▁▃
Cached Build 4.984s 5.000s ▁▂▂▁▃
📦 Production Builds (Webpack) (Legacy)

📦 Production Builds (Webpack)

Metric Canary PR Change Trend
Fresh Build 25.024s 24.844s ▇█▇██
Cached Build 25.134s 25.196s ▇████
node_modules Size 514 MB 509 MB 🟢 4.58 MB (-1%) ▄▄▄▄▄
📦 Bundle Sizes

Bundle Sizes

⚡ Turbopack

Client

Main Bundles
Canary PR Change
03adk3nyxvjx-.js gzip 65.5 kB N/A -
03gmyxr7dukvs.js gzip 10.3 kB N/A -
040t1q17lo593.js gzip 8.77 kB N/A -
050fhfvs7piiv.js gzip 156 B N/A -
0bb0vtp8dwsez.js gzip 450 B N/A -
0cz1d0mv5g_q7.js gzip 39.4 kB 39.4 kB
0kgbuvx1hx54k.js gzip 156 B N/A -
0nxqz3q165m2l.js gzip 220 B N/A -
0qr-1tnb7_hg5.js gzip 5.72 kB N/A -
0uilzvklme4ea.js gzip 8.76 kB N/A -
0vm62nafb2wke.js gzip 7.65 kB N/A -
0z0y83mfx-l-h.js gzip 10 kB N/A -
0zd-an3epr5y3.js gzip 71 kB N/A -
1_16n0jqv0yqo.js gzip 154 B N/A -
15ok8ydf274z0.js gzip 10.6 kB N/A -
16cqqcigykfea.js gzip 13.6 kB N/A -
17h18zxt1915l.js gzip 1.46 kB N/A -
1d9sh6odmlpyr.js gzip 155 B N/A -
1elt1qium-r2m.css gzip 115 B 115 B
1fq1h7dxad4cv.js gzip 9.44 kB N/A -
1fym-adbk_69_.js gzip 13.1 kB N/A -
1gav7nfh4y8ln.js gzip 8.76 kB N/A -
1ksqg4jk58awz.js gzip 156 B N/A -
1nqtt44qosjqg.js gzip 161 B N/A -
1vzud5nqj-9bm.js gzip 168 B N/A -
1zxeepg375efo.js gzip 14.3 kB N/A -
2ojyq0ijfa5mm.js gzip 157 B N/A -
2rypqffktcxqh.js gzip 8.69 kB N/A -
2uqsizxtehgqf.js gzip 8.79 kB N/A -
2vzktdqwbijqc.js gzip 8.74 kB N/A -
34u4qqlnr07g4.js gzip 160 B N/A -
3c244akvx_-be.js gzip 8.74 kB N/A -
3dmlemitx3ef3.js gzip 2.29 kB N/A -
3e8de9h70zjb2.js gzip 152 B N/A -
3re-ah_sd3hok.js gzip 157 B N/A -
3umfpv6uzk6cg.js gzip 13.2 kB N/A -
3w0rgqfjtus_k.js gzip 155 B N/A -
3xaxx2id8j9or.js gzip 53.5 kB N/A -
3xxy47twfujin.js gzip 156 B N/A -
4237vdj6eyslt.js gzip 8.7 kB N/A -
turbopack-08..qxbs.js gzip 3.74 kB N/A -
turbopack-0q..z14-.js gzip 3.74 kB N/A -
turbopack-1-..m1t3.js gzip 3.74 kB N/A -
turbopack-1a..o107.js gzip 3.74 kB N/A -
turbopack-1u..33cy.js gzip 3.74 kB N/A -
turbopack-1w..xl_w.js gzip 3.74 kB N/A -
turbopack-1y..hs0a.js gzip 3.75 kB N/A -
turbopack-2i..5yhp.js gzip 3.74 kB N/A -
turbopack-2p..b5m_.js gzip 3.76 kB N/A -
turbopack-3b..64o5.js gzip 3.74 kB N/A -
turbopack-3c..-mro.js gzip 3.72 kB N/A -
turbopack-3v..s-rb.js gzip 3.74 kB N/A -
turbopack-3y..pbgl.js gzip 3.74 kB N/A -
turbopack-43..nrdf.js gzip 3.74 kB N/A -
00tc16j5-eos9.js gzip N/A 1.46 kB -
07jmt8qyd8gi7.js gzip N/A 14 kB -
0doo2ilbuk8wa.js gzip N/A 8.75 kB -
0e94q_0dk46ui.js gzip N/A 8.78 kB -
0ogyixhgyduog.js gzip N/A 10 kB -
0pprs9bw-3rld.js gzip N/A 169 B -
10g3486q7mqk2.js gzip N/A 65.6 kB -
12trp8u_7nsch.js gzip N/A 155 B -
1611-v-erczbg.js gzip N/A 155 B -
170t10ub162wk.js gzip N/A 5.74 kB -
1j3imf_79m_1b.js gzip N/A 156 B -
1ja820ngxue8q.js gzip N/A 8.81 kB -
1kon91zndf-mv.js gzip N/A 8.79 kB -
1llqf2qgac_-d.js gzip N/A 8.7 kB -
1pk1jag72fdtw.js gzip N/A 155 B -
1plixaiqght6v.js gzip N/A 161 B -
1pnb6nje0uc4h.js gzip N/A 13.6 kB -
1sowj02qcv096.js gzip N/A 152 B -
2-783-os26kir.js gzip N/A 158 B -
21a8jb_-wr_wm.js gzip N/A 71 kB -
22geiudvi1dh6.js gzip N/A 2.29 kB -
23p7wy6zx0abb.js gzip N/A 10.3 kB -
24-vujjeeyskr.js gzip N/A 157 B -
2c9pj5kgyr3ep.js gzip N/A 158 B -
2gt6n4c54rx94.js gzip N/A 8.76 kB -
2vhmp74csw0ql.js gzip N/A 232 B -
30h_m0irj-q6p.js gzip N/A 221 B -
359cg_n4yikp4.js gzip N/A 10.6 kB -
38c63ct4i1cy7.js gzip N/A 449 B -
39kshdfkb5_dc.js gzip N/A 12.9 kB -
3bxtggll2q95f.js gzip N/A 13.1 kB -
3kzc9t3aw7glu.js gzip N/A 7.61 kB -
3miimvtgoivna.js gzip N/A 157 B -
3st8r8c3o2nex.js gzip N/A 160 B -
3szjnxn29zeiv.js gzip N/A 8.7 kB -
3x9p6p2p03zg6.js gzip N/A 8.77 kB -
400_0js1xr5u-.js gzip N/A 156 B -
41p3ob-rpqz88.js gzip N/A 52.3 kB -
437aglmil86r0.js gzip N/A 9.43 kB -
turbopack-0_..ln9u.js gzip N/A 3.52 kB -
turbopack-03..3jn6.js gzip N/A 3.52 kB -
turbopack-0z..x45l.js gzip N/A 3.51 kB -
turbopack-1g..v-sk.js gzip N/A 3.52 kB -
turbopack-1g..9e68.js gzip N/A 3.51 kB -
turbopack-22..ldha.js gzip N/A 3.51 kB -
turbopack-22..zhqc.js gzip N/A 3.51 kB -
turbopack-2r..k431.js gzip N/A 3.53 kB -
turbopack-35..9kwl.js gzip N/A 3.52 kB -
turbopack-3q..cvun.js gzip N/A 3.5 kB -
turbopack-3r..hmpw.js gzip N/A 3.51 kB -
turbopack-3s..ibgu.js gzip N/A 3.51 kB -
turbopack-41..n4cr.js gzip N/A 3.52 kB -
turbopack-41..ifp4.js gzip N/A 3.51 kB -
Total 466 kB 462 kB ✅ -4.77 kB

Server

Middleware
Canary PR Change
middleware-b..fest.js gzip 730 B 729 B
Total 730 B 729 B ✅ -1 B
Build Details
Build Manifests
Canary PR Change
_buildManifest.js gzip 431 B 432 B
Total 431 B 432 B ⚠️ +1 B

📦 Webpack

Client

Main Bundles
Canary PR Change
2486.HASH.js gzip 169 B N/A -
3146-HASH.js gzip 63.6 kB N/A -
39fcf99b-HASH.js gzip 62.9 kB N/A -
8443-HASH.js gzip 4.68 kB N/A -
9431-HASH.js gzip 5.62 kB N/A -
framework-HASH.js gzip 59.8 kB 59.8 kB
main-app-HASH.js gzip 255 B 252 B 🟢 3 B (-1%)
main-HASH.js gzip 39.6 kB 39.8 kB
webpack-HASH.js gzip 1.68 kB 1.68 kB
6105-HASH.js gzip N/A 5.64 kB -
764.HASH.js gzip N/A 169 B -
8898-HASH.js gzip N/A 61.7 kB -
9597-HASH.js gzip N/A 4.67 kB -
e1ccab69-HASH.js gzip N/A 62.8 kB -
Total 238 kB 237 kB ✅ -1.74 kB
Polyfills
Canary PR Change
polyfills-HASH.js gzip 39.4 kB 39.4 kB
Total 39.4 kB 39.4 kB
Pages
Canary PR Change
_app-HASH.js gzip 194 B 194 B
_error-HASH.js gzip 183 B 182 B
css-HASH.js gzip 335 B 335 B
dynamic-HASH.js gzip 1.8 kB 1.8 kB
edge-ssr-HASH.js gzip 255 B 254 B
head-HASH.js gzip 351 B 349 B
hooks-HASH.js gzip 384 B 384 B
image-HASH.js gzip 580 B 581 B
index-HASH.js gzip 259 B 259 B
link-HASH.js gzip 2.49 kB 2.52 kB 🔴 +34 B (+1%)
routerDirect..HASH.js gzip 319 B 319 B
script-HASH.js gzip 386 B 386 B
withRouter-HASH.js gzip 315 B 313 B
1afbb74e6ecf..834.css gzip 106 B 106 B
Total 7.96 kB 7.99 kB ⚠️ +30 B

Server

Edge SSR
Canary PR Change
edge-ssr.js gzip 127 kB 126 kB
page.js gzip 284 kB 281 kB 🟢 2.96 kB (-1%)
Total 411 kB 408 kB ✅ -3.1 kB
Middleware
Canary PR Change
middleware-b..fest.js gzip 618 B 616 B
middleware-r..fest.js gzip 156 B 155 B
middleware.js gzip 45 kB 44.8 kB
edge-runtime..pack.js gzip 842 B 842 B
Total 46.7 kB 46.4 kB ✅ -218 B
Build Details
Build Manifests
Canary PR Change
_buildManifest.js gzip 719 B 717 B
Total 719 B 717 B ✅ -2 B
Build Cache
Canary PR Change
0.pack gzip 4.74 MB 4.59 MB 🟢 155 kB (-3%)
index.pack gzip 117 kB 113 kB 🟢 3.9 kB (-3%)
index.pack.old gzip 116 kB 113 kB 🟢 3.6 kB (-3%)
Total 4.98 MB 4.81 MB ✅ -163 kB

🔄 Shared (bundler-independent)

Runtimes
Canary PR Change
app-page-exp...dev.js gzip 364 kB 358 kB 🟢 6.12 kB (-2%)
app-page-exp..prod.js gzip 200 kB 197 kB 🟢 2.68 kB (-1%)
app-page-tur...dev.js gzip 363 kB 357 kB 🟢 6.1 kB (-2%)
app-page-tur..prod.js gzip 200 kB 197 kB 🟢 2.68 kB (-1%)
app-page-tur...dev.js gzip 360 kB 354 kB 🟢 6.1 kB (-2%)
app-page-tur..prod.js gzip 198 kB 195 kB 🟢 2.66 kB (-1%)
app-page.run...dev.js gzip 360 kB 354 kB 🟢 6.13 kB (-2%)
app-page.run..prod.js gzip 198 kB 195 kB 🟢 2.65 kB (-1%)
app-route-ex...dev.js gzip 79 kB 77.8 kB 🟢 1.26 kB (-2%)
app-route-ex..prod.js gzip 53.6 kB 53.1 kB
app-route-tu...dev.js gzip 79.1 kB 77.8 kB 🟢 1.26 kB (-2%)
app-route-tu..prod.js gzip 53.6 kB 53.1 kB
app-route-tu...dev.js gzip 78.7 kB 77.4 kB 🟢 1.26 kB (-2%)
app-route-tu..prod.js gzip 53.3 kB 52.9 kB
app-route.ru...dev.js gzip 78.6 kB 77.4 kB 🟢 1.26 kB (-2%)
app-route.ru..prod.js gzip 53.3 kB 52.9 kB
dist_client_...dev.js gzip 324 B 324 B
dist_client_...dev.js gzip 326 B 326 B
dist_client_...dev.js gzip 318 B 318 B
dist_client_...dev.js gzip 317 B 317 B
pages-api-tu...dev.js gzip 45.2 kB 44.3 kB 🟢 819 B (-2%)
pages-api-tu..prod.js gzip 33.9 kB 33.8 kB
pages-api.ru...dev.js gzip 45.1 kB 44.3 kB 🟢 818 B (-2%)
pages-api.ru..prod.js gzip 33.9 kB 33.8 kB
pages-turbo....dev.js gzip 54.6 kB 53.7 kB 🟢 901 B (-2%)
pages-turbo...prod.js gzip 39.5 kB 39.4 kB
pages.runtim...dev.js gzip 54.6 kB 53.7 kB 🟢 901 B (-2%)
pages.runtim..prod.js gzip 39.5 kB 39.4 kB
server.runti..prod.js gzip 64.9 kB 64.9 kB
use-cache-pr...dev.js gzip 71.3 kB 70.7 kB
use-cache-pr...dev.js gzip 71.3 kB 70.7 kB
use-cache-pr...dev.js gzip 69.6 kB 69 kB
use-cache-pr...dev.js gzip 69.6 kB 69 kB
Total 3.47 MB 3.42 MB ✅ -48.3 kB
📝 Changed Files (29 files)

Files with changes:

  • app-page-exp..ntime.dev.js
  • app-page-exp..time.prod.js
  • app-page-tur..ntime.dev.js
  • app-page-tur..time.prod.js
  • app-page-tur..ntime.dev.js
  • app-page-tur..time.prod.js
  • app-page.runtime.dev.js
  • app-page.runtime.prod.js
  • app-route-ex..ntime.dev.js
  • app-route-ex..time.prod.js
  • app-route-tu..ntime.dev.js
  • app-route-tu..time.prod.js
  • app-route-tu..ntime.dev.js
  • app-route-tu..time.prod.js
  • app-route.runtime.dev.js
  • app-route.ru..time.prod.js
  • pages-api-tu..ntime.dev.js
  • pages-api-tu..time.prod.js
  • pages-api.runtime.dev.js
  • pages-api.ru..time.prod.js
  • ... and 9 more
View diffs
app-page-exp..ntime.dev.js
failed to diff
app-page-exp..time.prod.js
failed to diff
app-page-tur..ntime.dev.js
failed to diff
app-page-tur..time.prod.js
failed to diff
app-page-tur..ntime.dev.js
failed to diff
app-page-tur..time.prod.js
failed to diff
app-page.runtime.dev.js
failed to diff
app-page.runtime.prod.js
failed to diff
app-route-ex..ntime.dev.js

Diff too large to display

app-route-ex..time.prod.js

Diff too large to display

app-route-tu..ntime.dev.js

Diff too large to display

app-route-tu..time.prod.js

Diff too large to display

app-route-tu..ntime.dev.js

Diff too large to display

app-route-tu..time.prod.js

Diff too large to display

app-route.runtime.dev.js

Diff too large to display

app-route.ru..time.prod.js

Diff too large to display

pages-api-tu..ntime.dev.js

Diff too large to display

pages-api-tu..time.prod.js

Diff too large to display

pages-api.runtime.dev.js

Diff too large to display

pages-api.ru..time.prod.js

Diff too large to display

pages-turbo...ntime.dev.js

Diff too large to display

pages-turbo...time.prod.js

Diff too large to display

pages.runtime.dev.js

Diff too large to display

pages.runtime.prod.js

Diff too large to display

server.runtime.prod.js

Diff too large to display

use-cache-pr..ntime.dev.js

Diff too large to display

use-cache-pr..ntime.dev.js

Diff too large to display

use-cache-pr..ntime.dev.js

Diff too large to display

use-cache-pr..ntime.dev.js

Diff too large to display

📎 Tarball URL
https://vercel-packages.vercel.app/next/commits/a272e2e180465df42e92d45c9c4c30485bc501bc/next

Commit: a272e2e

@github-actions

github-actions Bot commented Jun 30, 2026

Copy link
Copy Markdown
Contributor

Tests Passed

Commit: a272e2e

@devjiwonchoi devjiwonchoi marked this pull request as ready for review June 30, 2026 17:54
@devjiwonchoi devjiwonchoi changed the title Add early OpenTelemetry tracer prerender coverage Jun 30, 2026
@devjiwonchoi devjiwonchoi requested a review from gnoff June 30, 2026 18:50
@devjiwonchoi devjiwonchoi force-pushed the jiwon/test-early-otel-tracer-prerender branch from d8d4431 to 05e44f4 Compare June 30, 2026 21:39
@devjiwonchoi devjiwonchoi force-pushed the jiwon/test-early-otel-tracer-prerender branch from 05e44f4 to be2a7aa Compare July 1, 2026 12:46

@vercel vercel Bot left a comment

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

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

Additional Suggestion:

The production fix for early OTel proxy tracers is missing: instrumentation-node-extensions.ts only patches provider.getTracer, not provider.getDelegateTracer, so tracers acquired before provider registration run startSpan inside the prerender work-unit context and trigger Cache Components dynamic-access errors.

Fix on Vercel

@devjiwonchoi devjiwonchoi merged commit fa71595 into canary Jul 1, 2026
130 checks passed
@devjiwonchoi devjiwonchoi deleted the jiwon/test-early-otel-tracer-prerender branch July 1, 2026 16:14
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

2 participants