IIS

Internet Information Services 集成可从 IIS Web 服务器收集遥测数据。这些指标会提供连接信息以及传输的字节数的相关数据。此集成还会从访问日志收集信息。

如需详细了解 IIS,请参阅 Internet Information Services 文档

准备工作

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

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

本文档将以 agent 为前缀的指标称为 v1 指标,将以 workload 为前缀的指标称为 v2 指标。如需查看这些指标的表,请参阅受监控的内容

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

前提条件

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

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

此集成支持 IIS 8.5 和 10.0 版。

为 IIS 配置 Ops Agent

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

配置示例

以下命令会创建相关配置来收集和注入 IIS 的遥测数据,并重启 Ops Agent。

# 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.

Add-Content 'C:\Program Files\Google\Cloud Operations\Ops Agent\config\config.yaml' "
metrics:
  receivers:
    iis_v2:
      type: iis
      receiver_version: 2
  service:
    pipelines:
      iispipeline:
        receivers:
          - iis_v2
logging:
  receivers:
    iis_access:
      type: iis_access
  service:
    pipelines:
      iis:
        receivers:
        - iis_access
"

Stop-Service google-cloud-ops-agent -Force
Start-Service google-cloud-ops-agent* 

此接收器仅支持默认的 W3C 日志记录格式。

配置日志收集

如需从 IIS 注入访问日志,您必须为该日志创建接收器,然后为新接收器创建流水线。

如需为 iis_access 日志配置接收器,请指定以下字段:

字段 默认 说明
exclude_paths [] 要从 include_paths 匹配的集合中排除的文件系统路径模式列表。
include_paths ['C:\inetpub\logs\LogFiles\W3SVC1\u_ex*'] 要通过跟踪每个文件读取的文件系统路径列表。路径中可以使用通配符 (*);例如 C:\inetpub\logs\LogFiles\W3SVC1\u_ex*
type 该值必须为 iis_access
record_log_file_path false 如果设置为 true,则从中获取日志记录的特定文件的路径将作为 agent.googleapis.com/log_file_path 标签的值显示在输出日志条目中。使用通配符时,系统只会记录从中获取记录的文件的路径。
wildcard_refresh_interval 60s include_paths 中通配符文件路径的刷新间隔。指定为 time.ParseDuration 可解析的时间间隔,例如 30 秒或 2 分钟。该属性在高日志记录吞吐量下可能很有用,因为日志文件的轮替速度快于默认时间间隔。

记录的内容

logName 派生自配置中指定的接收器 ID。LogEntry 中的详细字段如下所示。

iis_access 日志包含 LogEntry 中的以下字段:

字段 类型 说明
httpRequest.referer 字符串 Referer 标头的内容
httpRequest.remoteIp 字符串 发出请求的客户端的 IP
httpRequest.requestMethod 字符串 HTTP 方法
httpRequest.requestUrl 字符串 请求网址(通常只是网址的路径部分)
httpRequest.serverIp 字符串 请求的服务器的 IP 地址和端口
httpRequest.status 数字 HTTP 状态代码
httpRequest.userAgent 字符串 User-Agent 标头的内容
jsonPayload.sc_substatus 数字 子状态错误代码
jsonPayload.sc_win32_status 数字 Windows 状态代码
jsonPayload.time_taken 数字 操作所用的时长(以毫秒为单位)
jsonPayload.user 字符串 请求经过身份验证的用户名
timestamp 字符串 (Timestamp) 收到请求的时间

配置 v1 指标收集

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

设置新的 IIS 实例后,IIS 可能不会立即报告任何指标。使用 Windows Server 上安装的服务器管理器控制台,您可能会在“可管理性”列中看到服务器的状态为联机 - 未启动性能计数器

启用 IIS 以生成指标的一种方法是在服务器管理器控制台中右键点击 IIS 服务器,然后选择启动性能计数器。您的服务器应开始向 Ops Agent 发送指标。

配置 v2 指标收集

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

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

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

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

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

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

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

监控的内容

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

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

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

此表中的“指标类型”字符串必须以 agent.googleapis.com/iis/ 为前缀。表中的条目已省略该前缀。

指标类型发布阶段
显示名
种类、类型、单位
受监控的资源
说明
标签
current_connections 正式版
IIS 打开的连接
GAUGEDOUBLE1
aws_ec2_instance、gce_instance
当前 IIS 的打开的连接。每 60 秒采样一次。
network/transferred_bytes_count 正式版
IIS 已传输的字节数
CUMULATIVEINT64By
aws_ec2_instance、gce_instance
IIS 已传输的网络字节数。每 60 秒采样一次。
direction:方向(已发送,已接收)
new_connection_count 正式版
IIS 连接
CUMULATIVEINT641
aws_ec2_instance、gce_instance
对 IIS 打开的连接。每 60 秒采样一次。
request_count 正式版
IIS 请求
CUMULATIVEINT641
aws_ec2_instance、gce_instance
向 IIS 发出的请求。每 60 秒采样一次。
http_method:Http 方法(post、put、get、delete、option、trace、head)

世界协调时间 (UTC) 2022-08-04 12:34:49 生成的表。

V2 指标

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

指标类型
种类、类型
受监控的资源
标签
workload.googleapis.com/iis.request.count
CUMULATIVEINT64
gce_instance
request
workload.googleapis.com/iis.request.rejected
CUMULATIVEINT64
gce_instance
 
workload.googleapis.com/iis.request.queue.count
GAUGEINT64
gce_instance
 
workload.googleapis.com/iis.request.queue.age.max
GAUGEINT64
gce_instance
 
workload.googleapis.com/iis.network.file.count
CUMULATIVEINT64
gce_instance
direction
workload.googleapis.com/iis.network.blocked
CUMULATIVEINT64
gce_instance
 
workload.googleapis.com/iis.network.io
CUMULATIVEINT64
gce_instance
direction
workload.googleapis.com/iis.connection.attempt.count
CUMULATIVEINT64
gce_instance
 
workload.googleapis.com/iis.connection.active
GAUGEINT64
gce_instance
 
workload.googleapis.com/iis.connection.anonymous
CUMULATIVEINT64
gce_instance
 
workload.googleapis.com/iis.thread.active
GAUGEINT64
gce_instance
 
workload.googleapis.com/iis.uptime
GAUGEINT64
gce_instance
 

示例信息中心

如需查看 IIS 指标,您必须配置一个图表或信息中心。Cloud Monitoring 提供了一个用于集成的示例信息中心库,其中包含一些预配置的图表。如需了解如何安装这些信息中心,请参阅安装示例信息中心

验证配置

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

如需验证日志是否已注入,请转到日志浏览器并运行以下查询来查看 IIS 日志:

resource.type="gce_instance"
logName=("projects/PROJECT_ID/logs/iis_access")

如需验证指标是否已注入,请转到 Metrics Explorer 并在 MQL 标签页中运行以下查询之一。

  • 对于 v1 指标:

    fetch gce_instance
    | metric 'agent.googleapis.com/iis/request_count'
    | every 1m
    
  • 对于 v2 指标:

    fetch gce_instance
    | metric 'workload.googleapis.com/iis.request.count'
    | every 1m
    

后续步骤

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