Skip to content

change the process name of builds#92411

Merged
timneutkens merged 1 commit intocanaryfrom
04-06-change_the_process_name_of_builds
Apr 7, 2026
Merged

change the process name of builds#92411
timneutkens merged 1 commit intocanaryfrom
04-06-change_the_process_name_of_builds

Conversation

@lukesandberg
Copy link
Copy Markdown
Contributor

@lukesandberg lukesandberg commented Apr 6, 2026

When next dev is running we change the process name, we should do the same thing for builds.

This is a small performance hit on MacOs, about 10ms, (See node issue: nodejs/node#59678), but not on other platforms. process.title is also apparently not implemented on Bun or Deno 🤦

Copy link
Copy Markdown
Contributor Author

lukesandberg commented Apr 6, 2026

This stack of pull requests is managed by Graphite. Learn more about stacking.

@nextjs-bot
Copy link
Copy Markdown
Collaborator

Stats from current PR

✅ No significant changes detected

📊 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) 455ms 456ms ▅▅▅▅▁
Cold (Ready in log) 437ms 439ms ▅▇█▂▁
Cold (First Request) 1.131s 1.117s ▁▆██▆
Warm (Listen) 457ms 456ms ▁▁▁██
Warm (Ready in log) 439ms 439ms ▇▇█▁▂
Warm (First Request) 343ms 332ms ▇▅▇▁▃
📦 Dev Server (Webpack) (Legacy)

📦 Dev Server (Webpack)

Metric Canary PR Change Trend
Cold (Listen) 455ms 455ms ▆▃▆▃▆
Cold (Ready in log) 432ms 433ms ▇▅▆▃▂
Cold (First Request) 1.913s 1.941s █▇█▄▆
Warm (Listen) 456ms 457ms █████
Warm (Ready in log) 432ms 433ms ▆▅▆▃▃
Warm (First Request) 1.929s 1.932s ▇▇▇▃▆

⚡ Production Builds

Metric Canary PR Change Trend
Fresh Build 3.866s 3.809s █▅█▅▇
Cached Build 3.861s 3.870s █▄▅█▅
📦 Production Builds (Webpack) (Legacy)

📦 Production Builds (Webpack)

Metric Canary PR Change Trend
Fresh Build 14.321s 14.417s ██▇▁▁
Cached Build 14.474s 14.472s ███▃▂
node_modules Size 488 MB 488 MB ▄▄▅██
📦 Bundle Sizes

Bundle Sizes

⚡ Turbopack

Client

