跳到主要内容
Deno 2.4 发布,带来 deno bundle、bytes/text imports、稳定的 OTel 等更多功能
了解更多
Supabase Functions on Deno Deploy

Deno Deploy 上的 Supabase Functions

我们很高兴宣布与 Supabase 合作,推出他们的新产品 Supabase Functions,该产品允许您在几秒钟内将代码全球部署到边缘。它建立在我们 Deno Deploy 基础设施之上,该基础设施默认包含自动扩展和自动缓存,因此您可以将更多精力放在产品构建上,而减少对基础设施的关注。

借助 Deno,Supabase Functions 获得了一流的 TypeScript 支持、ESM 风格的导入、开箱即用的安全性以及对现代 Web API 的支持。

如果您之前没有听说过 Supabase,它是一个开源的 Firebase 替代方案,提供后端服务来创建和部署网站、服务和应用程序。新的 Functions 产品加入了令人印象深刻的托管解决方案套件,包括数据库存储用户管理系统

让我们来看看如何开始。

Supabase Functions

开始使用 Supabase Functions 只需几分钟。

安装和设置 Supabase CLI

在 Mac 上,您可以使用 Homebrew

$ brew install supabase/tap/supabase

查看其他安装说明

通过此处获取访问令牌并将其粘贴到此命令后出现的提示中,登录您的 Supabase CLI。

$ supabase login

创建 Supabase 函数

您可以使用子命令 functions 来创建函数。

$ supabase functions new hello

这将创建一个函数 stub supabase/functions/hello/index.ts,它看起来像这样:

import { serve } from "https://deno.land/std@0.140.0/http/server.ts";

console.log("Hello from Functions!");

serve(async (req) => {
  const { name } = await req.json();
  const data = {
    message: `Hello ${name}!`,
  };

  return new Response(
    JSON.stringify(data),
    { headers: { "Content-Type": "application/json" } },
  );
});

本地执行函数

首先,启动 Docker,然后启动 Supabase 栈。

$ supabase start
Started local development setup.

         API URL: https://:54321
          DB URL: postgresql://postgres:postgres@localhost:54322/postgres
      Studio URL: https://:54323
    Inbucket URL: https://:54324
        anon key: eyxxxxx
service_role key: eyzzzzz

获取 anon key,因为我们需要在请求头中传递它来调用函数。

接下来,启动函数监听器。

$ supabase functions serve hello

请注意,supabase function serve 具有热重载功能。如果您的文件有任何更改,它将重新启动 Deno 服务器。

一旦函数在本地提供服务,您就可以使用 curl 执行它。将 ANON_KEY 替换为 supabase start 输出中的匿名密钥。

$ curl --location --request POST 'https://:54321/functions/v1/' \
    --header 'Authorization: Bearer ANON_KEY' \
    --header 'Content-Type: application/json' \
    --data '{"name":"Functions"}'

您应该收到响应 {"message":"Hello Functions!"}

部署函数

您可以直接从 CLI 部署函数。首先,您必须链接一个 Supabase 项目。请访问 supabase.com 并创建一个项目。

您的 Supabase 项目的 URL 结构应类似于 https://app.supabase.io/project/xyzabcxxxxxx/project/ 后面的字母就是项目的 ref,您需要在下面的命令中提供它。

$ supabase link --ref xyzabcxxxxxx
Finished supabase link.

然后,部署就如以下命令一样简单:

$ supabase functions deploy hello
Bundling supabase/functions/hello
Deployed Function hello on project xyzabcxxxxxx.

最后,在生产环境中执行函数。请注意,这里的 ANON_KEY 应在 Supabase 网站上您的项目设置中。

curl --location --request POST 'https://PROJECT_REF.supabase.co/functions/' \
  --header 'Authorization: Bearer ANON_KEY' \
  --header 'Content-Type: application/json' \
  --data '{"name": "Functions"}'

您应该收到响应 {"message":"Hello Functions!"}

欲了解更多信息,请参阅 Supabase 的文档

下一步是什么?

我们大力倡导尽可能轻松愉悦地进行 Web 开发,而让 Supabase 开发者能够通过 Deno Deploy 在全球部署边缘函数来增强其应用程序,正是朝着这个方向迈出的一步。随着更多开发者使用 Deno 和 Deno Deploy,这将有助于我们改进,以便您能持续获得为用户构建和部署产品的最佳体验。

想为您的用户提供快速、简单且全球化的边缘部署吗?请通过 deploy@deno.com 联系我们。