您可以使用 Ruby 版 Error Reporting 库,从 Ruby 应用向 Error Reporting 发送错误报告。 使用 Ruby 版 Error Reporting 库可针对以下情况创建错误组:
- 包含日志条目的日志存储桶具有客户管理的加密密钥 (CMEK)。
- 日志存储桶满足以下条件之一:
- 日志存储桶存储在日志条目源自的项目中。
- 日志条目被路由到一个项目,然后该项目将这些日志条目存储在自己拥有的日志存储桶中。
 
- 您想报告自定义错误事件。
Error Reporting 已与某些 Google Cloud 服务集成,例如 Cloud Functions、App Engine、Compute Engine 和 Google Kubernetes Engine。Error Reporting 可显示在这些服务上运行的应用记录到 Cloud Logging 中的错误。如需了解详情,请参阅本页面上的在 Google Cloud上运行。
您还可以使用 Logging 将错误数据发送到 Error Reporting。如需了解数据格式设置要求,请参阅设置 Logging 中的错误消息格式。
准备工作
- 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 Error Reporting 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 Error Reporting 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.
- 安装 Ruby 2.2+ 或更高版本。
- 
  将 google-cloud-error_reportinggem 添加到 Gemfile:gem "google-cloud-error_reporting" 
- 
  使用 Bundler 安装 gem: bundle install 
- 确保您的容器要使用的服务账号已被授予 Error Reporting Writer 角色 ( - roles/errorreporting.writer)。- 您可以使用 Compute Engine 默认服务账号或自定义服务账号。 - 如需了解如何授予角色,请参阅管理对项目、文件夹和组织的访问权限。 
- 创建集群,并向该集群授予 - cloud-platform访问权限范围。- 例如,以下创建命令指定了 - cloud-platform访问权限范围和服务账号:- gcloud container clusters create CLUSTER_NAME --service-account SERVICE_ACCT_NAME --scopes=cloud-platform 
- 确保虚拟机实例要使用的服务账号已被授予错误报告写入者角色 ( - roles/errorreporting.writer)。- 您可以使用 Compute Engine 默认服务账号或自定义服务账号。 - 如需了解如何授予角色,请参阅管理对项目、文件夹和组织的访问权限。 
- 
在 Google Cloud 控制台中,前往虚拟机实例页面: 如果您使用搜索栏查找此页面,请选择子标题为 Compute Engine 的结果。 
- 选择要接收 - cloud-platform访问权限范围的虚拟机实例。
- 点击停止,然后点击修改。 
- 在身份和 API 访问权限部分,选择具有 Error Reporting Writer 角色 ( - roles/errorreporting.writer) 的服务账号。
- 在访问权限范围部分中,选择授予对所有 Cloud API 的完整访问权限,然后保存更改。 
- 点击启动/恢复。 
安装客户端库
借助 Ruby 版 Error Reporting 库,您可以监控和查看几乎在任何位置运行的 Ruby 应用所报告的错误。
启用库
如果您正在使用 Ruby on Rails,Bundler 会在启动时自动将库加载到您的应用中。
其他基于 Rack 的应用可以使用库提供的 Rack Middleware:
如需详细了解如何安装,请参阅 Ruby 版 Error Reporting 库的文档。您还可以使用问题跟踪器来报告问题。
配置客户端库
您可以自定义 Ruby 版 Error Reporting 库的行为。如需查看可能的配置选项的列表,请参阅库的配置。
在 Google Cloud上运行应用
如需使用 projects.events.report 创建错误组,您的服务账号需要具有Error Reporting Writer 角色 (roles/errorreporting.writer)。
某些 Google Cloud 服务会自动向相应的服务账号授予 Error Reporting Writer 角色 (roles/errorreporting.writer)。不过,对于某些服务,您必须将此角色授予相应的服务账号。
Cloud Run 和 Cloud Run functions
Cloud Run 使用的默认服务账号具有错误报告写入者角色 (roles/errorreporting.writer) 的权限。
您无需明确提供凭据即可使用 Ruby 版 Error Reporting 库。
Cloud Run 已配置为自动使用 Error Reporting。未处理的 JavaScript 异常将在 Logging 中显示,并且会由 Error Reporting 进行处理,而无需使用 Ruby 版 Error Reporting 库。
使用 Ruby on Rails 配置界面
要在 Ruby on Rails 框架中使用 Ruby 版 Error Reporting 库,请通过 Ruby on Rails 配置界面提供如下参数:
您还可以使用以下代码为所有 Stackdriver gem 设置共享配置:
如果 Rails 在生产模式下运行,则 Error Reporting 默认处于启用状态。要在开发模式下启用 Error Reporting,请添加以下代码:
使用 instrumentation 配置界面
如需在其他基于 Rack 的应用中使用 Ruby 版 Error Reporting 库,请通过配置界面提供如下参数:
您还可以使用以下代码,为所有 Google Cloud Observability gem 设置共享配置:
App Engine 柔性环境
App Engine 会自动向您的默认服务账号授予 Error Reporting Writer 角色 (roles/errorreporting.writer)。
您无需明确提供凭据即可使用 Ruby 版 Error Reporting 库。
系统会自动为 App Engine 柔性环境应用启用 Error Reporting。 无需进行额外设置。Google Kubernetes Engine
如需将 Error Reporting 与 Google Kubernetes Engine 搭配使用,请执行以下操作:
Compute Engine
如需将 Error Reporting 与 Compute Engine 虚拟机实例搭配使用,请执行以下操作:
示例
报告基于 Rack 的框架中的错误
通过 Ruby 版 Error Reporting 库,您可以将 Error Reporting 轻松集成到常用的基于 Rack 的 Ruby Web 框架中,例如 Ruby on Rails 和 Sinatra。该库启用后,它会自动报告从应用的 Rack 堆栈捕获的异常。
手动报告错误
您可以调用report 方法来手动报告错误,如以下示例所示:
  
