Complete Bun Complete Guide | Ultra-Fast JavaScript Runtime
이 글의 핵심
Complete guide to implementing fast JavaScript development with Bun. Node.js alternative, fast package installation, built-in bundler, test runner with ...
Key Takeaways
Complete guide to implementing fast JavaScript development with Bun. Covers Node.js alternative, fast package installation, built-in bundler, and test runner with practical examples.
Real-World Experience: Sharing experience of transitioning from Node.js to Bun, where package installation became 10x faster and test execution became 5x faster.
Introduction: “Node.js is Slow”
Real-World Problem Scenarios
Scenario 1: npm install is too slow
npm is slow. Bun is 10x faster.
Scenario 2: Bundler configuration is complex
Webpack is complex. Bun provides built-in bundler.
Scenario 3: Tests are slow
Jest is slow. Bun is 5x faster.
1. What is Bun?
Core Features
Bun is an ultra-fast JavaScript runtime. Key Advantages:
- Fast Speed: 4x faster than Node.js
- All-in-One: Runtime + Package Manager + Bundler + Test
- Node.js Compatible: Mostly compatible
- TypeScript: Native support
- Web API: Built-in fetch, WebSocket Performance Comparison:
- Node.js: 100ms
- Deno: 80ms
- Bun: 25ms
Real-World Adoption
Bun is rapidly gaining traction as the fastest JavaScript runtime:
Created by Jarred Sumner:
- Built from scratch in Zig - systems programming language for maximum performance
- Started 2021 - youngest of the major JavaScript runtimes
- Funded by $7M Series A (2023) to build the team
Production Usage:
- Vercel: Testing Bun for build pipelines (reported 3x faster installs)
- Linear: Using Bun in development workflows
- Payload CMS: Offers Bun as installation option
- Cloudflare: Evaluating Bun for Workers compatibility
Market Growth:
- 1.5+ million weekly npm downloads (April 2026) - explosive growth
- 72,000+ GitHub stars - fastest-growing JS runtime project
- 500,000+ installs in first 2 years
- Used in 50,000+ repositories
Why Developers Love Bun:
- 4x faster startup than Node.js (JavaScriptCore engine)
- 10x faster package installs - global cache, parallel downloads
- All-in-one: Runtime + bundler + test runner + package manager
- Drop-in Node replacement: 90%+ Node.js API compatible
- Native TypeScript: No compilation step needed
Performance Benchmarks:
- bun install: 6s (npm: 60s, pnpm: 20s)
- HTTP server: 4x faster than Express on Node
- Test runner: 5x faster than Jest
- Cold start: 25ms (Node: 100ms)
Ecosystem Compatibility:
- ✅ Express, Fastify, Hono work out of the box
- ✅ React, Vue, Svelte - all compatible
- ✅ Most npm packages work (90%+ compatibility)
- ⚠️ Native addons require recompilation
- ⚠️ Some Node-specific APIs still in progress
When to Choose Bun:
- ✅ New projects prioritizing speed
- ✅ Monorepos with slow installs
- ✅ Scripts and CLIs
- ✅ Development environments
- ⏳ Production (test thoroughly first - API surface still evolving)
- ❌ Apps with many native addons
- ❌ Enterprise requiring LTS stability
Community Impact:
- Pushed Node.js to improve performance (Node 20+ faster)
- Inspired pnpm and yarn to optimize further
- Proved Zig viable for systems-level JS tooling
Bun is the fastest option today, but verify your specific use case - Node.js’s maturity still matters for many production workloads.
2. Installation and Basic Usage
Installation
Here’s an implementation example using bash. Try running the code directly to see how it works.
# macOS/Linux
curl -fsSL https://bun.sh/install | bash
# Windows
powershell -c "irm bun.sh/install.ps1 | iex"
Basic Commands
Here’s an implementation example using bash. Try running the code directly to see how it works.
# Run file
bun run index.ts
# REPL
bun
# Check version
bun --version
3. Package Management
Package Installation
Here’s an implementation example using bash. Please review the code to understand the role of each part.
# Install dependencies
bun install
# Add package
bun add express
bun add -d typescript
# Remove package
bun remove express
# Global install
bun add -g typescript
Speed Comparison:
- npm: 60 seconds
- pnpm: 20 seconds
- bun: 6 seconds
4. Web Server
HTTP Server
Here’s a detailed implementation using TypeScript. Handle branching with conditionals. Please review the code to understand the role of each part.
// server.ts
const server = Bun.serve({
port: 3000,
fetch(req) {
const url = new URL(req.url);
if (url.pathname === '/') {
return new Response('Hello Bun!');
}
if (url.pathname === '/api/users') {
return Response.json([
{ id: 1, name: 'John' },
{ id: 2, name: 'Jane' },
]);
}
return new Response('Not Found', { status: 404 });
},
});
console.log(`Server running on http://localhost:${server.port}`);
Using Express
Here’s an implementation example using TypeScript. Import necessary modules. Please review the code to understand the role of each part.
import express from 'express';
const app = express();
app.get('/', (req, res) => {
res.send('Hello Bun with Express!');
});
app.listen(3000, () => {
console.log('Server running on :3000');
});
5. Bundler
Basic Bundling
Here’s an implementation example using TypeScript. Perform tasks efficiently with async processing, ensure stability with error handling. Try running the code directly to see how it works.
// build.ts
await Bun.build({
entrypoints: ['./src/index.ts'],
outdir: './dist',
target: 'browser',
minify: true,
sourcemap: 'external',
});
React Bundling
Here’s an implementation example using TypeScript. Perform tasks efficiently with async processing, ensure stability with error handling. Please review the code to understand the role of each part.
await Bun.build({
entrypoints: ['./src/index.tsx'],
outdir: './dist',
target: 'browser',
minify: true,
splitting: true,
loader: {
'.png': 'file',
'.svg': 'file',
},
});
6. Testing
Basic Tests
Here’s an implementation example using TypeScript. Import necessary modules. Please review the code to understand the role of each part.
// math.test.ts
import { expect, test, describe } from 'bun:test';
describe('Math', () => {
test('add', () => {
expect(1 + 2).toBe(3);
});
test('multiply', () => {
expect(2 * 3).toBe(6);
});
});
Async Tests
Here’s an implementation example using TypeScript. Import necessary modules, perform tasks efficiently with async processing. Try running the code directly to see how it works.
import { expect, test } from 'bun:test';
test('fetch users', async () => {
const response = await fetch('https://api.example.com/users');
const users = await response.json();
expect(users).toBeArray();
expect(users.length).toBeGreaterThan(0);
});
Run
bun test
7. File System
Reading Files
Here’s an implementation example using TypeScript. Perform tasks efficiently with async processing. Try running the code directly to see how it works.
// Text file
const text = await Bun.file('data.txt').text();
// JSON file
const json = await Bun.file('data.json').json();
// Binary file
const buffer = await Bun.file('image.png').arrayBuffer();
Writing Files
await Bun.write('output.txt', 'Hello Bun!');
await Bun.write('data.json', JSON.stringify({ name: 'John' }));
8. Environment Variables
Here’s an implementation example using TypeScript. Try running the code directly to see how it works.
// .env
DATABASE_URL=postgresql://localhost:5432/mydb
API_KEY=secret123
// Usage
console.log(process.env.DATABASE_URL);
console.log(Bun.env.API_KEY);
9. Hot Reload
bun --watch server.ts
10. Real-World Example
REST API
Here’s a detailed implementation using TypeScript. Perform tasks efficiently with async processing, handle branching with conditionals. Please review the code to understand the role of each part.
// api/server.ts
const server = Bun.serve({
port: 3000,
async fetch(req) {
const url = new URL(req.url);
if (url.pathname === '/api/users' && req.method === 'GET') {
const users = await db.select().from(usersTable);
return Response.json(users);
}
if (url.pathname === '/api/users' && req.method === 'POST') {
const body = await req.json();
const user = await db.insert(usersTable).values(body).returning();
return Response.json(user[0], { status: 201 });
}
return new Response('Not Found', { status: 404 });
},
});
Summary and Checklist
Key Summary
- Bun: Ultra-fast JavaScript runtime
- All-in-One: Runtime + Package Manager + Bundler + Test
- Fast Speed: 4x faster than Node.js
- TypeScript: Native support
- Node.js Compatible: Mostly compatible
- Web API: Built-in fetch, WebSocket
Implementation Checklist
- Install Bun
- Initialize project
- Implement web server
- Configure bundling
- Write tests
- Use file system
- Deploy
Related Articles
- Complete pnpm Guide
- Complete Vite 5 Guide
- Complete Vitest Guide
Keywords Covered
Bun, JavaScript, Runtime, Package Manager, Bundler, Performance, Node.js
Frequently Asked Questions (FAQ)
Q. Can it completely replace Node.js?
A. Possible in most cases, but some native modules may not be compatible.
Q. Is it safe to use in production?
A. Still version 1.0, but used in many projects. If stability is important, Node.js is recommended.
Q. Can I use npm packages?
A. Yes, most npm packages are compatible.
Q. Does it support Windows?
A. Yes, Windows is supported.
자주 묻는 질문 (FAQ)
Q. 이 내용을 실무에서 언제 쓰나요?
A. Complete guide to implementing fast JavaScript development with Bun. Node.js alternative, fast package installation, bui… 실무에서는 위 본문의 예제와 선택 가이드를 참고해 적용하면 됩니다.
Q. 선행으로 읽으면 좋은 글은?
A. 각 글 하단의 이전 글 또는 관련 글 링크를 따라가면 순서대로 배울 수 있습니다. C++ 시리즈 목차에서 전체 흐름을 확인할 수 있습니다.
Q. 더 깊이 공부하려면?
A. cppreference와 해당 라이브러리 공식 문서를 참고하세요. 글 말미의 참고 자료 링크도 활용하면 좋습니다.
같이 보면 좋은 글 (내부 링크)
이 주제와 연결되는 다른 글입니다.
- pnpm 완벽 가이드 | 빠른 패키지 관리자·Monorepo·Workspace·성능·실전 활용
- Vite 5 완벽 가이드 | 빌드 도구·HMR·플러그인·최적화·Rollup
이 글에서 다루는 키워드 (관련 검색어)
Bun, JavaScript, Runtime, Package Manager, Bundler, Performance, Node.js 등으로 검색하시면 이 글이 도움이 됩니다.