| Command | Time |
|---|---|
bun hello.js | 5.2ms |
node hello.js | 25.1ms |
Run a file
Usebun run to execute a source file.
terminal
terminal
run keyword and use the “naked” command; it behaves identically.
terminal
--watch
To run a file in watch mode, use the --watch flag.
terminal
When using Flags at the end of the command are ignored by
bun run, put Bun flags like --watch immediately after bun.bun and passed through to the "dev" script itself.Run a package.json script
Compare to
npm run <script> or yarn <script>package.json can define named "scripts" that correspond to shell commands.
package.json
bun run <script> to execute these scripts.
terminal
bash, sh, zsh. On Windows, it uses the Bun Shell to support bash-like syntax and many common commands.
⚡️ The startup time for
npm run on Linux is roughly 170ms; with Bun it is 6ms.bun <script>. If a built-in bun command has the same name, the built-in command takes precedence; use the explicit bun run <script> to run your package script instead.
terminal
bun run without any arguments.
terminal
bun run clean runs preclean and postclean, if defined. If the pre<script> fails, Bun does not run the script itself.
--bun
It’s common for package.json scripts to reference locally-installed CLIs like vite or next. These CLIs are often JavaScript files marked with a shebang to indicate that they should be executed with node.
node. The --bun flag overrides it: the CLI runs with Bun instead of Node.js.
terminal
Filtering
In a monorepo, the--filter argument runs a script in many packages at once.
bun run --filter <name_pattern> <script> executes <script> in every package whose name matches <name_pattern>.
For example, if you have subdirectories containing packages named foo, bar and baz, running
terminal
<script> in both bar and baz, but not in foo.
See --filter.
bun run - to pipe code from stdin
bun run - reads JavaScript, TypeScript, TSX, or JSX from stdin and executes it without writing to a temporary file first.
terminal
bun run - to redirect files into Bun. For example, to run a .js file as if it were a .ts file:
terminal
bun run - treats all input as TypeScript with JSX support.
bun run --console-depth
Control the depth of object inspection in console output with the --console-depth flag.
terminal
--console-depth sets how deeply nested objects are displayed in console.log() output. The default depth is 2. Higher values show more nested properties but may produce verbose output for complex objects.
bun run --smol
In memory-constrained environments, use the --smol flag to reduce memory usage at a cost to performance.
terminal
--smol makes the garbage collector run more frequently, which can slow down execution. Bun adjusts the garbage collector’s heap size based on the available memory (accounting for cgroups and other memory limits) with and without the --smol flag, so the flag is mostly useful when you want the heap to grow more slowly.
Resolution order
Absolute paths and paths starting with./ or .\\ are always executed as source files. Unless you use bun run, a name with an allowed extension resolves to the file rather than a package.json script.
When a package.json script and a file have the same name, bun run prefers the script. The full resolution order is:
package.jsonscripts:bun run build- Source files:
bun run src/main.js - Binaries from project packages:
bun add eslint && bun run eslint - (
bun runonly) System commands:bun run ls
CLI Usage
General Execution Options
Don’t print the script command
Exit without an error if the entrypoint does not exist
Evaluate argument as a script. Alias:
-eEvaluate argument as a script and print the result. Alias:
-pDisplay this menu and exit. Alias:
-hWorkspace Management
Number of lines of script output shown when using —filter (default: 10). Set to 0 to show all lines
Run a script in all workspace packages matching the pattern. Alias:
-FRun a script in all workspace packages (from the
workspaces field in package.json)Run multiple scripts or workspace scripts concurrently with prefixed output
Run multiple scripts or workspace scripts one after another with prefixed output
When using
—parallel or —sequential, continue running other scripts when one failsRuntime & Process Control
Force a script or package to use Bun’s runtime instead of Node.js (via symlinking node). Alias:
-bControl the shell used for
package.json scripts. Supports either bun or systemUse less memory, but run garbage collection more often
Expose
gc() on the global object. Has no effect on Bun.gc()Suppress all reporting of the custom deprecation
Determine whether deprecation warnings result in errors
Set the process title
Force
Buffer.allocUnsafe(size) to be zero-filledThrow an error if
process.dlopen is called, and disable export condition node-addonsOne of
strict, throw, warn, none, or
warn-with-error-codeSet the default depth for
console.log object inspection (default: 2)Development Workflow
Automatically restart the process on file change
Enable auto reload in the Bun runtime, test runner, or bundler
Disable clearing the terminal screen on reload when —hot or —watch is enabled
Debugging
Activate Bun’s debugger
Activate Bun’s debugger, wait for a connection before executing
Activate Bun’s debugger, set breakpoint on first line of code and wait
Dependency & Module Resolution
Import a module before other modules are loaded. Alias:
-rAlias of —preload, for Node.js compatibility
Alias of —preload, for Node.js compatibility
Disable auto install in the Bun runtime
Configure auto-install behavior. One of
auto (default, auto-installs when no node_modules),
fallback (missing packages only), force (always)Auto-install dependencies during execution. Equivalent to —install=fallback
Skip staleness checks for packages in the Bun runtime and resolve from disk
Use the latest matching versions of packages in the Bun runtime, always checking npm
Pass custom conditions to resolve
Main fields to lookup in
package.json. Defaults to —target dependentPreserve symlinks when resolving files
Preserve symlinks when resolving the main entry point
Defaults to:
.tsx,.ts,.jsx,.js,.jsonTranspilation & Language Features
Specify custom
tsconfig.json. Default $cwd/tsconfig.jsonSubstitute K:V while parsing, e.g.
—define process.env.NODE_ENV:“development”. Values are parsed as
JSON. Alias: -dRemove function calls, e.g.
—drop=console removes all console.* callsParse files with
.ext:loader, e.g. —loader .js:jsx. Valid loaders: js,
jsx, ts, tsx, json, toml, text,
file, wasm, napi. Alias: -lDisable macros from being executed in the bundler, transpiler and runtime
Changes the function called when compiling JSX elements using the classic JSX runtime
Changes the function called when compiling JSX fragments
Declares the module specifier used to import the jsx and jsxs factory functions. Default:
reactautomatic (default) or classicTreat JSX elements as having side effects (disable pure annotations)
Ignore tree-shaking annotations such as
@PURENetworking & Security
Set the default port for
Bun.servePreconnect to a URL while code is loading
Set the maximum size of HTTP headers in bytes. Default is 16KiB
Set the default order of DNS lookup results. Valid orders:
verbatim (default), ipv4first,
ipv6firstUse the system’s trusted certificate authorities
Use OpenSSL’s default CA store
Use bundled CA store
Preconnect to
$REDIS_URL at startupPreconnect to PostgreSQL at startup
Set the default User-Agent header for HTTP requests
Global Configuration & Context
Load environment variables from the specified file(s)
Absolute path to resolve files & entrypoints from. This just changes the process’ cwd
Specify path to Bun config file. Default
$cwd/bunfig.toml. Alias: -c