使用 Security Health Analytics

本页面介绍了如何使用 Security Command Center 管理 Security Health Analytics 发现结果。

Security Health Analytics 是 Security Command Center 中的一项内置服务,可扫描云环境中的资源,并针对检测到的任何错误配置发布发现结果。

如需接收 Security Health Analytics 发现结果,必须在 Security Command Center 服务设置中启用该服务。

如需接收其他云平台的发现结果,Security Command Center 必须连接到其他云平台

Security Health Analytics 检测器的发现结果可以在 Google Cloud 控制台中使用 Security Command Center API 进行搜索,如果您使用的是 Security Command Center 的企业级层级,也可以在 Security Operations 控制台中搜索。对于严重级别为 HIGHCRITICAL 的发现结果,Security Command Center 会在 Security Operations 控制台中打开一个案例。

在 Security Command Center 启用大约一小时后开始扫描。在 Google Cloud 上,以两种模式运行:批处理模式,每天自动运行一次;实时模式,针对资产配置更改运行扫描。

Security Command Center 延迟时间概览中列出了不支持实时扫描模式的 Security Health Analytics 检测器。

Security Health Analytics 仅以批处理模式扫描其他云平台。

Security Command Center 的 IAM 角色可以在组织、文件夹或项目级层授予。您能否查看、修改、创建或更新发现结果、资产和安全来源,取决于您获授予的访问权限级别。如需详细了解 Security Command Center 角色,请参阅访问权限控制

启用和停用检测器

停用检测器可能会影响活跃的发现结果的状态。停用检测器后,现有发现结果会自动标记为无效。

在组织级层激活 Security Command Center 时,您可以停用 Security Health Analytics 或特定文件夹或项目的特定检测器。如果为文件夹和项目关闭 Security Health Analytics 或检测器,则与这些资源中的资产关联的任何现有发现结果都会被标记为非活跃。

如需详细了解

默认情况下,Google Cloud 的以下 Security Health Analytics 检测器处于停用状态:

  • BIGQUERY_TABLE_CMEK_DISABLED
  • BUCKET_CMEK_DISABLED
  • CLOUD_ASSET_API_DISABLED
  • DATAPROC_CMEK_DISABLED
  • DATASET_CMEK_DISABLED
  • DISK_CMEK_DISABLED
  • DISK_CSEK_DISABLED
  • NODEPOOL_BOOT_CMEK_DISABLED
  • PUBSUB_CMEK_DISABLED
  • SQL_CMEK_DISABLED
  • SQL_NO_ROOT_PASSWORD
  • SQL_WEAK_ROOT_PASSWORD
  • VPC_FLOW_LOGS_SETTINGS_NOT_RECOMMENDED

如需启用或停用 Security Health Analytics 检测模块,请点击首选方法对应的标签页。

Google Cloud 控制台

您可以在 Google Cloud 控制台的 Security Command Center 设置中,访问 Security Health Analytics 页面的模块标签页,启用或停用检测器。您可以在组织级别或项目级别启用或停用检测器。

gcloud

如需启用检测器(也称为模块),在 Google Cloud CLI 中,请在组织级层或项目级层运行 modules enable gcloud alpha 命令。

如果您在组织级层激活 Security Command Center,请运行以下命令:

gcloud alpha scc settings services modules enable \
  --organization=ORGANIZATION_ID \
  --service=SECURITY_HEALTH_ANALYTICS \
  --module=DETECTOR_NAME

替换以下内容:

  • ORGANIZATION_ID:您的组织 ID。
  • DETECTOR_NAME:您要启用的检测器的名称

如果您在项目级层激活 Security Command Center,请运行以下命令:

gcloud alpha scc settings services modules enable \
  --project=PROJECT_ID \
  --service=SECURITY_HEALTH_ANALYTICS \
  --module=DETECTOR_NAME

替换以下内容:

  • PROJECT_ID:您的项目 ID
  • DETECTOR_NAME:您要启用的检测器的名称

如需停用检测器,请在组织级层或项目级层运行 modules disable 命令。

如果您在组织级层激活 Security Command Center,请运行以下命令:

gcloud alpha scc settings services modules disable \
  --organization=ORGANIZATION_ID \
  --service=SECURITY_HEALTH_ANALYTICS \
  --module=DETECTOR_NAME

