私有部署 (Self-Hosting)
私有部署适合希望自己控制数据路径、鉴权策略、数据库、私有通道和 MCP/OAuth 的用户。Gateway 是 Rust 服务;HTTP API、WSS、MCP/OAuth 共用同一个 HTTP listener,QUIC 和 Raw TCP 使用独立监听地址。
什么时候需要私有部署
Section titled “什么时候需要私有部署”- 不希望通知、事件或实体状态经过公共 Gateway。
- 需要自己的数据库、备份、日志、监控和容量策略。
- 需要 Android 私有通道的低延迟同步。
- 希望用自己的域名启用 MCP/OAuth。
- 需要网关级 Bearer Token 限制调用方。
如果你只是想体验 PushGo,先使用公共网关完成 快速上手。
| 层级 | 适合谁 | 主要配置 |
|---|---|---|
| 最小可用 | 本地测试、单用户脚本 | SQLite + HTTP API |
| 生产基础 | 长期运行、公开域名 | HTTPS 反向代理 + 持久化数据库 + Bearer Token |
| 私有通道 | Android 低延迟同步 | WSS,按需增加 QUIC / Raw TCP |
| AI 集成 | MCP 客户端和 AI 助手 | MCP/OAuth + PUSHGO_PUBLIC_BASE_URL |
最小可用部署
Section titled “最小可用部署”最小部署只需要数据库和 HTTP listener。
mkdir -p /var/lib/pushgo
docker run -d --name pushgo-gateway \ -p 6666:6666 \ -e PUSHGO_HTTP_ADDR=0.0.0.0:6666 \ -e PUSHGO_DB_URL='sqlite:///var/lib/pushgo/pushgo.db?mode=rwc' \ -v /var/lib/pushgo:/var/lib/pushgo \ ghcr.io/aldenclark/pushgo-gateway:latest测试:
curl -X POST http://127.0.0.1:6666/message \ -H "Content-Type: application/json" \ -d '{ "channel_id": "YOUR_CHANNEL_ID", "password": "YOUR_CHANNEL_PASSWORD", "title": "私有网关测试", "body": "这条消息来自自己的 Gateway。" }'最小部署适合验证链路,不建议直接暴露到公网。
生产基础配置
Section titled “生产基础配置”生产环境建议至少做到:
- Gateway 只监听内网或本机地址。
- 使用 Nginx、Caddy 或负载均衡器提供 HTTPS。
- 设置
PUSHGO_TOKEN作为网关级 Bearer Token。 - 使用持久化数据库并纳入备份。
- 显式设置
PUSHGO_PUBLIC_BASE_URL和PUSHGO_TOKEN_SERVICE_URL。
docker run -d --name pushgo-gateway \ -p 127.0.0.1:6666:6666 \ -e PUSHGO_HTTP_ADDR=0.0.0.0:6666 \ -e PUSHGO_DB_URL='postgres://user:pass@db:5432/pushgo' \ -e PUSHGO_TOKEN='replace-with-gateway-token' \ -e PUSHGO_PUBLIC_BASE_URL='https://gateway.example.com' \ -e PUSHGO_TOKEN_SERVICE_URL='https://token.pushgo.dev' \ ghcr.io/aldenclark/pushgo-gateway:latest设置 PUSHGO_TOKEN 后,所有 API 请求都需要:
Authorization: Bearer replace-with-gateway-token频道 ID 和频道密码仍然需要放在请求体中。两层鉴权的区别见 身份验证。
公共区域端点
Section titled “公共区域端点”如果 Gateway 需要联系 token-service,建议按区域显式配置。
| 区域 | Gateway | token-service |
|---|---|---|
| Global | https://gateway.pushgo.dev/ | https://token.pushgo.dev/ |
| 中国大陆 | https://gateway.pushgo.cn/ | https://token.pushgo.cn/ |
私有部署可以继续使用公共 token-service,也可以根据项目后续部署策略切换到自己的服务。
HTTP API、WSS、MCP/OAuth 共用 HTTP listener。反向代理需要支持普通 HTTP 和 WebSocket upgrade。
server { listen 443 ssl http2; server_name gateway.example.com;
ssl_certificate /etc/nginx/certs/fullchain.pem; ssl_certificate_key /etc/nginx/certs/privkey.pem;
location / { proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; proxy_pass http://127.0.0.1:6666; }}PUSHGO_PUBLIC_BASE_URL 必须是外部可访问的 HTTPS 根地址,否则 MCP issuer、绑定链接和客户端 profile 可能生成内部地址。
Android 私有通道
Section titled “Android 私有通道”私有通道由 PUSHGO_PRIVATE_TRANSPORTS 开启。建议从 wss 开始,因为它复用 HTTPS 入口,部署复杂度最低。
PUSHGO_PRIVATE_TRANSPORTS=wssPUSHGO_PUBLIC_BASE_URL=https://gateway.example.com需要更低延迟或受控网络时,再增加 QUIC / Raw TCP。
PUSHGO_PRIVATE_TRANSPORTS=quic,tcp,wssPUSHGO_PRIVATE_QUIC_BIND=0.0.0.0:5223PUSHGO_PRIVATE_QUIC_PORT=5223PUSHGO_PRIVATE_TCP_BIND=0.0.0.0:5223PUSHGO_PRIVATE_TCP_PORT=5223PUSHGO_PRIVATE_TLS_CERT=/certs/fullchain.pemPUSHGO_PRIVATE_TLS_KEY=/certs/privkey.pem| 配置 | 说明 |
|---|---|
PUSHGO_PRIVATE_TRANSPORTS | false、true、none 或显式列表,例如 wss、quic,tcp,wss。 |
PUSHGO_PRIVATE_QUIC_BIND | Gateway 实际监听的 UDP 地址。 |
PUSHGO_PRIVATE_QUIC_PORT | 对客户端宣告的 QUIC 端口。 |
PUSHGO_PRIVATE_TCP_BIND | Gateway 实际监听的 TCP 地址。 |
PUSHGO_PRIVATE_TCP_PORT | 对客户端宣告的 Raw TCP 端口。 |
PUSHGO_PRIVATE_TLS_CERT / PUSHGO_PRIVATE_TLS_KEY | QUIC 必填;Raw TCP 未做 TLS offload 时也必填。 |
PUSHGO_PRIVATE_TCP_TLS_OFFLOAD | Raw TCP 是否由边缘代理处理 TLS。 |
PUSHGO_PRIVATE_TCP_PROXY_PROTOCOL | Raw TCP 入口是否期待 PROXY protocol v1。 |
QUIC 使用自定义 ALPN (pushgo-quic),不能简单地和 HTTP/3 共用同一个 UDP/443 入口。若边缘代理已在 443/udp 提供 HTTP/3,请为 PushGo QUIC 使用独立 UDP 端口,或确认代理能够正确分流。
MCP / OAuth
Section titled “MCP / OAuth”启用 MCP 至少需要:
PUSHGO_MCP_ENABLED=truePUSHGO_PUBLIC_BASE_URL=https://gateway.example.com常用配置:
| 环境变量 | 默认值 | 说明 |
|---|---|---|
PUSHGO_MCP_DCR_ENABLED | true | 是否允许 Dynamic Client Registration。 |
PUSHGO_MCP_PREDEFINED_CLIENTS | 无 | 预置 OAuth 客户端,格式为 client_id:client_secret;多个客户端用换行或分号分隔。 |
更多工具和授权流程见 MCP 参考。
核心配置速查
Section titled “核心配置速查”| CLI / 环境变量 | 默认值 | 说明 |
|---|---|---|
--http-addr / PUSHGO_HTTP_ADDR | 127.0.0.1:6666 | HTTP API、WSS、MCP/OAuth 的监听地址。 |
--db-url / PUSHGO_DB_URL | 无,必填 | 数据库 URL,支持 SQLite、PostgreSQL 和 MySQL。 |
--runtime-profile / PUSHGO_RUNTIME_PROFILE | small | 运行时容量档位:small 用于私有/轻量部署,public 用于高负载部署。 |
--token / PUSHGO_TOKEN | 无 | 网关级 Bearer Token;为空时不启用网关级 Token 鉴权。 |
--token-service-url / PUSHGO_TOKEN_SERVICE_URL | https://token.pushgo.dev | token-service 地址,生产环境建议显式设置。 |
--public-base-url / PUSHGO_PUBLIC_BASE_URL | 无 | 对外 HTTPS 根地址。 |
--sandbox-mode / PUSHGO_SANDBOX_MODE | false | 沙箱模式,包括 APNs sandbox endpoint。 |
--observability-profile / PUSHGO_OBSERVABILITY_PROFILE | prod_min | 可观测性档位:prod_min、ops、incident、debug。 |
--observability-log-level / PUSHGO_OBSERVABILITY_LOG_LEVEL | warn | 原生 tracing 日志级别。 |
- 数据库必须纳入备份;频道、设备、MCP 授权和实体状态都依赖持久化存储。
- SQLite 适合个人或轻量部署;多人或高并发场景优先使用 PostgreSQL。
- 高负载先观察分发队列和 worker,再评估数据库和 provider 限流。
- 生产排障优先使用
PUSHGO_OBSERVABILITY_PROFILE=ops,临时深查再切到incident或debug。 - Android 私有通道问题先检查
/gateway/profile宣告的端口和外部可访问性。
运行时容量:
Gateway v1.2.9 的运行容量由运行时档位管理。私有或轻量部署使用 PUSHGO_RUNTIME_PROFILE=small,高负载公网部署使用 PUSHGO_RUNTIME_PROFILE=public。队列、分发、提供商、数据库连接池和 SQLite 等底层调优值现在是档位内置默认值,不再作为公开环境变量配置。
- 升级前备份数据库和运行配置。
- 保持 Gateway 镜像/二进制、环境变量和反向代理配置可追踪。
- 先在测试频道验证
/message、/event/create和/thing/create。 - 如果启用了私有通道,升级后检查 Android 客户端是否能获取新的
/gateway/profile。 - 如果启用了 MCP,升级后检查
/.well-known/*、/oauth/*和/mcp是否仍使用外部 HTTPS 地址。