Skip to main content
每天,Bun 都在向 100% 兼容 Node.js API 更进一步。如今,像 Next.js、Express 这样流行的框架以及数百万专为 Node 设计的 npm 包,都能直接在 Bun 上运行。为了确保兼容性,我们在每个 Bun 版本发布前都会运行来自 Node.js 测试套件的数千个测试。 如果某个包在 Node.js 中可用,但在 Bun 中不可用,我们视其为 Bun 的 bug。提交问题,我们会进行修复。 本页面会定期更新以反映最新版本 Bun 的兼容状态。以下信息反映了 Bun 与 Node.js v23 的兼容性。

内置 Node.js 模块

node:assert

🟢 完全实现。

node:buffer

🟢 完全实现。

node:console

🟢 完全实现。

node:dgram

🟢 完全实现。> 90% 的 Node.js 测试套件通过。

node:diagnostics_channel

🟢 完全实现。

node:dns

🟢 完全实现。> 90% 的 Node.js 测试套件通过。

node:events

🟢 完全实现。Node.js 测试套件 100% 通过。EventEmitterAsyncResource 底层使用 AsyncResource

node:fs

🟢 完全实现。Node.js 测试套件通过率为 92%。

node:http

🟢 完全实现。当前传出客户端请求体是缓冲的,而非流式的。

node:https

🟢 API 已实现,但 Agent 还未完全使用。

node:os

🟢 完全实现。Node.js 测试套件 100% 通过。

node:path

🟢 完全实现。Node.js 测试套件 100% 通过。

node:punycode

🟢 完全实现。Node.js 测试套件 100% 通过,Node.js 已弃用

node:querystring

🟢 完全实现。Node.js 测试套件 100% 通过。

node:readline

🟢 完全实现。

node:stream

🟢 完全实现。

node:string_decoder

🟢 完全实现。Node.js 测试套件 100% 通过。

node:timers

🟢 推荐直接使用全局的 setTimeout 等函数。

node:tty

🟢 完全实现。

node:url

🟢 完全实现。

node:zlib

🟢 完全实现。Node.js 测试套件通过率为 98%。

node:async_hooks

🟡 实现了 AsyncLocalStorageAsyncResource。v8 的 promise 钩子未调用,且其使用被 强烈不建议

node:child_process

🟡 缺少 proc.gidproc.uidStream 类未导出。IPC 不能发送 socket 句柄。Node.js ↔ Bun 的 IPC 可通过 JSON 序列化使用。

node:cluster

🟡 句柄和文件描述符不能在工作线程间传递,这意味着多进程 HTTP 请求负载均衡目前仅在 Linux 平台通过 SO_REUSEPORT 支持。其他部分已实现,但未经过严格测试。

node:crypto

🟡 缺少 secureHeapUsedsetEnginesetFips

node:domain

🟡 缺少 Domainactive

node:http2

🟡 已实现客户端和服务端(gRPC 测试套件通过率为 95.25%)。缺少 options.allowHTTP1options.enableConnectProtocol、ALTSVC 扩展和 http2stream.pushStream

node:module

🟡 缺少 syncBuiltinESMExportsModule#load()。支持对 ESM 和 CJS 模块覆盖 require.cachemodule._extensionsmodule._pathCachemodule._cache 是无操作。module.register 未实现,推荐暂时用 Bun.plugin

node:net

🟢 完全实现。

node:perf_hooks

🟡 API 已实现,但 Node.js 测试套件尚未全部通过。

node:process

🟡 见 process 全局变量部分。

node:sys

🟡 见 node:util

node:tls

🟡 缺少 tls.createSecurePair

node:util

🟡 缺少 getCallSitegetCallSitesgetSystemErrorMapgetSystemErrorMessagetransferableAbortSignaltransferableAbortController

node:v8

🟡 已实现 writeHeapSnapshotgetHeapSnapshotserializedeserialize 使用的是 JavaScriptCore 的线格式(wire format)而非 V8 的。其他方法未实现。做性能分析时建议使用 bun:jsc

node:vm

🟡 核心功能和 ES 模块已实现,包括 vm.Scriptvm.createContextvm.runInContextvm.runInNewContextvm.runInThisContextvm.compileFunctionvm.isContextvm.Modulevm.SourceTextModulevm.SyntheticModule 以及 importModuleDynamically 支持。选项如 timeoutbreakOnSigint 完全支持。缺少 vm.measureMemory 和部分 cachedData 功能。

