暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

让函数随时可用,详解PolarDB Supabase Edge Functions

1316

在现代全栈开发中,边缘函数(Edge Functions)已成为连接前端与后端逻辑的关键枢纽。它让开发者无需管理服务器,即可将自定义代码部署在全球边缘节点,实现低延迟、高可用、自动扩展的 API 与事件处理能力。PolarDB Supabase 支持完整的 Edge Functions 功能闭环,成为业内少数在公有云托管环境中实现这一能力的平台。

01


什么是Supabase Edge Functions?为现代应用而生的无服务器引擎

Supabase Edge Functions 是一套基于 Deno 运行时构建的轻量级无服务器服务,是一种为全栈应用量身打造的现代化边缘计算解决方案。

🔥 核心能力一览

🌐 典型应用场景

Edge Functions 不仅是“写个 API”,更是连接前后端、第三方服务与业务系统的智能中枢:

⚙️ 开发体验:极简、高效、现代化

Supabase 为 Edge Functions 提供了两种主流开发方式,满足不同团队的工作流需求:
1. 通过 CLI 部署(适合专业开发者与 CI/CD)
  • 本地打包:使用 supabase cli 将源码编译为单个main.js

  • 安全上传:通过 Bearer Token 认证推送至云端
  • 适合自动化部署、GitOps 流程
2. 通过 Studio 可视化部署(适合快速迭代与团队协作)
  • 在浏览器中直接编辑函数代码
  • 点击“Save and Deploy”一键发布
  • 支持语法高亮、错误提示、实时保存
  • 无需本地环境,适合产品经理、运维人员参与开发
这两种方式共同构成了Supabase Cloud上完整、高效、开箱即用的无服务器开发闭环。

02


开源版 Supabase 的“能力断层”:有引擎,无驾驶舱

Supabase 是开源的,但它的 Edge Functions 管理后台(FaaS Backend)并未开源。这意味着:
  • 您可以在本地使用supabase start
    运行边缘函数(模拟环境);

  • 也可以部署一个包含edge-runtime
    的容器;

  • 但您无法通过 Studio 创建、编辑或部署函数;
  • 也无法通过 CLI 将代码推送到自建实例。
许多企业在尝试自建 Supabase 时,发现 Edge Functions 功能“不可用”或“只能靠手动脚本部署”,最终放弃使用这一核心能力。

03


Supabase Cloud vs. 公有云托管:一场关于隔离性与控制力的权衡

04


PolarDB Supabase:打破两难,兼顾功能完整与企业级控制力

我们深知企业客户的需求:既要现代化的开发体验,又要对资源、数据和系统拥有更强的控制力。

因此,PolarDB Supabase 在公有云托管环境下,采用独立实例(Isolated Instance)架构,并自主研发轻量级 FaaS 管理系统,成功补全了开源版 Supabase 缺失的最后一块拼图——Edge Functions。

✅ 我们带来了什么?

您获得的是:与 Supabase Cloud 几乎一致的开发体验,但运行在资源独享、数据可控的独立实例中。

05


立即体验:30秒开启第一个边缘函数

1. 登录 PolarDB Supabase Studio
2. 进入 “Edge Functions” 页面
3. 可通过下面三种方式的任意一种来完成代码编辑
a. 代码编辑器
b. 本地打包上传eszip(包含所有依赖)
c. 本地打包上传zip(不包含依赖,上传后服务端打包依赖)

4. 调用URL:http://<supabase实例公网地址>/functions/v1/hello-world

06


最佳实践

1. 参考最佳实践文档,实战一个完整的Web应用。
🔗 https://help.aliyun.com/zh/polardb/polardb-for-postgresql/polardb-supabase-best-practices
2. 登录 PolarDB Supabase Studio,进入 “Edge Functions” 页面,点击 “New Function”,Function name 输入:tongyi
3. 代码编辑框填入下面内容,点击 “Save and Deploy”。代码逻辑是调用通义API,总结会议纪要。注意:代码中要填入您的通义大模型 apiKey。
import "jsr:@supabase/functions-js/edge-runtime.d.ts";
import { OpenAI } from "npm:openai@4.8.0";
// CORS headers
const corsHeaders = {
  'Access-Control-Allow-Origin': '*',
  'Access-Control-Allow-Headers': 'authorization, apikey, content-type',
  'Access-Control-Allow-Methods': 'GET, POST, PUT, DELETE, OPTIONS',
  '
Content-Type': 'application/json,charset=utf-8'
};
const openai = new OpenAI({
  apiKey: "your api key",
  baseURL: "https://dashscope.aliyuncs.com/compatible-mode/v1"
});
Deno.serve(async (req)=>{
  if (req.method === '
OPTIONS') {
    return new Response('
ok', {
      headers: corsHeaders
    });
  }
  const { prompt } = await req.json();
  const response = await openai.chat.completions.create({
    model: "qwen-turbo",
    messages: [
      {
        role: "system",
        content: "你是一个专业的会议纪要助手,能够根据会议内容生成结构化的会议纪要。"
      },
      {
        role: "user",
        content: prompt
      }
    ]
  });
  return new Response(JSON.stringify({
    answer: response.choices[0].message.content
  }), {
    headers: corsHeaders
  });
});

4. 按照最佳实践文档启动本地运行:pnpm run dev
5. 进入会议,填写一些会议内容,点击AI纪要总结。前端会请求 Edge Functions 函数,利用通义大模型生成会议纪要,效果见下图:

07


结语:让强大,更自由

Supabase的强大,在于它让全栈开发变得简单。 而真正的自由,是既能享受这份简单,又能掌控自己的数据、资源与架构。
PolarDB Supabase 不做功能的搬运者,我们是完整体验的创造者。 在公有云的便利之上,构建独立实例的确定性;在开源的能力之外,补全企业所需的每一块拼图。

🌐 您不必在“开箱即用”和“自主可控”之间妥协。现在,您可以同时拥有两者。

PolarDB Supabase Edge Functions —— 在公有云上,释放 Supabase 的全部潜能,补全开源缺失的最后一块拼图。

如果您对 PolarDB Supabase 感兴趣,欢迎钉钉搜索群号:87370039661 或 扫码加入钉群申请试用,与我们面对面交流

#云原生数据库PolarDB

点击阅读原文了解 PolarDB Supabase 更多内容

喜欢就请点赞/分享/推荐

文章转载自阿里云瑶池数据库,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论