多环境

启动开发、预演或测试环境的选项。

一旦您开始在生产环境中运行 Metabase,您可能希望在单独的环境中进行测试和开发。对于大多数团队来说,这意味着复制生产环境中的部分(或所有)图表和仪表盘,对这些副本进行更改,然后选择性地将这些更改推送回生产环境。

对于希望一次性对许多 Metabase 项或设置进行编程更改的团队,最好为每个环境设置一个实例。您还可以通过为每个环境创建一个集合来模拟用于仪表盘维护的开发和生产环境。

每个环境一个实例

要为每个环境设置一个实例,您需要一个自托管的专业版或企业版套餐。由于自托管的专业版和企业版套餐按账户计费,您可以根据需要启动任意数量的 Metabase 实例。请记住,您将为所有 Metabase 实例的总用户数付费,因此只添加设置预演或开发实例所需的最少用户数(例如,在一个组中设置单个测试用户来测试权限,而不是添加生产实例中的所有用户)。

要基于您的生产 Metabase 建立新环境,您将使用 Metabase 的序列化功能来导出您的图表、仪表盘和设置。在将其导入新的 Metabase 预演实例之前,您还可以编辑导出的 YAML 文件。例如,您可以创建一组带有品牌设置的仪表盘模板,用于填充任何新环境。

当需要将预演环境中的更改推送回生产环境时,您的团队将使用相同的序列化流程从预演环境导出并导入到生产环境。您还可以设置自己的集成测试,以避免导入任何可能破坏生产实例的内容。

示例:创建自托管预演实例

假设您的 Metabase 生产实例正在 Docker 或类似环境中运行

  1. 备份用于生产实例的应用程序数据库。
  2. 创建一个名为 staging 的新容器。
  3. staging 容器中,启动一个新的 Metabase,并进行以下设置

    • 使用相应的环境变量连接到您的生产应用程序数据库。
    • 使用 MB_PREMIUM_EMBEDDING_TOKEN 添加您的许可证密钥。
    • 包含与您的生产实例匹配的版本标签(例如 metabase/metabase-enterprise:v1.55.2)。
  4. 一旦 Metabase 在 staging 容器中运行,执行序列化导出命令。
  5. 将导出的内容持久化到您想要的任何对象存储中。
  6. 可选:编辑导出的 YAML 文件。例如,您可以运行一个脚本,将 ID = 1 替换为 ID = 2
  7. 重启 staging 容器。
  8. staging 容器中,创建一个新的应用程序数据库。
  9. 使用序列化 [import](/docs/latest/installation-and-operation/serialization 命令启动 Metabase

    • 使用相应的环境变量连接到新的应用程序数据库。
    • 使用 MB_PREMIUM_EMBEDDING_TOKEN 添加您的许可证密钥。
    • 包含与您的生产实例匹配的版本标签(例如 metabase/metabase-enterprise:v1.55.2)。

具体步骤将取决于您的部署。如果您遇到困难,随时可以咨询我们的成功工程师

每个环境一个集合

要在不使用序列化的情况下管理 Metabase 仪表盘的更改,您可以改用集合集合权限历史记录

示例:创建生产和开发集合

以下是为每个集合设置一个“环境”的示例

  1. 创建两个集合,分别命名为 ProdDev
  2. 创建两个,分别命名为 最终用户开发者
  3. 为每个组设置集合权限
    • 开发者可以管理 ProdDev 集合。
    • 最终用户可以查看 Prod 集合。
  4. 可选:为每个组设置数据权限。例如
    • 开发者可以通过查询构建器和原生查询访问 DevProd 集合中使用的表或数据库。
    • 最终用户可以在沙盒中访问 Prod 集合中使用的表或数据库。

开发者组的成员可以在 ProdDev 集合之间复制移动项目,以便进行更改而不会暴露正在进行的工作。人们还可以使用项目的历史记录查看和恢复更改。

延伸阅读

下一篇:序列化:在新 Metabase 实例中预加载仪表盘

如何使用 Metabase 的序列化功能将问题、仪表盘、集合、设置等从一个 Metabase 实例复制到新的 Metabase 实例。

下一篇文章
© . All rights reserved.