Main Bundles
Canary PR Change
0_bd52mr0x-ld.js gzip 158 B N/A -
02fkg8wfh0iju.js gzip 9.19 kB N/A -
050zwt5xh_0tx.js gzip 10.4 kB N/A -
06rvbj82bhyo0.js gzip 13 kB N/A -
087fzjd-gvlzv.js gzip 450 B N/A -
0cz1d0mv5g_q7.js gzip 39.4 kB 39.4 kB
0iw83or5zbh4j.js gzip 65.7 kB N/A -
0ppxcl_z43mad.js gzip 8.52 kB N/A -
14skh21p_nw_l.js gzip 155 B N/A -
15bklaj-xtg2d.js gzip 157 B N/A -
16a0o61m1v97-.js gzip 157 B N/A -
17m8mjo2po5vp.js gzip 160 B N/A -
19oha6-znmkcv.js gzip 8.55 kB N/A -
1bn_vx1o8t5e3.js gzip 155 B N/A -
1elt1qium-r2m.css gzip 115 B 115 B
1w62u8ecozso_.js gzip 158 B N/A -
2_5rjb7lqxntf.js gzip 221 B 221 B
219prxwxgaalc.js gzip 7.61 kB N/A -
26elcgxnn9zjd.js gzip 8.52 kB N/A -
2900hudr6gvm0.js gzip 2.28 kB N/A -
2iw5wad_q3_ez.js gzip 157 B N/A -
2lv2js3kmdeho.js gzip 8.48 kB N/A -
2rehygrd36hqv.js gzip 8.58 kB N/A -
2srwswih0m9_h.js gzip 13.3 kB N/A -
2sz4898u16cqt.js gzip 157 B N/A -
2tn3c33kdri7o.js gzip 153 B N/A -
2wrczlt8w5t5f.js gzip 70.8 kB N/A -
3-p9p9mheqhzx.js gzip 8.55 kB N/A -
31030bryqpolg.js gzip 8.53 kB N/A -
31dx5nmrzzuy7.js gzip 225 B N/A -
385ukaiizu9-5.js gzip 169 B N/A -
3925v09gtu-5k.js gzip 49 kB N/A -
39x4zj5mjb4d_.js gzip 9.77 kB N/A -
3k-48b78ys_vy.js gzip 10.1 kB N/A -
3m7-5rfj0avoz.js gzip 12.9 kB N/A -
3oswpc45fltwt.js gzip 157 B N/A -
3uqce_6sa526g.js gzip 8.47 kB N/A -
3yurjqk-sjs3y.js gzip 1.46 kB N/A -
40cw2kzpcd2jf.js gzip 164 B N/A -
40ybjx9c192n0.js gzip 13.8 kB N/A -
421vzwdt9j1b_.js gzip 5.62 kB N/A -
turbopack-0g..rudx.js gzip 4.18 kB N/A -
turbopack-0h..9wd_.js gzip 4.19 kB N/A -
turbopack-0h..gwqs.js gzip 4.18 kB N/A -
turbopack-18..55ib.js gzip 4.18 kB N/A -
turbopack-1p..92t9.js gzip 4.16 kB N/A -
turbopack-1r..mey7.js gzip 4.18 kB N/A -
turbopack-1v..3zrt.js gzip 4.18 kB N/A -
turbopack-21..h36l.js gzip 4.18 kB N/A -
turbopack-24..ybs2.js gzip 4.18 kB N/A -
turbopack-2h..dsv4.js gzip 4.18 kB N/A -
turbopack-2o..g1-p.js gzip 4.18 kB N/A -
turbopack-3_..73ss.js gzip 4.18 kB N/A -
turbopack-32..rd15.js gzip 4.17 kB N/A -
turbopack-3x..5c51.js gzip 4.18 kB N/A -
03dgzoo-qf3sm.js gzip N/A 9.19 kB -
05tx5f25dlivn.js gzip N/A 8.53 kB -
06r-jg2j_a08m.js gzip N/A 157 B -
0c7ez6p2qc57f.js gzip N/A 5.62 kB -
0duvj3qk5pvgn.js gzip N/A 13.8 kB -
0geda8-lalb73.js gzip N/A 70.8 kB -
0m-34rm9w_wpm.js gzip N/A 7.6 kB -
0qh4mb74ob5ni.js gzip N/A 154 B -
0qnwuk92m8i7o.js gzip N/A 10.4 kB -
0r4wrn6n0ue2m.js gzip N/A 8.55 kB -
0rp0fodtbt_6m.js gzip N/A 8.52 kB -
0sfck-km4dl1k.js gzip N/A 8.47 kB -
0vk0-l3pztvop.js gzip N/A 154 B -
0x0xuhmxzwkp8.js gzip N/A 8.47 kB -
1-wdvgxnzicj7.js gzip N/A 1.46 kB -
11u6nxujb2eg4.js gzip N/A 450 B -
1jflh3_98hv--.js gzip N/A 161 B -
1jv-o1_s-zmua.js gzip N/A 49 kB -
2bhyonfpc_hr2.js gzip N/A 157 B -
2cbv0_9xq0ij0.js gzip N/A 161 B -
2j9hi9ynyu1ju.js gzip N/A 168 B -
2k9ax08cjl2id.js gzip N/A 12.9 kB -
2lms6k76q5-6m.js gzip N/A 13.3 kB -
2p377sxsvk-76.js gzip N/A 156 B -
2qx4twi9i3xus.js gzip N/A 2.28 kB -
2rkb_cvq4e-z2.js gzip N/A 157 B -
2srnqic6tvxxd.js gzip N/A 8.52 kB -
30l7m4nayp73a.js gzip N/A 8.55 kB -
34kadk39px5p2.js gzip N/A 155 B -
38rr7d3kfutni.js gzip N/A 13 kB -
3dbvo2la2u-z8.js gzip N/A 65.7 kB -
3h_ecpiaatwgc.js gzip N/A 10.1 kB -
3ity0aahajapd.js gzip N/A 225 B -
3kp_ccx33x6gc.js gzip N/A 154 B -
3umvvgauv2n4y.js gzip N/A 156 B -
3wrhpuc-j1aw9.js gzip N/A 9.77 kB -
3xwp-6w1frq90.js gzip N/A 155 B -
43mlw9dy_8f02.js gzip N/A 8.58 kB -
turbopack-0e..rd7r.js gzip N/A 4.18 kB -
turbopack-0j..q6by.js gzip N/A 4.18 kB -
turbopack-0v..v41_.js gzip N/A 4.18 kB -
turbopack-1d..0g85.js gzip N/A 4.19 kB -
turbopack-1w..kl_a.js gzip N/A 4.18 kB -
turbopack-2_..o2wm.js gzip N/A 4.18 kB -
turbopack-26..fuma.js gzip N/A 4.16 kB -
turbopack-2r..ja-n.js gzip N/A 4.17 kB -
turbopack-35..l_ua.js gzip N/A 4.18 kB -
turbopack-36..uvcz.js gzip N/A 4.18 kB -
turbopack-3r..iufv.js gzip N/A 4.17 kB -
turbopack-42..mo42.js gzip N/A 4.18 kB -
turbopack-43..cf59.js gzip N/A 4.18 kB -
turbopack-43..0hsi.js gzip N/A 4.18 kB -
Total 464 kB 464 kB ✅ -51 B