node:wasi

🟡 部分实现。

node:worker_threads

🟡 Worker 不支持以下选项:stdinstdoutstderrtrackedUnmanagedFdsresourceLimits。缺少 markAsUntransferablemoveMessagePortToContext

node:inspector

🔴 未实现。

node:repl

🔴 未实现。

node:sqlite

🔴 未实现。

node:test

🟡 部分实现。缺少模拟(mocks)、快照(snapshots)和定时器。建议使用 bun:test

node:trace_events

🔴 未实现。

Node.js 全局变量

下表列出了 Node.js 实现的所有全局变量以及 Bun 当前的兼容状态。

AbortController

🟢 完全实现。

AbortSignal

🟢 完全实现。

Blob

🟢 完全实现。

Buffer

🟢 完全实现。

ByteLengthQueuingStrategy

🟢 完全实现。

__dirname

🟢 完全实现。

__filename

🟢 完全实现。

atob()

🟢 完全实现。

Atomics

🟢 完全实现。

BroadcastChannel

🟢 完全实现。

btoa()

🟢 完全实现。

clearImmediate()

🟢 完全实现。

clearInterval()

🟢 完全实现。

clearTimeout()

🟢 完全实现。

CompressionStream

🟢 完全实现。

console

🟢 完全实现。

CountQueuingStrategy

🟢 完全实现。

Crypto

🟢 完全实现。

SubtleCrypto (crypto)

🟢 完全实现。

CryptoKey

🟢 完全实现。

CustomEvent

🟢 完全实现。

DecompressionStream

🟢 完全实现。

Event

🟢 完全实现。

EventTarget

🟢 完全实现。

exports

🟢 完全实现。

fetch

🟢 完全实现。

FormData

🟢 完全实现。

global

🟢 已实现。它是包含全局命名空间中所有对象的对象。一般很少直接引用,因为其内容可直接使用,无需额外前缀,例如使用 __dirname 而非 global.__dirname

globalThis

🟢 别名指向 global

Headers

🟢 完全实现。

MessageChannel

🟢 完全实现。

MessageEvent

🟢 完全实现。

MessagePort

🟢 完全实现。

module

🟢 完全实现。

PerformanceEntry

🟢 完全实现。

PerformanceMark

🟢 完全实现。

PerformanceMeasure

🟢 完全实现。

PerformanceObserver

🟢 完全实现。

PerformanceObserverEntryList

🟢 完全实现。

PerformanceResourceTiming

🟢 完全实现。

performance

🟢 完全实现。

process

🟡 大部分已实现。process.binding(Node.js 内部绑定,部分包依赖)部分实现。process.title 在 macOS 和 Linux 上目前无操作。getActiveResourcesInfosetActiveResourcesInfogetActiveResourcessetSourceMapsEnabled 是存根。新接口如 process.loadEnvFileprocess.getBuiltinModule 尚未实现。

queueMicrotask()

🟢 完全实现。

ReadableByteStreamController

🟢 完全实现。

ReadableStream

🟢 完全实现。

ReadableStreamBYOBReader

🟢 完全实现。

ReadableStreamBYOBRequest

🟢 完全实现。

ReadableStreamDefaultController

🟢 完全实现。

ReadableStreamDefaultReader

🟢 完全实现。

require()

🟢 完全实现,包括 require.mainrequire.cacherequire.resolve

Response

🟢 完全实现。

Request

🟢 完全实现。

setImmediate()

🟢 完全实现。

setInterval()

🟢 完全实现。

setTimeout()

🟢 完全实现。

structuredClone()

🟢 完全实现。

SubtleCrypto

🟢 完全实现。

DOMException

🟢 完全实现。

TextDecoder

🟢 完全实现。

TextDecoderStream

🟢 完全实现。

TextEncoder

🟢 完全实现。

TextEncoderStream

🟢 完全实现。

TransformStream

🟢 完全实现。

TransformStreamDefaultController

🟢 完全实现。

URL

🟢 完全实现。

URLSearchParams

🟢 完全实现。

WebAssembly

🟢 完全实现。

WritableStream

🟢 完全实现。

WritableStreamDefaultController

🟢 完全实现。

WritableStreamDefaultWriter

🟢 完全实现。