Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

elastic-apm-node

elastic1.2mBSD-2-Clause4.11.0TypeScript support: included

The official Elastic APM agent for Node.js

opbeat, elastic, elasticapm, elasticsearch, log, logging, bug, bugs, error, errors, exception, exceptions, catch, monitor, monitoring, alert, alerts, performance, apm, ops, devops, stacktrace, trace, tracing, distributedtracing, distributed-tracing

readme

Elastic APM Node.js Agent

This is the official Node.js application performance monitoring (APM) agent for the Elastic Observability solution. It is a Node.js package that runs with your Node.js application to automatically capture errors, tracing data, and performance metrics. APM data is sent to your Elastic Observability deployment -- hosted in Elastic's cloud or in your own on-premises deployment -- where you can monitor your application, create alerts, and quick identify root causes of service issues.

If you have any feedback or questions, please post them on the Discuss forum.

npm tests

Installation

npm install --save elastic-apm-node

Getting started

First, you will need an Elastic Stack deployment. This is a deployment of APM Server (which receives APM data from the APM agent running in your application), Elasticsearch (the database that stores all APM data), and Kibana (the application that provides the interface to visualize and analyze the data). If you do not already have an Elastic deployment to use, follow this APM Quick Start guide to create a free trial on Elastic's cloud. From this deployment you will need the APM serverUrl and secretToken (or a configured apiKey) to use for configuring the APM agent.

Next, the best and easiest way to see how to install and start the APM agent is to follow one of the "Get started" guides for the web framework or technology that you are using:

Typically, the quick start steps are:

  1. Install the APM agent package as a dependency:

     npm install --save elastic-apm-node
  2. Configure and start the APM agent. For the APM agent's automatic instrumentation of popular modules to work, it must be started before your application imports its other dependencies. For example, if you use CommonJS, then put this at the very top of your main application file:

     require('elastic-apm-node').start({
         serverUrl: '<serverUrl from your Elastic Stack deployment>',
         secretToken: '<secretToken from your Elastic Stack deployment>'
         serviceName: '...', // https://www.elastic.co/guide/en/apm/agent/nodejs/current/configuration.html#service-name
         environment: '...', // https://www.elastic.co/guide/en/apm/agent/nodejs/current/configuration.html#environment
     });

There are other ways to start the APM agent: for example, to support starting the APM agent without having to change application code; or to avoid certain surprises when using TypeScript or other transpilers like Babel or esbuild. See Starting the agent for a reference of all ways to start the agent and for details on gotchas with transpilers and bundlers (like Webpack and esbuild).

If your application is using ES modules, please see ECMAScript module support for the current experimental support.

Documentation

The full Node.js APM agent documentation is here. Some important links:

  • Release notes
  • Supported Technologies describes the supported Node.js versions, which modules (and version ranges) are automatically traced, and other technologies.
  • Configuring the agent describes the different ways to configure the APM agent (via options to apm.start(...), environment variables, or other mechanisms).
  • Configuration options is a full configuration reference.
  • Troubleshooting describes some common issues and a way to get debugging output from the APM agent for bug reports.
  • Upgrading includes a guide for upgrading from each past major version of the APM agent.
  • Metrics describes the metrics that the APM agent automatically collects.
  • The APM agent includes an OpenTelemetry Bridge that allows one to use the vendor-agnostic OpenTelemetry API for manual instrumentation in your application, should you require manual instrumentation.

Active release branches

The following git branches are active:

Contributing

Contributions are very welcome. You can get in touch with us through our Discuss forum. If you have found an issue, you can open an issue at https://github.com/elastic/apm-agent-nodejs/issues.

If you are considering contributing code to the APM agent, please read our contribution guide.

Please see TESTING.md for instructions on how to run the test suite.

License

BSD-2-Clause


Made with ♥️ by Elastic and our community.

changelog

elastic-apm-http-client changelog

Note: After v12.0.0 the elastic-apm-http-client package code was included in this repo. This repo was the only intended user of the http-client package.

