데이터베이스 옵션

이 페이지

EmDash는 여러 데이터베이스 백엔드를 지원합니다. 배포 대상에 따라 선택하세요.

개요

데이터베이스최적 용도배포
D1Cloudflare Workers엣지, 전역 분산
PostgreSQL프로덕션 Node.jsPostgres를 지원하는 모든 플랫폼
libSQL원격 데이터베이스엣지 또는 Node.js
SQLiteNode.js, 로컬 개발단일 서버

Cloudflare D1

D1은 Cloudflare의 서버리스 SQLite 데이터베이스입니다. Cloudflare Workers에 배포할 때 사용하세요.

import { d1 } from "@emdash-cms/cloudflare";

export default defineConfig({
	integrations: [
		emdash({
			database: d1({ binding: "DB" }),
		}),
	],
});

구성

옵션타입기본값설명
bindingstringwrangler.jsonc의 D1 바인딩 이름
sessionstring"disabled"읽기 복제 모드 (아래 참조)
bookmarkCookiestring"__em_d1_bookmark"세션 북마크용 쿠키 이름

설정

wrangler.jsonc

{
  "d1_databases": [
    {
      "binding": "DB",
      "database_name": "emdash-db",
      "database_id": "your-database-id"
    }
  ]
}

wrangler.toml

[[d1_databases]]
binding = "DB"
database_name = "emdash-db"
database_id = "your-database-id"

D1 데이터베이스 생성

wrangler d1 create emdash-db

읽기 레플리카

D1은 읽기 복제를 지원하여 전역 분산 사이트의 읽기 지연 시간을 줄입니다. 활성화하면 읽기 쿼리가 항상 기본 데이터베이스에 접속하는 대신 가까운 레플리카로 라우팅됩니다.

EmDash는 D1 Sessions API를 사용하여 이를 투명하게 관리합니다. session 옵션으로 활성화하세요:

import { d1 } from "@emdash-cms/cloudflare";

export default defineConfig({
	integrations: [
		emdash({
			database: d1({
				binding: "DB",
				session: "auto",
			}),
		}),
	],
});

세션 모드

모드동작
"disabled"세션 없음. 모든 쿼리가 기본으로 전송됩니다. 기본값.
"auto"익명 요청은 가장 가까운 레플리카에서 읽습니다. 인증된 사용자는 북마크 쿠키를 통해 읽기-쓰기 일관성을 얻습니다.
"primary-first""auto"와 유사하지만 첫 번째 쿼리는 항상 기본으로 전송됩니다. 쓰기가 매우 빈번한 사이트에 사용합니다.

작동 방식

  • 익명 방문자first-unconstrained를 받습니다 — 읽기는 가장 가까운 레플리카로 전송되어 최저 지연 시간을 달성합니다. 익명 사용자는 쓰기를 수행하지 않으므로 일관성 보장이 필요하지 않습니다.
  • 인증된 사용자 (편집자, 작성자)는 북마크 기반 세션을 받습니다. 쓰기 후 북마크 쿠키는 다음 요청이 최소한 해당 상태를 보도록 보장합니다.
  • 쓰기 요청 (POST, PUT, DELETE)은 항상 기본 데이터베이스에서 시작됩니다.
  • 빌드 시 쿼리 (Astro 콘텐츠 컬렉션)는 세션을 완전히 우회하고 기본을 직접 사용합니다.

libSQL

libSQL은 원격 연결을 지원하는 SQLite의 포크입니다. Cloudflare D1을 사용하지 않고 원격 데이터베이스가 필요할 때 사용하세요.

import { libsql } from "emdash/db";

export default defineConfig({
	integrations: [
		emdash({
			database: libsql({
				url: process.env.LIBSQL_DATABASE_URL,
				authToken: process.env.LIBSQL_AUTH_TOKEN,
			}),
		}),
	],
});

구성

옵션타입설명
urlstring데이터베이스 URL (libsql://... 또는 file:...)
authTokenstring원격 데이터베이스용 인증 토큰 (로컬에서는 선택 사항)

로컬 개발

개발 중에 로컬 libSQL 파일을 사용하세요:

database: libsql({ url: "file:./data.db" });

PostgreSQL

PostgreSQL은 완전한 관계형 데이터베이스가 필요한 Node.js 배포에서 지원됩니다.

import { postgres } from "emdash/db";

export default defineConfig({
	integrations: [
		emdash({
			database: postgres({
				connectionString: process.env.DATABASE_URL,
			}),
		}),
	],
});

구성

연결 문자열 또는 개별 매개변수로 연결할 수 있습니다:

// 연결 문자열
database: postgres({
	connectionString: "postgres://user:password@localhost:5432/emdash",
});

// 개별 매개변수
database: postgres({
	host: "localhost",
	port: 5432,
	database: "emdash",
	user: "emdash",
	password: process.env.DB_PASSWORD,
	ssl: true,
});
옵션타입설명
connectionStringstringPostgreSQL 연결 URL
hoststring데이터베이스 호스트
portnumber데이터베이스 포트
databasestring데이터베이스 이름
userstring데이터베이스 사용자
passwordstring데이터베이스 비밀번호
sslbooleanSSL 활성화
pool.minnumber최소 풀 연결 수 (기본값 0)
pool.maxnumber최대 풀 연결 수 (기본값 10)

연결 풀링

어댑터는 내부적으로 pg.Pool을 사용합니다. 배포에 따라 풀 크기를 조정하세요:

database: postgres({
	connectionString: process.env.DATABASE_URL,
	pool: { min: 2, max: 20 },
});

SQLite

better-sqlite3를 사용하는 SQLite는 Node.js 배포의 가장 간단한 옵션입니다.

import { sqlite } from "emdash/db";

export default defineConfig({
	integrations: [
		emdash({
			database: sqlite({ url: "file:./data.db" }),
		}),
	],
});

구성

옵션타입설명
urlstringfile: 접두사가 있는 파일 경로

파일 경로

urlfile:로 시작해야 합니다:

// 상대 경로
database: sqlite({ url: "file:./data/emdash.db" });

// 절대 경로
database: sqlite({ url: "file:/var/data/emdash.db" });

// 환경 변수에서
database: sqlite({ url: `file:${process.env.DATABASE_PATH}` });

마이그레이션

EmDash는 SQLite, libSQL 및 PostgreSQL의 마이그레이션을 자동으로 처리합니다. D1의 경우 Wrangler를 통해 마이그레이션을 실행하세요.

마이그레이션 상태 확인

npx emdash init --database ./data.db

이 명령은:

  1. 필요한 경우 데이터베이스 파일 생성
  2. 보류 중인 마이그레이션 실행
  3. 현재 마이그레이션 상태 보고

마이그레이션 파일

마이그레이션은 EmDash와 함께 번들로 제공됩니다. 수동으로 실행하려면:

# SQLite/libSQL - 마이그레이션이 자동으로 실행됩니다

# D1 - wrangler를 통해 실행
wrangler d1 migrations apply DB

환경 기반 구성

환경마다 다른 데이터베이스를 사용하세요:

import { sqlite, libsql, postgres } from "emdash/db";
import { d1 } from "@emdash-cms/cloudflare";

const database = import.meta.env.PROD ? d1({ binding: "DB" }) : sqlite({ url: "file:./data.db" });

export default defineConfig({
	integrations: [emdash({ database })],
});

또는 환경 변수에 따라 전환하세요:

const database = process.env.DATABASE_URL
	? postgres({ connectionString: process.env.DATABASE_URL })
	: sqlite({ url: "file:./data.db" });