Turso是一个多租户数据库平台,适用于各种类型的应用程序,包括具有设备端RAG的AI应用程序、本地优先的向量搜索、离线写入和注重隐私的低延迟数据访问。

以下是如何将您的SuperStarter项目从Neon切换到Turso

1. 注册Turso

您可以使用DashboardCLI来管理您的账户、数据库和认证令牌。

在本指南中,我们将使用CLI。

2. 创建数据库

使用Turso CLI创建一个新数据库并为其命名:

Terminal
turso db create <database-name>

您现在可以获取数据库的URL:

Terminal
turso db show <database-name> --url

它看起来会像这样:

libsql://<database-name>-<account-or-org-slug>.turso.io

3. 创建数据库认证令牌

您需要创建一个认证令牌以连接到您的Turso数据库:

Terminal
turso db tokens create <database-name>

4. 更新您的环境变量

更新您的环境变量以使用新的Turso连接字符串:

apps/database/.env
DATABASE_URL="libsql://<database-name>-<account-or-org-slug>.turso.io"
DATABASE_AUTH_TOKEN="..."
apps/app/.env.local
DATABASE_URL="libsql://<database-name>-<account-or-org-slug>.turso.io"
DATABASE_AUTH_TOKEN="..."

等等。

现在在zh/packages/env/index.ts中,将DATABASE_AUTH_TOKEN添加到serverruntimeEnv对象中:

const server: Parameters<typeof createEnv>[0]["server"] = {
  // ...
  DATABASE_AUTH_TOKEN: z.string(),
  // ...
};

export const env = createEnv({
  client,
  server,
  runtimeEnv: {
    // ...
    DATABASE_AUTH_TOKEN: process.env.DATABASE_AUTH_TOKEN,
    // ...
  },
});

5. 安装@libsql/client

@libsql/client用于连接托管的Turso数据库。

卸载Neon的现有依赖…

Terminal
pnpm remove @neondatabase/serverless @prisma/adapter-neon ws @types/ws --filter @repo/database

…并安装Turso和libSQL的新依赖:

Terminal
pnpm add @libsql/client --filter @repo/database

6. 更新Webpack配置

打开zh/packages/next-config/index.ts并将@libsql/client添加到外部依赖列表中:

zh/packages/next-config/index.ts
let nextConfig: NextConfig = {
  ...config,
  webpack: (config, { isServer }) => {
    if (isServer) {
      config.externals = [...(config.externals || []), "@libsql/client"];
    }

    // ...
  },
};

7. 更新数据库连接代码

打开zh/packages/database/index.ts并进行以下更改:

zh/packages/database/index.ts
import "server-only";

import { createClient } from "@libsql/client";
import { env } from "@repo/env";

const libsql = createClient({
  url: env.DATABASE_URL,
  authToken: env.DATABASE_AUTH_TOKEN,
});

export const database = libsql;

8. 应用模式更改

现在使用CLI连接到Turso数据库:

Terminal
turso db shell <database-name>

并将模式应用到数据库:

CREATE TABLE pages (
  id INTEGER PRIMARY KEY AUTOINCREMENT,
  email TEXT UNIQUE NOT NULL,
  name TEXT
);

9. 更新应用程序代码

现在,无论您通常在何处调用Prisma,都请改用libsql客户端:

packages/app/app/(authenticated)/page.tsx
import { database } from "@repo/database";

type PageType = {
  id: number;
  email: string;
  name?: string;
};

// ...

const { rows } = await database.execute(`SELECT * FROM pages`);

const pages = rows as unknown as Array<PageType>;