部署到 Node.js

本頁內容

EmDash 可以在任何 Node.js 22+ 託管平台上執行。本指南使用 SQLite 與本機或 S3 相容儲存;libSQL 和 PostgreSQL 在 Node.js 上的運作方式相同 — 請參閱資料庫選項

前置要求

  • Node.js v22.12.0 或更高版本
  • Node.js 託管提供商或 VPS

設定

為 Node.js 部署設定 EmDash:

import { defineConfig } from "astro/config";
import node from "@astrojs/node";
import emdash, { local, s3 } from "emdash/astro";
import { sqlite } from "emdash/db";

export default defineConfig({
	output: "server",
	adapter: node({ mode: "standalone" }),
	integrations: [
		emdash({
			database: sqlite({ url: "file:./data/emdash.db" }),
			storage: local({
				directory: "./data/uploads",
				baseUrl: "/_emdash/api/media/file",
			}),
		}),
	],
});

建置和執行

  1. 建置專案:

    npm run build
  2. 啟動伺服器:

    node ./dist/server/entry.mjs

伺服器預設在 http://localhost:4321 上執行。遷移在第一次請求時套用。如果資料庫為空且尚未完成設定,您的種子檔案(如果沒有則使用內建預設值)也會在第一次請求時套用。

生產環境儲存

對於生產環境,使用 S3 相容儲存而不是本機檔案系統:

import emdash, { s3 } from "emdash/astro";

export default defineConfig({
	integrations: [
		emdash({
			database: sqlite({ url: `file:${process.env.DATABASE_PATH}` }),
			storage: s3({
				endpoint: process.env.S3_ENDPOINT,
				bucket: process.env.S3_BUCKET,
				accessKeyId: process.env.S3_ACCESS_KEY_ID,
				secretAccessKey: process.env.S3_SECRET_ACCESS_KEY,
				publicUrl: process.env.S3_PUBLIC_URL, // Optional CDN URL
			}),
		}),
	],
});

Docker

新增 .dockerignore 以保持建置內容較小:

node_modules
dist
.git

建立 Dockerfile

FROM node:22-alpine AS builder
WORKDIR /app
COPY package*.json ./
RUN npm ci
COPY . .
RUN npm run build

FROM node:22-alpine
WORKDIR /app
COPY --from=builder /app/dist ./dist
COPY --from=builder /app/node_modules ./node_modules
COPY --from=builder /app/package.json ./

RUN mkdir -p data

ENV HOST=0.0.0.0
ENV PORT=4321

EXPOSE 4321
CMD ["node", "./dist/server/entry.mjs"]

種子檔案在建置時讀取並內嵌到套件中,因此不需要複製到執行時映像中。遷移在部署後的第一次請求時執行;種子僅在資料庫沒有集合且尚未完成設定時套用 — 現有資料永遠不會被覆寫。

建置映像並執行容器:

docker build -t my-emdash-site .
docker run -p 4321:4321 -v emdash-data:/app/data my-emdash-site

Docker Compose 檔案使用命名卷管理相同的容器:

services:
  emdash:
    build: .
    ports:
      - "4321:4321"
    volumes:
      - emdash-data:/app/data
    restart: unless-stopped

volumes:
  emdash-data:

在背景啟動堆疊:

docker compose up -d

環境變數

建議:加密金鑰

EMDASH_ENCRYPTION_KEY 是用於加密外掛程式金鑰的金鑰。 該金鑰在啟動時驗證;外掛程式金鑰加密在啟用後使用它。 在每次部署時設定它,以便在不進行後續組態變更的情況下保護金鑰。

產生金鑰並將結果新增到您的環境中:

npx emdash secrets generate  # add the result to your environment

金鑰由您提供,永遠不會儲存在資料庫中;只有 加密的密文會被儲存。將其備份到持久位置(密碼管理器、 KMS 或您團隊的金鑰儲存)— 遺失它意味著遺失 使用它加密的每個金鑰。

可選:穩定值覆寫

EmDash 自動產生預覽 HMAC 金鑰和評論者 IP 雜湊鹽, 並在首次使用時將它們持久化到資料庫中。下面的環境變數 將它們固定到您控制的值 — 當單獨的程序需要 與您的主站台共享金鑰時很有用。

變數說明
EMDASH_PREVIEW_SECRET覆寫自動產生的預覽 HMAC 金鑰。
EMDASH_IP_SALT覆寫自動產生的評論者 IP 雜湊鹽。
EMDASH_AUTH_SECRET可選。如果設定,用作 IP 鹽來源(除非也設定了 EMDASH_IP_SALT,後者優先),為已經依賴它的安裝保持評論者 IP 雜湊穩定。對於新部署,請將其保持未設定狀態。

資料庫和儲存

變數說明範例
DATABASE_PATHSQLite 資料庫路徑/data/emdash.db
HOST伺服器主機0.0.0.0
PORT伺服器連接埠4321
S3_ENDPOINTS3 端點 URLhttps://xxx.r2.cloudflarestorage.com
S3_BUCKETS3 儲存貯體名稱my-media-bucket
S3_ACCESS_KEY_IDS3 存取金鑰AKIA...
S3_SECRET_ACCESS_KEYS3 金鑰...
S3_PUBLIC_URL媒體的公開 URLhttps://cdn.example.com

持久儲存

SQLite 需要持久磁碟儲存。確保您的託管平台提供:

  • 掛載的卷或持久磁碟
  • 對資料庫目錄的寫入存取權限
  • 資料庫檔案的備份機制

健康檢查

為負載平衡器新增健康檢查端點:

export const GET = () => {
  return new Response("OK", { status: 200 });
};

設定您的平台以檢查 /health 進行存活探測。