0.0.1 • Published 9 years ago
koa-relic v0.0.1
koa-newrelic
Fork of koa-newrelic to work with Koa 2.x
Koa middleware to allow Newrelic monitor Koa applications like Express. Supported features:
- Name transactions according to router (Only support
koa-router) - Group and name transactions for static resources according to file extensions
- Traces for Koa middlewares
Installation
npm install koa-newrelicAPI
var newrelic = require('newrelic');
var koaNewrelic = require('koa-newrelic')(newrelic, opts);
var app = require('koa')();
var router = require('koa-router')();
router.get('/', function *(next) {...});
app
.use(koaNewrelic);
.use(router.routes());To record traces of middlewares, please initialize koa-newrelic before adding any middlewares to app or router
Options
middlewareTraceBoolean for if need traces for each middleware. Defaults tofalsegroupStaticResourcesBoolean for if need to group transactions by file extension. Defaults tofalsestaticExtensionsArray of file extensions will be grouped ifgroupStaticResourcesis true. Defaults to['svg','png','jpg','gif','css','js','html']customTransactionNameFunction to customize transaction metrics name bymethodand routepath. Defaults to(method, path) => 'Koajs/' + (path[0] === '/' ? path.slice(1) : path) + '#' + method
Examples
var koaNewrelic = require('koa-newrelic')(newrelic, {
middlewareTrace: true,
groupStaticResources: true,
staticExtensions: ['js', 'css'],
customTransactionName: (method, path) => `Koajs/${path.slice(1)}#${method}`
});
router.get('/index', function* ctrA(next) {...});
router.post('/login', function* ctrB(next) {...});
app.use(koaNewrelic)
.use(serve('/public'));
.use(router.routes());
/*
In Newrelic, you will find following transactions
/index#GET
Middleware serve
Middleware dispatch
Middleware ctrA
/login#POST
Middleware serve
Middleware dispatch
Middleware ctrB
/*.js#GET
Middleware serve
/*.css#GET
Middleware serve
*/Test
npm testKnown Issues
License
Copyright (c) 2016 AfterShip
Licensed under the MIT license.
0.0.1
9 years ago