对于 Node.js 应用,系统会为常用的 Winston 和 Bunyan 日志记录库维护插件。Winston 是一个通用库,可实现各种日志格式设置程序和传输。Bunyan 专用于结构化 JSON 日志,支持通过管道传输到 Bunyan 命令行来进行日志格式设置。
您也可以直接使用 Node.js 版 Logging 客户端库,或自行创建与首选日志记录库的集成。例如,您可以使用 Pino 日志框架示例。
无需安装 Logging 代理即可在 Compute Engine 虚拟机 (VM) 实例上使用 Winston 或 Bunyan。
准备工作
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
- 
    
    
      In the Google Cloud console, on the project selector page, select or create a Google Cloud project. Roles required to select or create a project - Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
- 
      Create a project: To create a project, you need the Project Creator
      (roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
 
- 
  
    Verify that billing is enabled for your Google Cloud project. 
- 
  
  
    
      Enable the Cloud Logging API. Roles required to enable APIs To enable APIs, you need the Service Usage Admin IAM role ( roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.
- 
    
    
      In the Google Cloud console, on the project selector page, select or create a Google Cloud project. Roles required to select or create a project - Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
- 
      Create a project: To create a project, you need the Project Creator
      (roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
 
- 
  
    Verify that billing is enabled for your Google Cloud project. 
- 
  
  
    
      Enable the Cloud Logging API. Roles required to enable APIs To enable APIs, you need the Service Usage Admin IAM role ( roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.
- 为 Node.js 开发准备好环境。
- 如需安装 Logging Winston 插件,请使用 npm: - npm install @google-cloud/logging-winston winston 
- 导入插件并将其添加到 Winston 配置: 
- 配置您的插件。 - 您可以使用 Node.js 版 Cloud Logging API Cloud 客户端库支持的相同配置选项来自定义 Winston 插件的行为。这些选项可以在传递到插件构造函数的 - options对象中传递。
- 如需安装 Logging Bunyan 插件,请使用 npm: - npm install bunyan @google-cloud/logging-bunyan 
- 导入插件并将其添加到 Bunyan 配置: 
- 配置您的插件。 - 您可以使用 Node.js 版 Cloud Logging API Cloud 客户端库支持的相同配置选项来自定义 Bunyan 插件的行为。这些选项可以在传递到插件构造函数的 - options对象中传递。
- 如果您将把应用部署到 App Engine 或者您使用的是 App Engine 专用的库,请将资源设置为 GAE 应用。 
- 如果您将在 Compute Engine 上部署应用,请将资源设置为 GCE 虚拟机实例。 
- 如果您要在 Google Kubernetes Engine 上部署应用,则集群的日志记录配置将确定日志条目的资源类型。如需详细了解旧版 Google Cloud Observability 和 Google Cloud Observability Kubernetes Monitoring 解决方案,以及这些选项如何影响资源类型,请参阅迁移至 Google Cloud Observability Kubernetes Monitoring。 
- 如果您的应用直接使用 Cloud Logging API,则资源取决于该 API 和您的配置。例如,在您的应用中,您可以指定资源或使用默认资源。 
- 如果您在 Logs Explorer 中没有看到任何日志,可切换到高级查询模式并使用空查询来查看所有日志条目。 - 如需切换到高级查询模式,请点击 Logs Explorer 顶部的菜单 (▾),然后选择转换为高级过滤条件。
- 清除过滤条件框中显示的内容。
- 点击提交过滤条件。
 - 您可以检查各个条目以找出您的资源。 
配置日志记录
本部分介绍了如何为 Winston 和 Bunyan 日志记录库安装和配置插件。对于 Bunyan,我们提供了有关如何将 Bunyan 与 Node.js Express 应用搭配使用的信息。
您可以使用其他库或框架。例如,您可以使用 Pino 日志框架。如需查看使用 OpenTelemetry 收集指标和跟踪记录数据以及使用 Pino 日志框架收集日志数据的示例代码,请参阅 Node.js 插桩示例。如果您使用 Pino,则必须在 Pino 严重级别与 Cloud Logging 使用的严重级别之间实现映射。如需查看代码示例,请参阅映射 Pino 日志级别。
安装和配置 Winston 插件
Cloud Logging 为 Winston Node.js Logging 库提供了一个插件。适用于 Winston 的 Logging 插件提供了一个更简单的更高层级,用于处理 Logging。
如需安装和配置 Winston 插件,请执行以下操作:
安装和配置 Bunyan 插件
Cloud Logging 为 Bunyan Node.js Logging 库提供了一个插件。适用于 Bunyan 的 Logging 插件提供了一个更简单的更高层级,用于处理 Logging。
如需安装和配置 Bunyan 插件,请执行以下操作:
使用 Bunyan 和 Express
您可以在 Node.js Express 应用中设置和使用 Bunyan 与 Logging。
如需了解安装详情,请参阅 Node.js 版 Cloud Logging 库的文档。您还可以使用问题跟踪器来报告问题。
使用 Cloud Logging 客户端库写入日志
如需了解如何直接使用 Node.js 版 Cloud Logging 客户端库,请参阅 Cloud Logging 客户端库。
在 Google Cloud上运行
如需使应用可使用 Node.js 版 Cloud Logging 库写入日志,底层资源的服务账号必须具有 Logs Writer (roles/logging.logWriter) IAM 角色。大多数 Google Cloud 环境会自动将默认服务账号配置为具有此角色。
App Engine
系统会自动为 App Engine 启用 Cloud Logging,并且应用的默认服务账号默认拥有 IAM 权限以写入日志条目。
如需从应用写入日志条目,我们建议您使用 Bunyan 或 Winston,如本页所述。
如需了解详情,请参阅写入和查看日志。
Google Kubernetes Engine (GKE)
GKE 会自动向默认服务账号授予 Logs Writer (roles/logging.logWriter) IAM 角色。如果您将 Workload Identity Federation for GKE 与此默认服务账号搭配使用,以允许工作负载访问特定Google Cloud API,则无需进行其他配置。不过,如果您将 Workload Identity Federation for GKE 与自定义 IAM 服务账号搭配使用,请确保该自定义服务账号具有 Logs Writer (roles/logging.logWriter) 角色。
如果需要,您还可以在创建集群时使用以下命令添加 logging.write 访问权限范围:
gcloud container clusters create example-cluster-name \
    --scopes https://www.googleapis.com/auth/logging.write
Compute Engine
使用 Compute Engine 虚拟机实例时,请为每个实例添加 cloud-platform 访问权限范围。通过Google Cloud 控制台创建新实例时,您可以在创建实例面板的身份和 API 访问权限部分中执行此操作。请使用 Compute Engine 默认服务账号或您所选的其他服务账号,并在身份和 API 访问权限部分中选择授予对所有 Cloud API 的完整访问权限。无论您选择哪个服务账号,都请确保已在Google Cloud 控制台的 IAM 和管理部分中向该服务账号授予 Logs Writer 角色。
Cloud Run functions
Cloud Run functions 默认授予 Logs Writer 角色。
无需明确提供凭据即可使用 Node.js 版 Cloud Logging 库。
Cloud Run functions 已配置为自动使用 Cloud Logging。
在本地和其他位置运行
如需在 Google Cloud外部使用 Node.js 版 Cloud Logging 库(包括在您自己的工作站、数据中心的计算机或其他云服务提供商的虚拟机实例上运行该库),您必须在本地环境中设置应用默认凭证 (ADC),以向 Node.js 版 Cloud Logging 库进行身份验证。
如需了解详情,请参阅为本地或其他云服务提供商设置 ADC。
使用 Winston:使用 Bunyan:
查看日志
在 Google Cloud 控制台中,转到 Logs Explorer 页面:
如果您使用搜索栏查找此页面,请选择子标题为 Logging 的结果。
在日志浏览器中,您必须指定一个或多个资源,但资源的选择并不那么显而易见。以下是帮助您上手的一些提示:
如需了解更多信息,请参阅使用 Logs Explorer。