替换以下内容:

  • ORGANIZATION_ID:您的组织 ID。
  • DETECTOR_NAME:要停用的检测器的名称

如果您在项目级层激活 Security Command Center,请运行以下命令:

gcloud alpha scc settings services modules disable \
  --project=PROJECT_ID \
  --service=SECURITY_HEALTH_ANALYTICS \
  --module=DETECTOR_NAME

替换以下内容:

  • PROJECT_ID:您的项目 ID
  • DETECTOR_NAME:要停用的检测器的名称

在 Google Cloud 控制台中过滤发现结果

大型组织在其部署过程中可能有很多漏洞发现结果,以进行审核、分类和跟踪。通过使用 Google Cloud 控制台的 Security Command Center 漏洞发现结果页面上提供的过滤条件,您可以重点关注整个组织中严重程度最高的漏洞,并按资产类型、项目等查看漏洞。

如需详细了解如何过滤漏洞发现结果,请参阅在 Security Command Center 中过滤漏洞发现结果

使用案例管理发现结果

Security Command Center 会自动在 Security Operations 控制台中打开一个案例,以查找严重级别为 HIGHCRITICAL 的漏洞和配置错误发现结果。一个案例可能包含多个相关发现结果。

该用例可与首选工单系统集成,通过分配所有者、查看相关信息以及使用手册自动执行响应工作流,从而管理发现结果的调查和补救措施。

如果某个发现结果有对应的案例,您可以在发现结果的详细信息页面上找到其案例的链接。在 Google Cloud 控制台的发现结果页面中,打开发现结果的详细信息页面。您还可以在 Google Cloud 控制台的风险概览页面上查看打开的漏洞案例总数。

如需详细了解支持请求,请参阅支持请求概览

忽略发现的结果

如需在 Google Cloud 控制台中控制发现结果的数量,您可以手动或以编程方式忽略个别发现结果,也可以创建忽略规则,以根据您定义的过滤条件自动忽略当前和未来的发现结果。

您在 Google Cloud 控制台中忽略的发现结果会被隐藏并静音,但会继续记录下来,以便进行审核和满足合规性要求。您可以随时查看已忽略的发现结果或将其取消忽略。如需了解详情,请参阅在 Security Command Center 中忽略发现结果

使用安全标记标记资源和发现结果

您可以使用安全标记在 Security Command Center 中将自定义属性添加到发现结果和资源。安全标记使您能够识别优先级高的感兴趣的地区,如生产项目、使用错误和突发事件跟踪编号标记发现结果等。

对于资产,您只能向 Security Command Center 支持的资产添加安全标记。如需查看支持的资产列表,请参阅 Security Command Center 中支持的资产类型

将资源添加到许可名单

虽然这不是推荐的方法,但您可以通过向资产添加专用安全标记来禁止不需要的发现结果,这样 Security Health Analytics 检测器就不会为这些资产创建安全发现结果。

推荐最有效的控制发现结果数量的方法是忽略发现结果。忽略不需要查看的发现结果,因为这些发现结果针对的是被隔离的资产,或者在可接受的业务参数范围内。

将专用安全标记应用于资产后,系统会将资产添加到 Security Health Analytics 的许可名单中,从而在下一次批量扫描期间将这些资产的所有发现结果标记为已解决。

专用安全标记必须直接应用于资源,而不是发现结果,如本页面稍后部分许可名单的工作原理中所述。如果您将标记应用于发现结果,则底层资源仍然可以生成发现结果。

许可名单的工作原理

每个 Security Health Analytics 检测器都有一个许可名单的专用标记类型,格式为 allow_FINDING_TYPE:true。通过向 Security Command Center 支持的资产添加此专用标记,您可以从检测政策中排除该资产。

例如,如需排除发现结果类型 SSL_NOT_ENFORCED,请在相关 Cloud SQL 实例上设置安全标记 allow_ssl_not_enforced:true。指定的检测器不会为已标记资源创建发现结果。

如需查看发现结果类型的完整列表,请参阅 Security Health Analytics 检测器列表。 如需详细了解安全标记及其使用方法,请参阅使用安全标记

资源类型