在本地开发环境中运行应用
若要在本地开发环境中使用 Ruby 版 Error Reporting 库(例如在自己的工作站上运行该库),您必须为 Ruby 版 Error Reporting 库提供本地应用默认凭据。如需了解详情,请参阅向 Error Reporting 进行身份验证。
如需在本地开发环境中使用本页面上的 Ruby 示例,请安装并初始化 gcloud CLI,然后使用您的用户凭证设置应用默认凭证。
安装 Google Cloud CLI。
如果您使用的是外部身份提供方 (IdP),则必须先使用联合身份登录 gcloud CLI。
If you're using a local shell, then create local authentication credentials for your user account:
gcloud auth application-default login
You don't need to do this if you're using Cloud Shell.
If an authentication error is returned, and you are using an external identity provider (IdP), confirm that you have signed in to the gcloud CLI with your federated identity.
如需了解详情,请参阅 Set up authentication for a local development environment。 如需了解详情,请参阅身份验证文档中的为本地开发环境设置 ADC。
   
      
        
        projects.events.report 方法也支持 API 密钥。 
   
    如果您要使用 API 密钥进行身份验证,则无需设置本地应用默认凭证文件。
    如需了解详情,请参阅
   
      在 Google Cloud 身份验证文档中创建 API 密钥。 
  
使用 Ruby on Rails 配置界面
要在 Ruby on Rails 框架中使用 Ruby 版 Error Reporting 库,请通过 Ruby on Rails 配置界面提供如下参数:
您还可以使用以下代码为所有 Stackdriver gem 设置共享配置:
如果 Rails 在生产模式下运行,则 Error Reporting 默认处于启用状态。要在开发模式下启用 Error Reporting,请添加以下代码:
使用 instrumentation 配置界面
如需在其他基于 Rack 的应用中使用 Ruby 版 Error Reporting 库,请通过配置界面提供如下参数:
您还可以使用以下代码,为所有 Google Cloud Observability gem 设置共享配置:
查看错误报告
在 Google Cloud 控制台中,前往 Error Reporting 页面:
您也可以使用搜索栏查找此页面。
如需了解详情,请参阅查看错误。