v12.0.0

  • Breaking change. The hostname configuration option has been renamed to configuredHostname. As well, the hostname detection has changed to prefer using a FQDN, if available. See the spec. (https://github.com/elastic/apm-agent-nodejs/issues/3310)

  • The APM client will send metadata.system.detected_hostname and metadata.system.configured_hostname as appropriate for APM server versions

    =7.4, rather than the now deprecated metadata.system.hostname. See the spec.

v11.4.0

  • Add support for pre-registering of partial transactions for AWS Lambda. This adds client.lambdaShouldRegisterTransactions() and client.lambdaRegisterTransaction(transaction, awsRequestId) so the APM agent can register a partial transaction with the Elastic Lambda extension before executing the user's handler. In some error cases (uncaughtException, unhandledRejection, Lambda timeout), the extension can report that transaction when the APM agent is unable. (https://github.com/elastic/apm-agent-nodejs/issues/3136)

v11.3.1

  • Tweak logic to only exclude metadata.service.agent.activation_method when the APM server version is known to be 8.7.0 -- i.e. optimistically assume it is a version that is fine. The APM server 8.7.0 issue isn't so severe that we want a fast first serverless function invocation to not send the field. (https://github.com/elastic/apm/pull/783)

v11.3.0

  • Ensure metadata.service.agent.activation_method is only sent for APM server version 8.7.1 or later. APM server 8.7.0 included a bug where receiving activation_method is harmful. (https://github.com/elastic/apm-agent-nodejs/issues/3230)

    This change adds the client.supportsActivationMethodField() method.

v11.2.0

v11.1.0

  • Add an extraMetadata config option, which is an object to merge into the built metadata object. This is an alternative to the existing cloudMetadataFetcher and expectExtraMetadata options which provide ways to asynchronously provide metadata. Only one (or zero) of these three options may be used.

v11.0.4

v11.0.3

v11.0.2

Bad release. Upgrade to 11.0.3.

v11.0.1

  • Fix an issue when running in a Lambda function, where a missing or erroring APM Lambda extension could result in apmclient back-off such that (a) the end-of-lambda-invocation signaling (?flushed=true) would not happen and (b) premature "beforeExit" event could result in the Lambda Runtime responding null before the Lambda function could respond (https://github.com/elastic/apm-agent-nodejs/issues/1831).

v11.0.0

  • Add support for coordinating data flushing in an AWS Lambda environment. The following two API additions are used to ensure that (a) the Elastic Lambda extension is signaled at invocation end per spec and (b) a new intake request is not started when a Lambda function invocation is not active.

    • Client#lambdaStart() should be used to indicate when a Lambda function invocation begins.
    • Client#flush([opts,] cb) now supports an optional opts.lambdaEnd boolean. Set it to true to indicate this is a flush at the end of a Lambda function invocation.

    This is a BREAKING CHANGE, because current versions of elastic-apm-node depend on ^10.4.0. If this were released as another 10.x, then usage of current elastic-apm-node with this version of the client would break behavior in a Lambda environment.

  • Add the freeSocketTimeout option, with a default of 4000 (ms), and switch from Node.js's core http.Agent to the agentkeepalive package to fix ECONNRESET issues with HTTP Keep-Alive usage talking to APM Server (https://github.com/elastic/apm-agent-nodejs/issues/2594).

v10.4.0

  • Add APM Server version checking to the client. On creation the client will call the APM Server Information API to get the server version and save that.

    The new Client#supportsKeepingUnsampledTransaction() boolean method returns true if APM Server is a version that requires unsampled transactions to be sent. This will be used by the APM Agent to drop unsampled transactions for newer APM Servers.

    There is a new apmServerVersion: <string> config option to tell the Client to skip fetching the APM Server version and use the given value. This config option is intended mainly for internal test suite usage.

v10.3.0

v10.2.0

  • The client will no longer append data to the configured userAgent string. Before this it would append " elastic-apm-http-client/$ver node/$ver". This is to support the APM agents spec for User-Agent.

v10.1.0

  • Fix client handling of an AWS Lambda environment:
    1. client.flush() will initiate a quicker completion of the current intake request.
    2. The process 'beforeExit' event is not used to start a graceful shutdown of the client, because the Lambda Runtime sometimes uses 'beforeExit' to handle freezing of the Lambda VM instance. That VM instance is typically unfrozen and used again, for which this Client is still needed.

v10.0.0

  • All truncation of string fields (per truncate*At config options) have changed from truncating at a number of unicode chars, rather than a number of bytes. This is both faster and matches the json-schema spec for apm-server intake fields that specify maxLength.
  • BREAKING CHANGE: The truncateQueriesAt config option has been removed.
  • In its place the truncateLongFieldsAt config option has been added to cover span.context.db.statement and a number of other possibly-long fields (per spec). This does mean that in rare cases of long field values longer than the default 10000 chars, this change will result in those values being truncated.
  • The truncateErrorMessagesAt config option has been deprecated, in favor of truncateLongFieldsAt. Note, however, that truncateLongFieldsAt does not support the special case -1 value to disable truncation. If truncateErrorMessagesAt is not specified, the value for truncateLongFieldsAt is used. This means the effective default is now 10000, no longer 2048.

v9.9.0

  • feat: Use uninstrumented HTTP(S) client request functions to avoid tracing requests made by the APM agent itself. (#161)

v9.8.1

  • perf: eliminate encodeObject stack and faster loop in _writeBatch (#159)
  • test: start testing with node 16 (#157)

v9.8.0

v9.7.1

  • Fix to ensure the client.flush(cb) callback is called in the (expected to be rare) case where there are no active handles -- i.e., the process is exiting. (#150)

v9.7.0

  • A number of changes were made to fix issues with the APM agent under heavy load and with a slow or non-responsive APM server. (#144)

    1. A new maxQueueSize config option is added (default 1024 for now) to control how many events (transactions, spans, errors, metricsets) will be queued before being dropped if events are incoming faster than can be sent to APM server. This ensures the APM agent memory usage does not grow unbounded.

    2. JSON encoding of events (when uncorking) is done in limited size batches to control the amount of single chunk CPU eventloop blocking time. (See MAX_WRITE_BATCH_SIZE in Client._writev.) Internal stats are collected to watch for long(est) batch processing times.

    3. The handling of individual requests to the APM Server intake API has be rewritten to handle some error cases -- especially from a non-responsive APM server -- and to ensure that only one intake request is being performed at a time. Two new config options -- intakeResTimeout and intakeResTimeoutOnEnd -- have been added to allow fine control over some parts of this handling. See the comment on makeIntakeRequest for the best overview.

    4. Support for backoff on intake API requests has been implemented per https://github.com/elastic/apm/blob/main/specs/agents/transport.md#transport-errors

  • Started testing against node v15 in preparation for supporting the coming node v16.

v9.6.0

  • Fix config initialization such that the keep-alive agent is used all the time, as intended. Before this change the keep-alive HTTP(S) agent would only be used if a second call to client.config(...) was made. For the Elastic APM Agent's usage of this module, that was when any of the express, fastify, restify, hapi, or koa modules was instrumented. (#139)

    A compatibility note for direct users of this APM http-client: Options passed to the Writable and http[s].Agent constructors no longer include the full options object passed to the Client constructor. Therefore usage of undocumented options can no longer be used.

v9.5.1

  • Fix possible crash when polling apm-server for config. Specifically it could happen with the Elastic Node.js APM agent when:

    1. using node.js v12;
    2. instrumenting one of hapi, restify, koa, express, or fastify; and
    3. on a second request to APM server that fails (non-200 response).

    https://github.com/elastic/apm-agent-nodejs/issues/1749

v9.5.0

(This changelog was started after the 9.5.0 release.)