Angular 集成
编辑Angular 集成
编辑本文档介绍如何在 Angular 应用程序中使用真实用户监控 JavaScript 代理。
支持的版本
编辑此集成支持 Angular 版本 ≥ 12.0
安装 Elastic APM Angular 包
编辑将 @elastic/apm-rum-angular
包作为依赖项安装到您的应用程序中
npm install @elastic/apm-rum-angular --save
如果您使用的是 Angular 版本 < 12.0,请使用 @elastic/apm-rum-angular 2.x 来检测您的应用程序。
如果您使用的是 Angular 版本 < 9.0,请使用 @elastic/apm-rum-angular 1.x 来检测您的应用程序。详细信息可在 先前版本 中找到。
检测您的 Angular 应用程序
编辑Angular 集成包公开了 ApmModule
和 ApmService
,它们使用 Angular 的依赖注入模式,并在服务初始化后开始订阅 Angular 路由事件。
ApmService
必须从应用程序模块或应用程序组件初始化,因为 RUM 代理必须尽快开始捕获所有资源和 API 调用。
import { NgModule } from '@angular/core' import { BrowserModule } from '@angular/platform-browser' import { Routes, RouterModule } from '@angular/router' import { ApmModule, ApmService } from '@elastic/apm-rum-angular' const routes: Routes = [ { path: 'contact', component: ContactListComponent }, { path: 'contact/:id', component: ContactDetailComponent } ] @NgModule({ imports: [ApmModule, BrowserModule, RouterModule.forRoot(routes)], declarations: [AppComponent, ContactListComponent, ContactDetailComponent], providers: [ApmService], bootstrap: [AppComponent] }) export class AppModule { constructor(service: ApmService) { // Agent API is exposed through this apm instance const apm = service.init({ serviceName: 'angular-app', serverUrl: 'https://127.0.0.1:8200' }) apm.setUserContext({ 'username': 'foo', 'id': 'bar' }) } }
服务初始化后,页面加载和单页应用程序导航事件都将被捕获为事务,其中路由的 path
作为其名称,page-load
或 route-change
作为类型。
捕获 Angular 应用程序中的错误
编辑默认情况下,当 Angular 应用程序内部抛出错误时,默认错误处理程序会将错误消息打印到控制台,而不会将其重新抛出为浏览器事件。
ApmErrorHandler
提供了集中式错误处理,该处理程序捕获并将错误报告到 APM UI
中显示,并将其记录到浏览器控制台。
import { ErrorHandler } from '@angular/core' import { ApmErrorHandler } from '@elastic/apm-rum-angular' @NgModule({ providers: [ { provide: ErrorHandler, useClass: ApmErrorHandler } ] }) class AppModule {}