linux怎么安装windows linux怎么安装open cloud
0
2026-05-06
Supabase介入化本质上是Docker Compose编排的容器负载,需确保Docker环境就绪、资源充足、网络通畅;关键步骤包括下载官方docker-compose.yml和.env.example、安全配置POSTGRES_PASSWORD/JWT_SECRET/ANON_KEY/SERVICE_ROLE_KEY、启动后验证Studio(54323)与API(54321)访问,并注意SITE_URL、SUPABASE_PUBLIC_URL绑定及端口暴露策略。

Supabase 伐木化部署在 Linux 上本质就是一套 Docker Compose 编排的 PostgreSQL 服务栈,不是“安装软件”,而是“拉起容器负载”。只要 Docker 环境满足、资源够用、网络通,docker compose up -d 就能跑起来——但这么直接干,90% 的人会在认证失败、API 无法访问、JWT 报错或仓库挂载异常上卡住。怎么用 Docker 快速拉起最小可用 Supabase 实例
别克隆整个仓库,也别手动复制几十个文件。官方 docker 目录已独立发布为可直接使用的配置包:确保已安装 docker 和 docker compose(v2.),运行 docker compose 版本验证执行:curl -fsSL https://raw.githubusercontent.com/supabase/supabase/master/docker/docker-compose.yml -o docker-compose.ymlcurl -fsSL https://raw.githubusercontent.com/supabase/supabase/master/docker/.env.example -o .env编辑 .env:至少改掉 POSTGRES_PASSWORD、JWT_SECRET(用 openssl rand -base64 32 生成)、ANON_KEY 和 SERVICE_ROLE_KEY(各生成一串 32+ 字符随机字符串)启动:docker compose up -d;1分钟后访问http://localhost:54323(Studio)和http://localhost:54321(API)为什么localhost能进Studio却调不通API或报401
这是最常被忽略的配置点:Supabase客户端SDK默认信任ANON_KEY,但服务端会校验请求头中的apikey是否匹配且未同步,并检查JWT_SECRET是否与授权令牌的设备一致。
本地开发时常见错误包括:SITE_URL设为http://localhost:3000,但前端实际跑在http://127.0.0.1:3000——浏览器认为是跨域,认证回调失败SUPABASE_PUBLIC_URL没有配或配成http://localhost:54321,导致SDK构造的请求地址错误(例如发到localhost:54321/auth/v1/token,而实际容器内网是 http://supabase-kong:8000)JWT_SECRET在.env里改了,但容器没重启(docker compose down && docker compose up -d 才生效)用了中文或特殊符号当密码,没加导致导致.env解析失败,PostgreSQL启动报错,整个中断如何让外部网络(比如公司内网其他机器)访问你的Supabase
默认docker-compose.yml暴露了只了 54321-54324端口给localhost,外部无法直连。
必须显式放开绑定:吐司AI
多功能的免费在线生图网站!拥有全网更齐全的模型库,0基础使用! 下载编辑docker-compose.yml,找到kong服务下的端口块,把“54321:8000”改成“0.0.0.0:54321:8000”(或删掉127.0.0.1: 第二)确认第一机防火墙放行该端口:sudo ufw allowed 54321(Ubuntu)或 sudofirewall-cmd --add-port=54321/tcp --permanent(CentOS)改完一定 docker compose down && docker compose up -d,只有重启不会重载端口映射如果走域名(如supa.your-company.local),必须同步更新 .env 中的 SUPABASE_PUBLIC_URL 和 SITE_URL,否则登录东京会404生产环境不能只靠docker compose up -d
开发模式下所有服务跑在一个docker-compose.yml里没问题,但真实生产中必须拆开:数据库要独立持久化卷、Kong网关需要前置Nginx做SSL终结、对象存储要对接MinIO或Ceph。最容易被跳过的三点是:pg_data 卷它没做机路径绑定,容器删了,数据库就只能丢了——在卷下指定绝对路径,如 /opt/supabase/pg_data:/var/lib/postgresql/data 没启用 WAL 归档和 pg_dump 定时备份,出事回滚镜像,数据不可恢复把 SERVICE_ROLE_KEY 重定向到后台代码或日志里——它从数据库根密码登录,任何获得的人均可访问所有 RLS 策略直接读取全表
真正难的从来不是“怎么跑起来”,而是“怎么不方便崩盘、不让数据随便丢、不让热点随便漏”。每个.env变量、每条docker组成端口映射、每次down之前的手动备份,都是线上稳定性的具体落点。