Skip to content

Для запуска нескольких HTTP-серверов одновременно используйте опцию reusePort в Bun.serve(), которая позволяет нескольким процессам использовать один и тот же порт.

Это автоматически балансирует нагрузку входящих запросов между несколькими экземплярами Bun.

ts
import { serve } from "bun";

const id = Math.random().toString(36).slice(2);

serve({
  port: process.env.PORT || 8080,
  development: false,

  // Использовать один порт для нескольких процессов
  // Это важная часть!
  reusePort: true,

  async fetch(request) {
    return new Response("Hello from Bun #" + id + "!\n");
  },
});

NOTE

**Только Linux** — Windows и macOS игнорируют опцию `reusePort`. Это ограничение операционной системы с `SO_REUSEPORT`.

После сохранения файла запустите ваши серверы на одном порту.

Под капотом это использует опции сокета Linux SO_REUSEPORT и SO_REUSEADDR для обеспечения справедливой балансировки нагрузки между несколькими процессами. Узнайте больше о SO_REUSEPORT и SO_REUSEADDR

ts
import { spawn } from "bun";

const cpus = navigator.hardwareConcurrency; // Количество ядер CPU
const buns = new Array(cpus);

for (let i = 0; i < cpus; i++) {
  buns[i] = spawn({
    cmd: ["bun", "./server.ts"],
    stdout: "inherit",
    stderr: "inherit",
    stdin: "inherit",
  });
}

function kill() {
  for (const bun of buns) {
    bun.kill();
  }
}

process.on("SIGINT", kill);
process.on("exit", kill);

Bun также реализовал модуль node:cluster, но это более быстрая, простая и ограниченная альтернатива.

Bun от www.bunjs.com.cn