Server

Middleware
Canary PR Change
middleware-b..fest.js gzip 722 B 717 B
Total 722 B 717 B ✅ -5 B
Build Details
Build Manifests
Canary PR Change
_buildManifest.js gzip 428 B 433 B 🔴 +5 B (+1%)
Total 428 B 433 B ⚠️ +5 B

📦 Webpack

Client

Main Bundles
Canary PR Change
5528-HASH.js gzip 5.54 kB N/A -
6280-HASH.js gzip 60.7 kB N/A -
6335.HASH.js gzip 169 B N/A -
912-HASH.js gzip 4.59 kB N/A -
e8aec2e4-HASH.js gzip 62.8 kB N/A -
framework-HASH.js gzip 59.7 kB 59.7 kB
main-app-HASH.js gzip 255 B 254 B
main-HASH.js gzip 39.3 kB 39.2 kB
webpack-HASH.js gzip 1.68 kB 1.68 kB
262-HASH.js gzip N/A 4.59 kB -
2889.HASH.js gzip N/A 169 B -
5602-HASH.js gzip N/A 5.55 kB -
6948ada0-HASH.js gzip N/A 62.8 kB -
9544-HASH.js gzip N/A 61.4 kB -
Total 235 kB 235 kB ⚠️ +649 B
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 180 B 🟢 3 B (-2%)
css-HASH.js gzip 331 B 330 B
dynamic-HASH.js gzip 1.81 kB 1.81 kB
edge-ssr-HASH.js gzip 256 B 256 B
head-HASH.js gzip 351 B 352 B
hooks-HASH.js gzip 384 B 383 B
image-HASH.js gzip 580 B 581 B
index-HASH.js gzip 260 B 260 B
link-HASH.js gzip 2.51 kB 2.51 kB
routerDirect..HASH.js gzip 320 B 319 B
script-HASH.js gzip 386 B 386 B
withRouter-HASH.js gzip 315 B 315 B
1afbb74e6ecf..834.css gzip 106 B 106 B
Total 7.98 kB 7.98 kB ✅ -1 B

Server

Edge SSR
Canary PR Change
edge-ssr.js gzip 125 kB 126 kB
page.js gzip 273 kB 273 kB
Total 398 kB 398 kB ⚠️ +161 B
Middleware
Canary PR Change
middleware-b..fest.js gzip 620 B 613 B 🟢 7 B (-1%)
middleware-r..fest.js gzip 156 B 155 B
middleware.js gzip 43.9 kB 44.4 kB 🔴 +491 B (+1%)
edge-runtime..pack.js gzip 842 B 842 B
Total 45.6 kB 46 kB ⚠️ +483 B
Build Details
Build Manifests
Canary PR Change
_buildManifest.js gzip 715 B 718 B
Total 715 B 718 B ⚠️ +3 B
Build Cache
Canary PR Change
0.pack gzip 4.38 MB 4.37 MB 🟢 8.84 kB (0%)
index.pack gzip 116 kB 113 kB 🟢 2.91 kB (-3%)
index.pack.old gzip 113 kB 115 kB 🔴 +1.94 kB (+2%)
Total 4.61 MB 4.6 MB ✅ -9.81 kB

