启用 Tableau Catalog

Tableau Catalog(Link opens in a new window) 发现 Tableau Online 站点或 Tableau Server 上的所有内容(包括工作簿、数据源、工作表和流程)并对其进行索引。索引用于收集有关内容的信息,或收集有关内容的架构和世系的元数据。然后,Catalog 通过元数据确定 Tableau Online 站点或 Tableau Server 上的内容使用的所有数据库、文件和表。

Catalog 随 数据管理加载项 一起提供。有关详细信息,请参见关于数据管理加载项

除了 Catalog 外,还可以分别通过 Tableau 元数据 API(Link opens in a new window) 和 Tableau Server REST API(使用元数据方法(Link opens in a new window))访问有关内容的元数据。

启用 Catalog 之前

作为 Tableau Server 管理员,在启用 Catalog 之前和启用 Catalog 时,您需要考虑一些事项,以确保 Catalog 在 Tableau Server 环境中保持最佳性能。

所需版本

在启用 Catalog 之前,请确保运行以下版本的 Tableau Server 之一

  • Tableau Server 2019.3.4 或更高版本
  • Tableau Server 2019.4.2 或更高版本
  • Tableau Server 2020.1.0 或更高版本
  • Tableau Server 2020.2.4 或更高版本

有关为何需要这些版本的详细信息,请参见 Tableau 知识库

启用 Catalog 预期会发生什么

启用 Catalog 时,将立即为 Tableau Server 上已存在的内容建立索引。

初始摄取

索引过程由两个主要部分组成,其中一个部分称为初始摄取。初始摄取部分可以分为两个其他部分:

  • 内容回填
  • 世系回填

稍后,在监视进度并验证 Catalog 是否已成功启用并在 Tableau Server 环境中运行时,务必要注意内容回填和世系回填的状态。

初始摄取速度

Catalog 为内容首次建立索引所需的时间取决于几个因素:

  • Tableau Server 上的内容量:内容量由发布到 Tableau Server 的工作簿、已发布数据源和流程总数来衡量。有关详细信息,请参见用于存储元数据的磁盘空间

  • 非交互式微服务容器的数量:Catalog 使用非交互式微服务容器为 Tableau Server 上的所有内容建立索引。有关详细信息,请参见用于非交互式微服务容器的内存

了解影响初始摄取的因素可以帮助您衡量在环境中启用和运行 Catalog 可能需要多长时间。

用于存储元数据的磁盘空间

在初始摄取期间,会生成元数据并将其存储在 Tableau Server 存储库(“关系”PostgreSQL 数据库)中。存储元数据所需的磁盘空间量大约是存储库(“工作组”PostgreSQL 数据库)当前使用的磁盘空间的一半。

例如,假设在启用 Catalog 之前存储库使用 50 GB 的磁盘空间,则在启用 Catalog 后存储库可以使用最多 75 GB 的磁盘空间。

用于非交互式微服务容器的内存

初始摄取在非交互式微服务容器内运行。非交互式微服务容器是两个 Tableau Server 微服务容器(Link opens in a new window)进程之一。默认情况下,会向安装了后台程序进程的每个节点中添加其中一个非交互式微服务容器。

默认情况下,非交互式微服务容器的单个实例上的初始摄取在后台程序节点上最多可以使用 4 GB 的内存。如果 Tableau Server 上的内容量超过 10,000,则非交互式微服务容器在后台程序节点上可能需要最多 16 GB 的内存。因此,启用 Catalog 时,请确保每个后台程序节点具有在初始摄取过程中支持每个非交互式微服务容器的可用容量。如果需要增加容量,则必须更新非交互式容器的 JVM 堆大小,以便在后台程序节点上分配最多 16 GB 的内存。有关详细信息,请参见noninteractivecontainer.vmopts

如果您计划添加更多非交互式微服务容器以减少初始摄取时间,请先确定总共需要多少容器(使用下面的步骤 2:估计初始摄取需要多长时间),然后验证 Tableau Server 环境是否配置具有足够的容量来支持所有非交互式微服务容器。根据 Tableau Server 环境的配置方式,可能无法添加减少初始摄取时间所需的所有其他非微服务容器。

启用 Catalog 的最佳做法

由于初始摄取的速度以及要求对于每个 Tableau Server 环境都是唯一的,因此 Tableau 建议在启用 Catalog 时执行以下一项或多项操作:

  • 确保 Tableau Server 存储库可以使用足够的磁盘空间来支持初始摄取将生成和存储的其他元数据。通常,存储库将需要存储库当前使用的额外 50% 的磁盘空间。有关 Tableau Server 磁盘使用情况的详细信息,请参见服务器磁盘空间

  • 根据 Tableau Server 上的内容量,请确保每个后台程序节点在初始摄取期间,对于非交互式微服务容器的每个实例至少具有 4-16 GB 的可用内存。

  • 在周末执行此过程,以便在用户开始使用 Catalog 功能之前完成初始摄取。

  • 首先在具有生产内容的测试环境中执行该过程。这是因为需要摄取的内容类型在摄取速度方面可以发挥重要作用。

