Looker 管理员可以启用增强型查询管理员实验性实验室功能来增强查询页面。“实验室”功能提升了查询页面的性能。该页面列出了 500 个分页查询,而不是 50 个。
管理菜单的数据库部分中的查询页面列出了 Looker 提交到数据库的最近 50 次查询。如需了解超前查询,请参阅 Looker 的用量部分。
基本查询信息
列 | 定义 |
---|---|
时间 | 查询的开始时间,以应用时区显示。 |
状态 | 查询的状态,可能包括: |
连接 | 运行此查询的 Looker 连接。 |
用户 | 运行此查询的用户(如果可以确定)。某些查询并非由特定用户执行,例如当 Looker 创建永久性派生表或未知用户访问公开 Look 时。 |
来源 | Looker 中查询的来源,例如“探索”页面或 SQL Runner。如果可能,还会显示指向已保存 Look 的链接、查询 ID 以及模型和探索的名称。某些查询不包含其他信息,例如在 SQL Runner 中运行的查询。 |
运行时 | 运行查询所用的时间。其中包括查询的构建方式、每当查询在队列中花费时间、传送到数据库或从数据库传输的查询,以及数据库的执行情况。 如果查询当前正在运行,运行时会显示查询的运行时长。对于之前运行的查询,运行时还会显示查询完成运行所需的时间。估算结果是基于上次运行查询的时长,并大致显示“大约为 2 秒”。 |
“详细信息”按钮 | 如需了解详情,请参阅本页面中的“详细信息”按钮子部分。 |
“详细信息”按钮
点击任意查询右侧的详细信息按钮便会打开有关该查询的其他信息。查询详情弹出式窗口包括以下内容:
- Info 部分,包含有关查询的详细信息(见下表)。
- SQL 部分,显示针对数据库执行的原始 SQL。上下文评论不会显示在查询详情信息中。为防止注释影响查询缓存,在将 SQL 发送到数据库之前,Looker 会将上下文注释添加到传出的 SQL 命令中。
- Open in SQL Runner 链接,用于在 SQL Runner 中打开查询。
Info(信息)部分包含以下信息:
段 | 定义 |
---|---|
历史记录 ID | 查询的历史记录 ID(如果有)。 |
状态 | 查询的状态,如上文所述。 |
连接 | 运行此查询的 Looker 连接。 |
用户 | 运行此查询的用户(如果可以确定)。某些查询并非由特定用户执行,例如当 Looker 创建永久性派生表或未知用户访问公开 Look 时。 |
来源 | Looker 中查询的来源,例如探索页面或 SQL Runner。如有可能,系统会显示其他信息,例如指向已保存 Look 的链接、查询 ID、模型名称、“探索”名称、所选字段等。 |
开始时间 | 查询的开始时间,以应用时区显示。 |
结束时间 | 查询的完成时间,显示在应用时区中。 |
运行时 | 运行查询所用的时间。 |
查询终止
当您关闭运行查询的浏览器标签页时,Looker 会自动停止仍在运行的查询。Looker 管理员也可以通过查询页面停止正在运行的查询。(拥有 see_queries
权限的用户可以查看查询页面,但只有 Looker 管理员可以停止正在运行的查询。)任何仍在运行的查询会在查询右侧显示 Stop 按钮。点击停止可停止查询。
为使 Looker 终止查询,您的数据库方言必须支持查询终止。以下列表显示了最新版本的 Looker 中支持查询终止的方言:
查询超时和队列
Looker 会终止在队列中等待时间过长的查询。此操作称为“超时”。您的查询可能会在以下情况下出现超时:
连接池超时:为了防止数据库在执行并发查询时负载过重,Looker 会将 Looker 查询队列中的并发查询保持在超额状态,并导致查询在队列中保留的时间过长。默认情况下,每个连接最多允许 75 个并发查询。超出连接上限的其他查询将在 0 秒后超时。要更改这些默认值,请在连接的连接设置页面上配置最大连接数和连接池超时设置。
每用户查询的限制和超时:为防止任何单个用户填充 Looker 查询队列,每个用户的并发查询数上限和相应的队列超时时间。默认情况下,每个用户最多可以运行 15 个并发查询,由于此限制导致查询排队的超时时间为 600 秒。如果您的 Looker 实例由客户托管,您可以通过配置
--per-user-query-limit
和--per-user-query-timeout
启动选项来更改这些默认设置。调度器查询限制和超时:为防止 Looker 调度程序进程过载,Looker 实例最多可以运行 10 个并发计划查询,并且调度器队列中的查询超时为 1200 秒。如果您的 Looker 实例由客户托管,您可以通过配置
--scheduler-query-limit
和--scheduler-query-timeout
启动选项来更改这些默认设置。如果您的 Looker 实例被聚类,则集群的每个节点都使用自己的调度器队列。因此,向集群添加节点会增加允许的并发计划查询总数,而不会增加 Looker 调度程序进程的负担。
渲染程序查询限制和超时:为了防止 Looker 渲染程序进程过载,Looker 实例最多可以同时渲染 2 次基于图片的下载,例如 PDF 和 PNG 格式。如果您的 Looker 实例由客户托管,您可以通过配置
--concurrent-render-jobs
启动选项来更改此默认设置。如果您的 Looker 实例被聚类,则集群的每个节点都使用自己的渲染程序队列。因此,向集群添加节点会增加允许的并发渲染程序作业总数,而不会对 Looker 渲染程序进程产生额外的负担。
网络钩子超时:Looker 会尝试将数据传送到网络钩子的时间不超过 30 分钟。如果 Looker 在 30 分钟内无法与网络钩子目的地通信,查询将会超时。此超时不可配置。
代理超时:客户托管的实例经常使用默认超时时间为 60 秒的代理。我们建议将这一时限延长到 60 分钟。如需了解详情,请参阅在代理服务器或负载均衡器后面运行 Looker 帖子。
数据库超时:大多数数据库都有排队和超时规则,这些规则与 Looker 的队列和超时无关。例如,查询可能已经离开 Looker 队列,但仍可能在您的数据库中排队。如需详细了解如何自定义数据库查询超时,请查看数据库的相关文档。