本部分介绍如何将安全标记用于不同的资源。

  • 许可名单资源:当您向资源(如 Cloud Storage 存储桶或防火墙)添加专用标记时,系统会在下次批量扫描运行时将发现结果标记为已解决。在移除该标记之前,检测器不会为资源生成新的发现结果或更新现有发现结果。

  • 许可名单项目:向项目资源添加标记时,将解决扫描项目或目标资源本身的发现。但是,项目中包含的资源(例如虚拟机或加密密钥)仍然可以生成发现结果。只有当您在组织级层激活 Security Command Center 高级层级时,此安全标记才可用。

  • 许可名单文件夹:向文件夹资源添加标记时,将解决扫描文件夹或目标资源本身的发现。但是,包含在文件夹内的资源(包括项目)仍然可以生成发现结果。只有当您在组织级层激活 Security Command Center 高级层级时,此安全标记才可用。

  • 支持多个资源的检测器:如果检测器支持多种资源类型,那么您必须为每个资源应用专用标记。例如,检测器 KMS_PUBLIC_KEY 支持两个 Cloud Key Management Service 资源:CryptoKey 和 KeyRing。如果您将 allow_kms_public_key:true 标记应用于 CryptoKey 资源,则该资源的 KMS_PUBLIC_KEY 发现结果将得到解析,但仍会为 KeyRing 资源生成。

安全标记仅在批量扫描期间更新,不支持实时扫描更新。因此,如果移除了某个专用安全标记,而且该资源存在漏洞,且删除该标记并写入发现结果,可能需要最长 24 小时。

特殊案例检测器:客户提供的加密密钥

DISK_CSEK_DISABLED 检测器默认不启用。要使用此检测器,您必须标记要使用自行管理的加密密钥的资源。

如需为特定资源启用 DISK_CSEK_DISABLED 检测器,请将安全标记 enforce_customer_supplied_disk_encryption_keys 应用于值为 true 的资产。

按发现结果类型查看有效的发现结果数量

您可以使用 Google Cloud 控制台或 Google Cloud CLI 命令按发现结果类型查看有效的发现结果数量。

Google Cloud 控制台

借助 Google Cloud 控制台,您可以查看每种发现结果类型的有效发现结果数量。

如要按发现类型查看 Security Health Analytics 发现结果,请执行以下操作:

  1. 转到 Google Cloud 控制台中的 Security Command Center。

    进入 Security Command Center

  2. 要显示 Security Health Analytics 的发现结果,请点击漏洞页面。

  3. 要按每种发现结果类型的有效发现结果数量对发现结果排序,请点击有效列标题。

gcloud CLI 命令

如需使用 gcloud CLI 获取所有有效发现结果的数量,请查询 Security Command Center 以获取 Security Health Analytics 来源 ID。然后使用来源 ID 来查询有效发现结果数量。

第 1 步:获取来源 ID

要完成此步骤,您需要提供您的组织 ID。若要获取您的组织 ID,请运行 gcloud organizations list 并记下组织名称旁边的编号。

若要获取 Security Health Analytics 来源 ID,请运行以下命令之一,具体取决于您在组织级层还是项目级层激活 Security Command Center:

gcloud scc sources describe organizations/ORGANIZATION_ID \
  --source-display-name='Security Health Analytics'

gcloud scc sources describe projects/PROJECT_ID \
  --source-display-name='Security Health Analytics'

如果您尚未启用 Security Command Center API,系统会提示您启用它。启用 Security Command Center API 后,再次运行上一个命令。该命令应显示如下输出:

description: Scans for deviations from a GCP security baseline.
displayName: Security Health Analytics
name: organizations/ORGANIZATION_ID/sources/SOURCE_ID

请记下要在下一步中使用的 SOURCE_ID

第 2 步:获取有效的发现结果数量

使用您在上一步中记下的 SOURCE_ID 以过滤来自 Security Health Analytics 的发现结果。以下 gcloud CLI 命令会按类别返回发现结果数。

如果您在组织级层激活 Security Command Center,请运行以下命令:

gcloud scc findings group organizations/ORGANIZATION_ID/sources/SOURCE_ID \
 --group-by=category --page-size=PAGE_SIZE

如果您在项目级层激活 Security Command Center,请运行以下命令:

gcloud scc findings group projects/PROJECT_ID/sources/SOURCE_ID \
 --group-by=category --page-size=PAGE_SIZE

您可以将页面大小设置为不超过 1000 的任意值。该命令应显示如下所示的输出,其中包含来自特定组织的结果:

groupByResults:
- count: '1'
  properties:
    category: MFA_NOT_ENFORCED
- count: '3'
  properties:
    category: ADMIN_SERVICE_ACCOUNT
- count: '2'
  properties:
    category: API_KEY_APIS_UNRESTRICTED
- count: '1'
  properties:
    category: API_KEY_APPS_UNRESTRICTED
- count: '2'
  properties:
    category: API_KEY_EXISTS
- count: '10'
  properties:
    category: AUDIT_CONFIG_NOT_MONITORED
- count: '10'
  properties:
    category: AUDIT_LOGGING_DISABLED
- count: '1'
  properties:
    category: AUTO_UPGRADE_DISABLED
- count: '10'
  properties:
    category: BUCKET_IAM_NOT_MONITORED
- count: '10'
  properties:
    category: BUCKET_LOGGING_DISABLED
nextPageToken: TOKEN
      readTime: '2019-08-05T21:56:13.862Z'
      totalSize: 50

以编程方式管理发现结果

通过将 Google Cloud CLI 与 Security Command Center SDK 结合使用,您可以自动执行通过 Google Cloud 控制台中的 Security Command Center 可完成的几乎所有操作。您还可以使用 gcloud CLI 修复许多发现结果。如需了解详情,请查看每个发现结果中所述资源类型的文档:

如需以编程方式导出或列出资产,请使用 Cloud Asset Inventory API。如需了解详情,请参阅导出资产历史记录和元数据

Security Command Center API 的资源方法和字段已弃用,将于 2024 年 6 月 26 日当天或之后移除。

移除之前,在 2023 年 6 月 26 日之前激活了 Security Command Center 的用户可以使用 Security Command Center API 的资产方法列出资产,但这些方法仅支持 Security Command Center 支持的资产。

如需了解如何使用已弃用的资产 API 方法,请参阅列出资产

扫描受服务边界保护的项目

此功能仅在组织级层激活 Security Command Center 高级层级时才可用。

如果您的服务边界阻止对某些项目和服务的访问,那么您必须向 Security Command Center 服务账号授予对该服务边界的入站访问权限。否则,Security Health Analytics 将无法生成与受保护项目和服务相关的发现结果。

服务账号的标识符是具有以下格式的电子邮件地址:

service-org-ORGANIZATION_ID@security-center-api.iam.gserviceaccount.com

ORGANIZATION_ID 替换为您的组织的数字标识符。

如需授予服务帐号对服务边界的入站访问权限,请按以下步骤操作。

  1. 转到 VPC Service Controls。

    转到 VPC Service Controls

  2. 在工具栏中,选择您的 Google Cloud 组织。

    项目选择器

  3. 在下拉列表中,选择包含要授予访问权限的服务边界的访问权限政策。

    访问权限政策列表

    与访问权限政策关联的服务边界将显示在列表中。

  4. 点击服务边界的名称。

  5. 点击 修改边界

  6. 在导航菜单中,点击入站流量政策

  7. 点击添加规则

  8. 按如下方式配置规则:

    API 客户端的“来自于”特性

    1. 来源部分,选择所有来源
    2. 身份部分,选择选定的身份
    3. 添加用户/服务账号字段中,点击选择
    4. 输入服务账号电子邮件地址。 如果您同时拥有组织级层和项目级层服务账号,请同时添加这两个服务账号。
    5. 点击保存

    GCP 服务/资源的“至”特性

    1. 对于项目,选择所有项目

    2. 对于服务,请选择所有服务,或选择 Security Health Analytics 所需的下列各项服务:

      • BigQuery API
      • Binary Authorization API
      • Cloud Logging API
      • Cloud Monitoring API
      • Compute Engine API
      • Kubernetes Engine API

    如果服务边界限制对所需服务的访问权限,则 Security Health Analytics 无法为该服务生成发现结果。

  9. 在导航菜单中,点击保存

如需了解详情,请参阅配置入站和出站政策

后续步骤