启用 Catalog 的步骤摘要

以下步骤总结了在 Tableau Server 上启用和运行 Catalog 的过程。步骤必须按顺序执行。

  1. 确定 Tableau Server 上的内容量
  2. 估计初始摄取需要多长时间
  3. 缩短初始摄取时间
  4. 激活数据管理加载项
  5. 关闭 Catalog 功能
  6. 运行 tsm maintenance metadata-services 命令
  7. 监控初始摄取进度并验证其状态
  8. 配置 SMTP
  9. 打开 Catalog 功能

注意:当 Tableau Server 未获得 数据管理加载项 许可时,这些步骤还可用于启用 Tableau 元数据 API。

启用 Catalog

第 1 步:确定 Tableau Server 上的内容量

若要确定 Tableau Server 上的内容量,请执行以下操作:

  1. 使用管理员凭据登录到 Tableau Server。

  2. 转到“浏览”页面。

  3. 单击“顶层项目”下拉菜单,将“所有工作簿”“所有数据源”“所有流程”旁边的数字加在一起。这就是 Tableau Serve 上的内容总量。

第 2 步:估计初始摄取需要多长时间

若要估计 Catalog 首次(初始摄取)在 Tableau Server 上摄取内容所需的时间,请将您的 Tableau Server 设置与基准 Tableau Server 设置进行比较。

对于具有以下设置的 Tableau Server,初始摄取可能需要大约 6 小时才能完成。

组件 基准值
内容 17,000 个工作簿、已发布数据源和流程
非交互式微服务容器 10 个
摄取消 约 6 小时

如果您有大约一半的内容在 Tableau Server 环境中,则初始摄取可能需要一半的时间才能完成。

例如:8,500 个(工作簿、已发布数据源和流程) + 10 个非交互式微服务容器 = 约 3 小时(初始摄取)

如果您有大约一倍的内容在 Tableau Server 环境中,则初始摄取可能需要一倍的时间才能完成。

例如:34,000 个(工作簿、已发布数据源和流程) + 10 个非交互式微服务容器 = 约 12 小时(初始摄取)

第 3 步:缩短初始摄取时间

通常,Catalog 执行初始摄取所需的时间与非交互式微服务容器数相关。为了帮助缩短初始摄取时间,可以增加非交互式微服务容器的数量。

增加非交互式微服务容器的数量

默认情况下,会向具有后台程序的每个节点中添加一个非交互式微服务容器。为了帮助缩短初始摄取时间,Tableau 建议使用 tsm topology set-process 命令增加非交互式微服务容器的数量。

  1. 在群集中的初始节点(安装了 TSM 的节点)上以管理员身份打开命令提示符。

  2. 运行命令:tsm topology set-process –-count <process_count> --<node_ID> --process <process_name>

    例如,若要将初始节点上的非交互式微服务容器增加到 4 个容器,请运行以下命令:

    tsm topology set-process –-count 4 –-n node1 --process noninteractive

    有关运行命令及其全局选项的详细信息,请参见 tsm topology

重要信息:在增加非交互式微服务容器的数量之前,请查看以下内容: 

  • 增加非交互式微服务容器的建议针对的是非交互式微服务容器的总数,而不是每个节点的非交互式微服务容器总数。例如,假设您有 4 个节点,但希望将非交互式容器的数量增加到 8。在 tsm 命令中使用的 --count 值为 2。

  • 对于添加的每个非交互式微服务容器,将会在节点上占用 4 GB 的额外内存,并且 Tableau Server 存储库(PostreSQL 数据库)的负载会增加。

    • Tableau 建议您逐步增加非交互式微服务容器(一次仅增加不超过 2 个),同时密切监视 Tableau Server 环境,以避免 Tableau Sever 存储库(PostgreSQL 数据库)出现 CPU 利用率问题。

    • 请注意,当添加的非交互式微服务容器过多时,PostgreSQL 数据库的 CPU 利用率可能会激增,并发生故障转移。需要注意的症状包括 vizportal 日志中的 SQLException 错误。有关详细信息,请参见存储库故障转移(Link opens in a new window)主题:

第 4 步:激活 数据管理加载项

