Microsoft SQL Server

Microsoft SQL Server 集成会从 SQL Server 实例收集事务、连接和其他指标。

如需详细了解 SQL Server,请参阅 SQL Server 文档。

准备工作

Ops Agent 2.15.0 版引入了对使用 workload.googleapis.com/ 前缀的一组新 SQL Server 指标的支持。您必须配置该代理以收集这些指标,如示例配置中所述。

Ops Agent 始终支持一组数量有限的 SQL Server 指标;这些指标使用 agent.googleapis.com/mssql/ 前缀。您无需进行额外配置即可在 Windows 虚拟机上收集这些指标。

本文档将以 agent 为前缀的指标称为 v1 指标,将以 workload 为前缀的指标称为 v2 指标。

  • v1 指标包括事务速率和连接计数信息。
  • v2 指标包括实例级的批处理、锁定、页面和用户连接计数信息,以及数据库级的事务和事务日志信息。

如需查看这些指标的表,请参阅受监控的内容

从 Ops Agent 2.15.0 版开始,您可以将该代理配置为收集 v1 指标和/或 v2 指标。

前提条件

如需收集 SQL Server 遥测数据,您必须安装 Ops Agent

  • 对于指标 v1,请安装 1.0.0 版或更高版本。
  • 对于指标 v2,请安装 2.15.0 版或更高版本。

此集成支持 SQL Server 11.x、12.x、13.x、14.x 和 15.x 版本。

为 SQL Server 配置 Ops Agent

在 Microsoft Windows 虚拟机上使用 Ops Agent 时,该代理会自动收集 SQL Server v1 指标。您无需进行其他配置。

按照配置 Ops Agent 指南,添加从 SQL Server 实例收集遥测数据所需的元素并重启代理

设置新的 SQL Server 实例后,您可能无法立即在 Metrics Explorer 中看到指标显示。仅在有数据库活动要报告后,Ops Agent 才会开始收集 SQL Server 指标。

配置示例

以下命令会创建配置以收集和注入 SQL Server 的遥测数据并重启 Ops Agent。

$ErrorActionPreference = 'Stop'

# This config gets merged with the built-in Ops Agent config, which already
# includes the v1 receiver in the default pipeline.
# Because the v2 receiver here uses a unique ID, it does not overwrite
# the default receiver and so both receivers will be active simultaneously
# during the test.

# Create a back up of the existing file so existing configurations are not lost.
Copy-Item -Path 'C:\Program Files\Google\Cloud Operations\Ops Agent\config\config.yaml' -Destination 'C:\Program Files\Google\Cloud Operations\Ops Agent\config\config.yaml.bak'

# Configure the Ops Agent.
Add-Content 'C:\Program Files\Google\Cloud Operations\Ops Agent\config\config.yaml' "
metrics:
  receivers:
    mssql_v2:
      type: mssql
      receiver_version: 2
  service:
    pipelines:
      mssql_v2:
        receivers:
        - mssql_v2
"

# Stop-Service may fail if the service isn't in a Running state yet.
(Get-Service google-cloud-ops-agent*).WaitForStatus('Running', '00:03:00')
Stop-Service google-cloud-ops-agent -Force
Start-Service google-cloud-ops-agent*

配置 v1 指标收集

Microsoft Windows 虚拟机上的 Ops Agent 会自动收集 SQL Server v1 指标。您无需进行其他配置。 如需了解如何仅收集 v2 指标,请参阅配置 v2 指标收集

设置新的 SQL Server 实例后,SQL Server 可能不会立即报告任何指标。仅在有数据库活动要报告后,Ops Agent 才会开始收集 SQL Server 指标。

配置 v2 指标收集

如需从 SQL Server 注入 v2 指标,您必须为 SQL Server 生成的指标创建接收器,然后为新接收器创建流水线。

此接收器不支持在配置中使用多个实例,例如,监控多个端点。所有这些实例都会写入相同的时序,并且 Cloud Monitoring 无法区分它们。Ops Agent 不支持 SQL Server 命名实例。

如需为 mssql 指标配置接收器,请指定以下字段:

字段 默认 说明
collection_interval 60s time.Duration 值,例如 30s5m
receiver_version 收集的指标的版本;可使用 2 收集 v2 指标。
type 该值必须为 mssql

