- APM Node.js Agent: other versions:
- Introduction
- Set up the Agent
- Monitoring AWS Lambda Node.js Functions
- Monitoring Node.js Azure Functions
- Get started with Express
- Get started with Fastify
- Get started with hapi
- Get started with Koa
- Get started with Next.js
- Get started with Restify
- Get started with TypeScript
- Get started with a custom Node.js stack
- Starting the agent
- Supported technologies
- Configuration
- API Reference
- Metrics
- Logs
- OpenTelemetry bridge
- OpenTracing bridge
- Source map support
- ECMAScript module support
- Distributed tracing
- Message queues
- Performance Tuning
- Troubleshooting
- Upgrading
- Release notes
Get started with Koa
editGet started with Koa
editGetting Elastic APM set up for your Koa app is easy, and there are various ways you can tweak it to fit your needs. Follow the guide below to get started, and for more advanced topics, check out the API Reference.
Koa doesn’t have a built-in router, so we can’t support Koa directly since we rely on router information for full support. We currently support the most popular Koa router called koa-router.
If you use another router with your Koa application, please open an issue so we can make sure to support your stack. In the meantime, you can configure Elastic APM to work with any stack.
Installation
editAdd the elastic-apm-node
module as a dependency to your application:
npm install elastic-apm-node --save
Initialization
editIt’s important that the agent is started before you require any other modules in your Node.js application - i.e. before koa
, http
, etc.
This means that you should probably require and start the agent in your application’s main file (usually index.js
, server.js
or app.js
).
Here’s a simple Koa example with the Elastic APM agent installed:
// Add this to the VERY top of the first file loaded in your app const apm = require('elastic-apm-node').start({ // Override service name from package.json // Allowed characters: a-z, A-Z, 0-9, -, _, and space serviceName: '', // Use if APM Server requires a token secretToken: '', // Use if APM Server uses API keys for authentication apiKey: '', // Set custom APM Server URL (default: http://127.0.0.1:8200) serverUrl: '', }) const app = require('koa')() const router = require('koa-router')() router.get('/', function *(next) { this.body = 'Hello World' }) app .use(router.routes()) .use(router.allowedMethods()) app.listen(3000)
The agent will now monitor the performance of your Koa application and record any uncaught exceptions.
Advanced configuration
editIn the above example we initialize the agent by calling the start()
function.
This function takes an optional options object used to configure the agent.
Any option not supplied via the options object can instead be configured using environment variables.
So if you prefer, you can set the same configuration options using environment variables:
ELASTIC_APM_SERVICE_NAME=<service name> ELASTIC_APM_SECRET_TOKEN=<token> ELASTIC_APM_SERVER_URL=<server url>
And then just start the agent like so:
// Start the agent before any thing else in your app var apm = require('elastic-apm-node').start()
See all possible ways to configure the agent in the API documentation.
Full documentation
editPerformance monitoring
editElastic APM automatically measures the performance of your Koa application. It records spans for database queries, external HTTP requests, and other slow operations that happen during requests to your Koa app.
By default, the agent will instrument the most common modules. To instrument other events, you can use custom spans. For information about custom spans, see the Custom Spans section.
Spans are grouped in transactions - by default one for each incoming HTTP request. But it’s possible to create custom transactions not associated with an HTTP request. See the Custom Transactions section for details.
Unknown routes
editWhen viewing the performance metrics of your application in Elastic APM, you might see some transactions named "unknown route". This indicates that the agent detected an incoming HTTP request to your application, but didn’t know which route in your Koa app the HTTP request matched.
This might simply be 404 requests, which by definition don’t match any route, or it might be a symptom that the agent wasn’t installed correctly. If you see this or can’t get any meaningful metrics to show up, please follow the Troubleshooting Guide.
Error logging
editBy default, the Node.js agent will watch for uncaught exceptions and send them to Elastic APM automatically.
But in most cases, errors are not thrown but returned via a callback,
caught by a promise,
or simply manually created.
Those errors will not automatically be sent to Elastic APM.
To manually send an error to Elastic APM,
simply call apm.captureError()
with the error:
var err = new Error('Ups, something broke!') apm.captureError(err)
For advanced logging of errors, including adding extra metadata to the error, see the API documentation.
Filter sensitive information
editBy default, the Node.js agent will filter common sensitive information before sending errors and metrics to the Elastic APM server.
It’s possible for you to tweak these defaults or remove any information you don’t want to send to Elastic APM:
-
By default, the Node.js agent will not log the body of HTTP requests.
To enable this,
use the
captureBody
config option -
By default, the Node.js agent will filter certain HTTP headers known to contain sensitive information.
To disable this,
use the
sanitizeFieldNames
config option - To apply custom filters, use one of the filtering functions
Add your own data
editThe Node.js agent will keep track of the active HTTP request and will link it to errors and recorded transaction metrics when they are sent to the Elastic APM server. This allows you to see details about which request resulted in a particular error or which requests cause a certain HTTP endpoint to be slow.
But in many cases, information about the HTTP request itself isn’t enough. To add even more metadata to errors and transactions, use one of the functions below:
-
apm.setUserContext()
- Call this to enrich collected performance data and errors with information about the user/client -
apm.setCustomContext()
- Call this to enrich collected performance data and errors with any information that you think will help you debug performance issues and errors (this data is only stored, but not indexed in Elasticsearch) -
apm.setLabel()
- Call this to enrich collected performance data and errors with simple key/value strings that you think will help you debug performance issues and errors (labels are indexed in Elasticsearch)
Compatibility
editSee Supported technologies for details.
Troubleshooting
editIf you can’t get the Node.js agent to work as expected, please follow the troubleshooting guide.
On this page
ElasticON events are back!
Learn about the Elastic Search AI Platform from the experts at our live events.
Register now