(需要 数据管理加载项

如果尚未完成,您可以激活 数据管理加载项。有关详细信息,请参见为数据管理加载项授予许可

步骤 5(可选):为每个站点关闭 Catalog 功能

(需要 数据管理加载项

数据管理加载项 激活过程中,默认情况下 Catalog 功能已打开。由于索引过程和预计完成时间的原因,请考虑为每个站点暂时关闭 Catalog 功能,以便 Tableau Server 用户在准备就绪并能够提供完整准确的结果之前无法访问 Catalog 功能。

  1. 使用管理员凭据登录到 Tableau Server。

  2. 从左侧的导航窗格中,单击“设置”

  3. 在“常规”选项卡上的“Tableau Catalog”下,清除“打开 Tableau Catalog”复选框。

  4. 为 Tableau Server 上的每个站点重复步骤 2-3。

第 6 步:运行 tsm maintenance metadata-services 命令

运行 tsm maintenance metadata-services 命令来启用 Tableau 元数据 API。运行该命令将开始初始摄取。如果您的 Tableau Server 已获得数据管理加载项许可,则运行该命令也会打开 Catalog 功能(如果之前未关闭)。

  1. 在群集中的初始节点(安装了 TSM 的节点)上以管理员身份打开命令提示符。

  2. 运行命令:tsm maintenance metadata-services enable

    有关运行 tsm 命令的详细信息,请参见 tsm maintenance(Link opens in a new window)

注意:运行此命令时,请谨记以下内容:

  • 此命令会停止和启动 Tableau Server 使用的某些服务,从而导致某些功能(例如“建议”功能)暂时不可用。

  • 此时将创建新的元数据索引。在以后的任何时间运行此命令都将创建和替换以前的索引。

第 7 步:监控初始摄取进度并验证其状态

运行上面的 tsm 命令将启动初始摄取过程。为了确保初始摄取过程顺利进行,您可以使用回填 API 监视其进度。有关详细信息,请参见获取初始摄取状态

第 8 步:配置 SMTP 设置

如果还没有为 Tableau Server 进行设置,请配置 SMTP 设置。SMTP 支持向需要就数据更改联系的所有者发送电子邮件。有关配置 SMTP 的详细信息,请参见配置 SMTP 设置(Link opens in a new window)

第 9 步(可选):打开 Catalog 功能

(需要 数据管理加载项

如果在上述过程之一中启用 Catalog 之前关闭了 Catalog 功能,则必须打开 Catalog,以便用户可以访问其功能。

  1. 使用管理员凭据登录到 Tableau Server。

  2. 从左侧的导航窗格中,单击“设置”

  3. 在“常规”选项卡上的“Tableau Catalog”下,清除“打开 Tableau Catalog”复选框。

Catalog 疑难解答

使用 Catalog(或 Tableau 元数据 API)时,您或您的用户可能会遇到以下问题之一。

超时限制和超过节点限制消息

为了确保必须返回大量结果的 Catalog 任务或元数据 API 查询不会占用所有 Tableau Sever 系统资源,Catalog 会同时实施超时和节点限制。

  • 超时限制

    当 Catalog 中的任务或元数据 API 中的查询达到超时限制时,您和您的用户将看到以下消息:

    显示部分结果,超过请求时间限制。请稍后重试。”或 TIME_LIMIT_EXCEEDED

    若要解决此问题,作为 Tableau Server 管理员,您可以使用 tsm configuration set –k metadata.query.limits.time 命令增加超时限制。有关详细信息,请参见 tsm configuration(Link opens in a new window)tsm configuration set 选项(Link opens in a new window)主题。

    重要信息:增加超时限制可以延长使用 CPU 的时间,这可以提高 Tableau Server 上其他进程的性能。

  • 节点限制

    当 Catalog 中的任务或元数据 API 中的查询达到节点限制时,您和您的用户将看到以下消息:

    NODE_LIMIT_EXCEEDED

    若要解决此问题,作为 Tableau Server 管理员,您可以使用 tsm configuration set –k metadata.query.limits.count 命令增加节点限制。有关详细信息,请参见 tsm configuration(Link opens in a new window)tsm configuration set 选项(Link opens in a new window)主题。

    重要信息:增加超时限制可能会影响系统内存。

缺少内容

如果您怀疑在初始摄取后,Catalog 或元数据 API 中缺少内容,可以使用事件 API 来帮助排除故障。事件处理初始摄取后 Tableau Server 上的索引内容。有关详细信息,请参见获取事件状态

禁用 Catalog

作为 Tableau Server 管理员,您可以通过两种方式之一禁用 Catalog。

为每个站点关闭 Catalog 功能

(需要 数据管理加载项

您可以随时关闭 Catalog 功能。关闭 Catalog 功能之后,将无法通过 Tableau Server(或 Tableau 元数据 API)访问 Catalog 的功能,例如添加数据质量警告,或显式管理数据库和表资产权限的功能。但是,Catalog 将继续为发布的内容建立索引,并且可通过 Tableau 元数据 API 和 Tableau Server REST API 中的元数据方法访问元数据。

  1. 使用站点管理员凭据登录到 使用管理员凭据登录到 Tableau Server

  2. 从左侧的导航窗格中,单击“设置”

  3. 在“常规”选项卡上的“Tableau Catalog”下,清除“打开 Tableau Catalog”复选框。

停止为 Tableau Server 上的元数据建立索引

若要停止为 Tableau Server 上的已发布内容建立索引,您可以禁用 Tableau 元数据 API。若要禁用元数据 API,请运行 tsm maintenance metadata-services disable 命令。有关详细信息,请参见 tsm maintenance(Link opens in a new window)

此部分中的其他文章

感谢您的反馈! 提交反馈时出错。请重试,或向我们发送消息