🔄 Shared (bundler-independent)

Runtimes
Canary PR Change
app-page-exp...dev.js gzip 342 kB 342 kB
app-page-exp..prod.js gzip 189 kB 189 kB
app-page-tur...dev.js gzip 341 kB 341 kB
app-page-tur..prod.js gzip 189 kB 189 kB
app-page-tur...dev.js gzip 338 kB 338 kB
app-page-tur..prod.js gzip 187 kB 187 kB
app-page.run...dev.js gzip 338 kB 338 kB
app-page.run..prod.js gzip 187 kB 187 kB
app-route-ex...dev.js gzip 76.6 kB 76.6 kB
app-route-ex..prod.js gzip 52.2 kB 52.2 kB
app-route-tu...dev.js gzip 76.6 kB 76.6 kB
app-route-tu..prod.js gzip 52.2 kB 52.2 kB
app-route-tu...dev.js gzip 76.2 kB 76.2 kB
app-route-tu..prod.js gzip 52 kB 52 kB
app-route.ru...dev.js gzip 76.2 kB 76.2 kB
app-route.ru..prod.js gzip 52 kB 52 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 43.8 kB 43.8 kB
pages-api-tu..prod.js gzip 33.4 kB 33.4 kB
pages-api.ru...dev.js gzip 43.8 kB 43.8 kB
pages-api.ru..prod.js gzip 33.4 kB 33.4 kB
pages-turbo....dev.js gzip 53.2 kB 53.2 kB
pages-turbo...prod.js gzip 39 kB 39 kB
pages.runtim...dev.js gzip 53.2 kB 53.2 kB
pages.runtim..prod.js gzip 39 kB 39 kB
server.runti..prod.js gzip 62.8 kB 62.8 kB
Total 3.03 MB 3.03 MB ⚠️ +1 B
📎 Tarball URL
https://vercel-packages.vercel.app/next/commits/8aff77abcf266ad2307544ce994555755c0ce1d7/next

@mischnic
Copy link
Copy Markdown
Member

mischnic commented Apr 6, 2026

I remember @timneutkens investigating this some time ago as well.
It takes a few hundred milliseconds to set it, if I recall correctly?

There was some Vite/Vitest blog post about this how they made their tool faster by dropping this name set call.

Copy link
Copy Markdown
Contributor Author

yeah i was wondering about that. sigh...

nodejs/node#59678

i can drop this, but perhaps a 10ms hit is acceptible? or i could do it in a worker_thread 😆

@lukesandberg lukesandberg requested a review from timneutkens April 6, 2026 20:32
@eps1lon
Copy link
Copy Markdown
Member

eps1lon commented Apr 7, 2026

IMO this amount of overhead doesn't really matter for next build which takes minutes. It's also rarely used on MacOS (most deploy machines use Linux I assume). For next dev it is more relevant since that's commonly used on MacOS and where we want to keep bootstrap ideally below 100ms.

Maybe just leave a note that this isn't super critical and can be removed if it turns out that the performance cost is noticeable?

@timneutkens
Copy link
Copy Markdown
Member

Yeah it's about 10ms. Not a big deal for this case. For dev it was in the hot path for logging bootup time.

@timneutkens timneutkens merged commit 621c73a into canary Apr 7, 2026
172 checks passed
@timneutkens timneutkens deleted the 04-06-change_the_process_name_of_builds branch April 7, 2026 09:51
eps1lon pushed a commit that referenced this pull request Apr 7, 2026
When `next dev` is running we change the process name, we should do the
same thing for builds.

This is a small performance hit on MacOs, about 10ms, (See node issue:
nodejs/node#59678), but not on other
platforms. `process.title` is also apparently not implemented on `Bun`
or `Deno` 🤦
eps1lon pushed a commit that referenced this pull request Apr 7, 2026
When `next dev` is running we change the process name, we should do the
same thing for builds.

This is a small performance hit on MacOs, about 10ms, (See node issue:
nodejs/node#59678), but not on other
platforms. `process.title` is also apparently not implemented on `Bun`
or `Deno` 🤦
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

6 participants