Typeorm db connection and instrumentation that adds Zipkin tracing to the application.
$ npm install --save zipkin-instrumentation-typeorm
Type: typeorm.SelectQueryBuilder
Allows to build complex sql queries in a fashion way and execute those queries.
Type: zipkin.Tracer
or false
Default: false
Type: string
Default: unknown
Type: string
Default: unknown
Type: number
Default: 0
Type: object
Example: ctx[zipkin.HttpHeaders.TraceId] = new zipkin.TraceId();
This library will wrap grpc client proxy to record traces.
import * as zipkin from 'zipkin';
import {TypeOrmInstrumentation} from '../index';
import {User as UserEntity} from './entity/User';
import {Entity, createConnection} from 'typeorm';
// build entities
const entities = [];
entities.push({UserEntity: UserEntity});
// create zipkin Tracer
const tracer = new zipkin.Tracer({
ctxImpl: new zipkin.ExplicitContext(),
recorder: new zipkin.ConsoleRecorder()
});
async function getUser(): Promise<UserEntity> {
const conn = await createConnection({
type: 'sqlite',
database: './User.db',
entities: entities,
});
const proxyConn = TypeOrmInstrumentation.proxyConnection(conn, {tracer});
return await proxyConn.getRepository(UserEntity)
.createQueryBuilder('user')
.where(`user.id=:id`, {id: '1000'})
.getOne();
}
getUser()
.then(res => console.log(res))
.catch(err => console.log(err));