默认情况下,系统会自动收集 v1 指标。您可以通过额外收集 v2 指标来扩充 v1 指标,也可以替换 v1 指标以仅收集 v2 指标。

  • 如需仅收集 v2 指标,请执行以下操作:

    • 将接收器命名为 mssql
    • type 字段设置为 mssql
    • receiver_version 字段设置为 2
    • default_pipeline 流水线中使用此接收器。此配置会替换 mssql 接收器的内置配置。
  • 如需同时收集 v1 和 v2 指标,请执行以下操作:

    • 将接收者命名为 mssql 以外的其他名称,例如 mssql_v2
    • type 字段设置为 mssql
    • receiver_version 设置为 2
    • 在新流水线中使用此接收器。此配置会添加 v2 接收器,而不是替换内置接收器。示例配置中的脚本会使用此方法。

监控的内容

从 2.15.0 版开始,Ops Agent 可以收集两组不同的指标:

  • v1 指标:agent.googleapis.com/mssql/
  • v2 指标:workload.googleapis.com/
V1 指标

下表提供了 Ops Agent 从 SQL Server 实例收集的 v1 指标列表。

此表中的“指标类型”字符串必须以 agent.googleapis.com/mssql/ 为前缀。表中的条目已省略该前缀。 查询标签时,请使用 metric.labels. 前缀;例如 metric.labels.LABEL="VALUE"

指标类型发布阶段
显示名
种类、类型、单位
受监控的资源
说明
标签
connections/user 正式版
SQL Server 打开的连接
GAUGEDOUBLE1
aws_ec2_instance
gce_instance
SQL Server 的当前打开的连接。每 60 秒采样一次。
transaction_rate 正式版
SQL Server 事务率
GAUGEDOUBLE1/s
aws_ec2_instance
gce_instance
SQL Server 每秒总事务数。每 60 秒采样一次。
write_transaction_rate 正式版
SQL Server 写入事务速率
GAUGEDOUBLE1/s
aws_ec2_instance
gce_instance
SQL Server 每秒写入事务数。每 60 秒采样一次。

世界协调时间 (UTC) 2024-04-17 21:38:09 生成的表。

V2 指标

下表提供了 Ops Agent 从 SQL Server 实例收集的 v2 指标列表。

指标类型
种类、类型
受监控的资源
标签
workload.googleapis.com/sqlserver.batch.request.rate
GAUGEDOUBLE
gce_instance
 
workload.googleapis.com/sqlserver.batch.sql_compilation.rate
GAUGEDOUBLE
gce_instance
 
workload.googleapis.com/sqlserver.batch.sql_recompilation.rate
GAUGEDOUBLE
gce_instance
 
workload.googleapis.com/sqlserver.lock.wait.rate
GAUGEDOUBLE
gce_instance
 
workload.googleapis.com/sqlserver.lock.wait_time.avg
GAUGEDOUBLE
gce_instance
 
workload.googleapis.com/sqlserver.page.buffer_cache.hit_ratio
GAUGEDOUBLE
gce_instance
 
workload.googleapis.com/sqlserver.page.checkpoint.flush.rate
GAUGEDOUBLE
gce_instance
 
workload.googleapis.com/sqlserver.page.lazy_write.rate
GAUGEDOUBLE
gce_instance
 
workload.googleapis.com/sqlserver.page.life_expectancy
GAUGEINT64
gce_instance
 
workload.googleapis.com/sqlserver.page.operation.rate
GAUGEDOUBLE
gce_instance
type
workload.googleapis.com/sqlserver.page.split.rate
GAUGEDOUBLE
gce_instance
 
workload.googleapis.com/sqlserver.transaction.rate
GAUGEDOUBLE
gce_instance
database
workload.googleapis.com/sqlserver.transaction.write.rate
GAUGEDOUBLE
gce_instance
database
workload.googleapis.com/sqlserver.transaction_log.flush.data.rate
GAUGEDOUBLE
gce_instance
database
workload.googleapis.com/sqlserver.transaction_log.flush.rate
GAUGEDOUBLE
gce_instance
database
workload.googleapis.com/sqlserver.transaction_log.flush.wait.rate
GAUGEDOUBLE
gce_instance
database
workload.googleapis.com/sqlserver.transaction_log.growth.count
CUMULATIVEINT64
gce_instance
database
workload.googleapis.com/sqlserver.transaction_log.percent_used
GAUGEINT64
gce_instance
database
workload.googleapis.com/sqlserver.transaction_log.shrink.count
CUMULATIVEINT64
gce_instance
database
workload.googleapis.com/sqlserver.user.connection.count
GAUGEINT64
gce_instance
 

