
关于
Bun 作为运行时、包管理器、打包器和测试运行器。何时选择 Bun vs Node、迁移注意事项和 Vercel 支持。
name: bun-runtime description: Bun 作为运行时、包管理器、打包器和测试运行器。何时选择 Bun 而非 Node、迁移注意事项以及 Vercel 支持。 origin: ECC
Bun 运行时
Bun 是一个快速的一体化 JavaScript 运行时和工具包:运行时、包管理器、打包器和测试运行器。
何时使用
- 优先选择 Bun:新的 JS/TS 项目、安装/运行速度很重要的脚本、使用 Bun 运行时的 Vercel 部署,以及当你想要单一工具链(运行 + 安装 + 测试 + 构建)时。
- 优先选择 Node:需要最大生态系统兼容性、依赖假定 Node 的遗留工具,或当某个依赖存在已知的 Bun 问题时。
适用场景:采用 Bun、从 Node 迁移、编写或调试 Bun 脚本/测试,或在 Vercel 或其他平台上配置 Bun。
工作原理
- 运行时:兼容 Node 的即插即用运行时(基于 JavaScriptCore 构建,用 Zig 实现)。
- 包管理器:
bun install比 npm/yarn 快得多。锁文件在当前 Bun 中默认为bun.lock(文本格式);旧版本使用bun.lockb(二进制格式)。 - 打包器:内置打包器和转译器,适用于应用和库。
- 测试运行器:内置
bun test,具有类似 Jest 的 API。
从 Node 迁移:将 node script.js 替换为 bun run script.js 或 bun script.js。用 bun install 代替 npm install;大多数包都能正常工作。使用 bun run 运行 npm 脚本;bun x 用于 npx 风格的一次性运行。支持 Node 内置模块;在有 Bun API 的地方优先使用以获得更好的性能。
Vercel:在项目设置中将运行时设置为 Bun。构建:bun run build 或 bun build ./src/index.ts --outdir=dist。安装:bun install --frozen-lockfile 以实现可复现的部署。
示例
运行和安装
# Install dependencies (creates/updates bun.lock or bun.lockb)
bun install
# Run a script or file
bun run dev
bun run src/index.ts
bun src/index.ts
脚本和环境变量
bun run --env-file=.env dev
FOO=bar bun run script.ts
测试
bun test
bun test --watch
// test/example.test.ts
import { expect, test } from "bun:test";
test("add", () => {
expect(1 + 2).toBe(3);
});
运行时 API
const file = Bun.file("package.json");
const json = await file.json();
Bun.serve({
port: 3000,
fetch(req) {
return new Response("Hello");
},
});
最佳实践
- 提交锁文件(
bun.lock或bun.lockb)以实现可复现的安装。 - 优先使用
bun run运行脚本。对于 TypeScript,Bun 原生运行.ts文件。 - 保持依赖更新;Bun 和生态系统发展迅速。
兼容工具
Claude CodeCursor
标签
后端开发

