采用共享实例加隔离上下文的混合多租户架构,通过tenant_id贯穿API网关、身份鉴权、数据分区、配置管理、函数运行时及计费全链路,实现租户间安全隔离与资源管控,结合RBAC权限体系、容器化沙箱、资源配额与独立命名空间,在保障高效可扩展的同时支持差异化部署与按需计费。

构建一个支持多租户的云函数平台,核心在于隔离、资源管理、安全和可扩展性。你需要从架构设计开始就考虑不同租户之间的数据、配置和执行环境的分离,同时保证系统高效运行。
1. 多租户模型选择
确定采用哪种多租户架构直接影响后续设计:
- 共享实例 + 隔离上下文:所有租户共用函数运行实例,通过请求上下文区分租户。成本低,适合轻量级场景,但需严格防止数据泄露。
- 独立命名空间或容器:每个租户有独立的函数命名空间或运行容器,如Kubernetes中按namespace隔离。兼顾性能与安全。
- 完全独立部署:为大客户单独部署运行环境,适用于合规要求高的企业租户。
大多数平台采用混合模式:中小租户共享资源池,大客户可选独占部署。
2. 身份认证与访问控制
每个租户必须有唯一身份标识,并通过统一鉴权机制控制访问:
- 使用OAuth 2.0或JWT进行租户身份验证,请求携带tenant_id作为上下文。
- 实现基于角色的访问控制(RBAC),定义租户内用户权限,如开发者只能部署函数,管理员可查看日志。
- API网关层拦截请求,校验租户凭证并路由到对应处理逻辑。
3. 数据与配置隔离
确保租户间的数据不交叉是关键:
Destoon B2B网站管理系统是一套完善的B2B(电子商务)行业门户解决方案。系统基于PHP+MySQL开发,采用B/S架构,模板与程序分离,源码开放。模型化的开发思路,可扩展或删除任何功能;创新的缓存技术与数据库设计,可负载千万级别数据容量及访问。 系统特性1、跨平台。支持Linux/Unix/Windows服务器,支持Apache/IIS/Zeus等2、跨浏览器。基于最新Web标准构建,在
- 数据库设计采用tenant_id字段分区,所有查询自动附加该条件,避免误读其他租户数据。
- 配置中心(如etcd、Consul)按租户划分命名空间,函数启动时拉取专属配置。
- 日志和监控数据打上租户标签,便于审计和计费。
4. 函数运行时隔离与资源限制
防止某个租户占用过多资源影响他人:
- 在容器层面设置CPU、内存限制,如Docker或Kubernetes的resource quota。
- 为每个租户设定调用频率(Rate Limit)和并发上限,防止单租户压垮系统。
- 函数沙箱化执行,禁止访问宿主机或其他租户的文件系统。
5. 部署与生命周期管理
支持租户自助部署函数,同时保持平台统一管控:
- 提供租户级CI/CD流水线,代码上传后自动构建镜像并部署到对应环境。
- 版本管理支持灰度发布,允许租户逐步上线新版本。
- 平台统一管理函数元信息(名称、入口、超时等),存储时关联tenant_id。
6. 计费与用量统计
按租户维度收集指标用于结算:
- 记录每个函数的调用次数、执行时间、资源消耗。
- 定时汇总生成账单,支持按量付费或套餐模式。
- 提供租户控制台查看自身用量和成本趋势。