验证配置

本部分介绍如何验证您已正确配置 SQL Server 接收器。Ops Agent 可能需要一两分钟才会开始收集遥测数据。

如需验证 SQL Server 指标是否已发送到 Cloud Monitoring,请执行以下操作:

  1. 在 Google Cloud 控制台的导航面板中,选择 Monitoring,然后选择 Metrics Explorer

    进入 Metrics Explorer

  2. 在查询构建器窗格的工具栏中,选择名为  MQL PromQL 的按钮。
  3. 验证已在语言切换开关中选择 MQL。语言切换开关位于同一工具栏中,用于设置查询的格式。
    • 对于 v1 指标,请在编辑器中输入以下查询,然后点击运行查询
      fetch gce_instance
      | metric 'agent.googleapis.com/mssql/connections/user'
      | every 1m
      
    • 对于 v2 指标,请在编辑器中输入以下查询,然后点击运行
      fetch gce_instance
      | metric 'workload.googleapis.com/sqlserver.user.connection.count'
      | every 1m
      

查看信息中心

如需查看 SQL Server 指标,您必须配置一个图表或信息中心。 SQL Server 集成服务可为您提供一个或多个信息中心。在您配置集成并且 Ops Agent 开始收集指标数据后,所有信息中心都会自动安装。

您还可以在不安装集成的情况下查看信息中心的静态预览。

如需查看已安装的信息中心,请执行以下操作:

  1. 在 Google Cloud 控制台的导航面板中,选择 Monitoring,然后选择  信息中心

    前往信息中心

  2. 选择信息中心列表标签页,然后选择集成类别。
  3. 点击您要查看的信息中心的名称。

如果您已配置集成,但尚未安装信息中心,请检查 Ops Agent 是否正在运行。如果信息中心内没有图表的指标数据,则信息中心的安装将失败。Ops Agent 开始收集指标后,系统会为您安装信息中心。

如需查看信息中心的静态预览,请执行以下操作:

  1. 在 Google Cloud 控制台的导航面板中,选择 Monitoring,然后选择  集成

    前往集成

  2. 点击 Compute Engine 部署平台过滤条件。
  3. 找到 SQL Server 的条目,然后点击查看详细信息
  4. 选择信息中心标签页以查看静态预览。如果信息中心已安装,您可以通过点击查看信息中心来转到信息中心。

如需详细了解 Cloud Monitoring 中的信息中心,请参阅信息中心和图表

如需详细了解如何使用集成页面,请参阅管理集成

安装提醒政策

提醒政策会指示 Cloud Monitoring 在满足指定条件时通知您。 SQL Server 集成包含一项或多项提醒政策供您使用。您可以从 Monitoring 中的集成页面查看和安装这些提醒政策。

如需查看可用提醒政策的说明并安装它们,请执行以下操作:

  1. 在 Google Cloud 控制台的导航面板中,选择 Monitoring,然后选择  集成

    前往集成

  2. 找到 SQL Server 的条目,然后点击查看详细信息
  3. 选择提醒标签页。此标签页提供可用提醒政策的说明,并提供一个安装政策的界面。
  4. 安装提醒政策。提醒政策需要知道将提醒触发的通知发送到何处,因此它们需要您提供信息才能进行安装。如需安装提醒政策,请执行以下操作:
    1. 从可用提醒政策列表中,选择您要安装的提醒政策。
    2. 配置通知部分中,选择一个或多个通知渠道。您可以选择禁止使用通知渠道,但如果您这样做,则您的提醒政策将以静默方式触发。您可以在 Monitoring 中查看其状态,但不会收到通知。

      如需详细了解通知渠道,请参阅管理通知渠道

    3. 点击创建政策

如需详细了解 Cloud Monitoring 中的提醒政策,请参阅提醒简介

如需详细了解如何使用集成页面,请参阅管理集成

后续步骤

如需查看如何使用 Ansible 安装 Ops Agent、配置第三方应用和安装示例信息中心的演示,请参阅安装 Ops Agent 以排查第三方应用的问题视频。