From 801df25b9bf7cf91c5cbfff2e9d3edd1b3d8cfb0 Mon Sep 17 00:00:00 2001 From: Daniel Dyla Date: Fri, 24 Jan 2020 10:02:12 -0500 Subject: [PATCH 1/3] fix: unref jaeger socket to prevent process running indefinitely (#715) --- packages/opentelemetry-exporter-jaeger/src/jaeger.ts | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/packages/opentelemetry-exporter-jaeger/src/jaeger.ts b/packages/opentelemetry-exporter-jaeger/src/jaeger.ts index 1b1f50e6b37..4ae500f74eb 100644 --- a/packages/opentelemetry-exporter-jaeger/src/jaeger.ts +++ b/packages/opentelemetry-exporter-jaeger/src/jaeger.ts @@ -14,12 +14,13 @@ * limitations under the License. */ -import { SpanExporter, ReadableSpan } from '@opentelemetry/tracing'; import { ExportResult } from '@opentelemetry/base'; -import * as jaegerTypes from './types'; import { NoopLogger } from '@opentelemetry/core'; +import { ReadableSpan, SpanExporter } from '@opentelemetry/tracing'; import * as types from '@opentelemetry/types'; +import { Socket } from 'dgram'; import { spanToThrift } from './transform'; +import * as jaegerTypes from './types'; /** * Format and sends span information to Jaeger Exporter. @@ -40,6 +41,11 @@ export class JaegerExporter implements SpanExporter { typeof config.flushTimeout === 'number' ? config.flushTimeout : 2000; this._sender = new jaegerTypes.UDPSender(config); + if (this._sender._client instanceof Socket) { + // unref socket to prevent it from keeping the process running + this._sender._client.unref(); + } + this._process = { serviceName: config.serviceName, tags: jaegerTypes.ThriftUtils.getThriftTags(tags), From d3af8c4e0b5cbed8388b87f710989d7d5848eb07 Mon Sep 17 00:00:00 2001 From: Daniel Dyla Date: Fri, 24 Jan 2020 11:56:17 -0500 Subject: [PATCH 2/3] chore: publish docs on all tags (#730) --- .circleci/config.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.circleci/config.yml b/.circleci/config.yml index c9017c895a6..49f2fb39df7 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -242,7 +242,7 @@ workflows: - lint_&_docs filters: tags: - only: /^v\d+\.\d+\.0$/ + only: /^v\d+\.\d+\.\d$/ branches: ignore: /.*/ - node8 From 69947da0c1f563a71906bb75b02991a749dbb07f Mon Sep 17 00:00:00 2001 From: Mayur Kale Date: Fri, 24 Jan 2020 15:06:34 -0800 Subject: [PATCH 3/3] Add benchmark README and latest numbers (#689) * add benchmark README and latest numbers * chore: update readme chore: update readme * chore: update readme chore: update readme * chore: update benchmarks * generate latest benchmark numbers Co-authored-by: Daniel Dyla Co-authored-by: Olivier Albertini --- benchmark/README.md | 67 +++++++++++++++++++++++++++++++++++++++++ benchmark/benchmark.js | 5 ++- benchmark/index.js | 4 +-- benchmark/propagator.js | 4 +-- benchmark/tracer.js | 43 ++++++++++++-------------- 5 files changed, 92 insertions(+), 31 deletions(-) create mode 100644 benchmark/README.md diff --git a/benchmark/README.md b/benchmark/README.md new file mode 100644 index 00000000000..0f1e81a9fa2 --- /dev/null +++ b/benchmark/README.md @@ -0,0 +1,67 @@ +# Benchmarks + +## How to run + +To run your benchmark, just: +```sh +$ npm run bench +``` + +The minimum sample size is set to 10 to perform statistical analysis on benchmark, you can re-configure that in `benchmark.js`. + +> NOTE: If you're interested in writing benchmark for other APIs, please write a benchmark in the `benchmark/index.js` module. Please refer to the `benchmark/tracer.js` or `benchmark/propagator.js` for more comprehensive examples. + +## Results + +### `v0.3.3` release + +``` +Beginning NoopTracerRegistry Benchmark... + 5 tests completed. + + #startSpan x 731,516,636 ops/sec ±2.57% (20 runs sampled) + #startSpan:parent x 744,353,590 ops/sec ±3.03% (20 runs sampled) + #startSpan with attribute x 737,451,332 ops/sec ±3.75% (20 runs sampled) + #startSpan with 30 attributes x 1,658,688 ops/sec ±1.23% (20 runs sampled) + #startSpan with 100 attributes x 535,082 ops/sec ±1.55% (20 runs sampled) + +Beginning BasicTracerRegistry Benchmark... + 5 tests completed. + + #startSpan x 80,633 ops/sec ±3.57% (20 runs sampled) + #startSpan:parent x 56,228 ops/sec ±2.18% (20 runs sampled) + #startSpan with attribute x 86,710 ops/sec ±1.80% (20 runs sampled) + #startSpan with 30 attributes x 36,331 ops/sec ±1.29% (20 runs sampled) + #startSpan with 100 attributes x 3,549 ops/sec ±3.59% (20 runs sampled) + +Beginning BasicTracerRegistry with SimpleSpanProcessor Benchmark... + 5 tests completed. + + #startSpan x 74,539 ops/sec ±4.49% (20 runs sampled) + #startSpan:parent x 48,953 ops/sec ±4.98% (20 runs sampled) + #startSpan with attribute x 79,686 ops/sec ±2.54% (20 runs sampled) + #startSpan with 30 attributes x 26,491 ops/sec ±13.68% (20 runs sampled) + #startSpan with 100 attributes x 2,464 ops/sec ±19.64% (20 runs sampled) + +Beginning BasicTracerRegistry with BatchSpanProcessor Benchmark... + 5 tests completed. + + #startSpan x 74,974 ops/sec ±3.57% (20 runs sampled) + #startSpan:parent x 42,390 ops/sec ±20.68% (20 runs sampled) + #startSpan with attribute x 76,497 ops/sec ±2.93% (20 runs sampled) + #startSpan with 30 attributes x 33,042 ops/sec ±2.03% (20 runs sampled) + #startSpan with 100 attributes x 3,459 ops/sec ±4.56% (20 runs sampled) + + +Beginning B3Format Benchmark... + 2 tests completed. + + #Inject x 5,086,366 ops/sec ±3.18% (100 runs sampled) + #Extract x 4,859,557 ops/sec ±3.80% (100 runs sampled) + +Beginning HttpTraceContext Benchmark... + 2 tests completed. + + #Inject x 13,660,710 ops/sec ±1.84% (100 runs sampled) + #Extract x 1,692,010 ops/sec ±0.83% (100 runs sampled) +``` diff --git a/benchmark/benchmark.js b/benchmark/benchmark.js index cb71c03a873..8bc04a47b5a 100644 --- a/benchmark/benchmark.js +++ b/benchmark/benchmark.js @@ -4,10 +4,9 @@ const Benchmark = require('benchmark'); const benchmarks = require('beautify-benchmark'); Benchmark.options.maxTime = 0; -// @todo : Change it to between 50-100 or keep it random. -Benchmark.options.minSamples = 10; -module.exports = () => { +module.exports = (minSamples) => { + Benchmark.options.minSamples = minSamples; const suite = new Benchmark.Suite(); return suite diff --git a/benchmark/index.js b/benchmark/index.js index ebf5aff932b..745b93b75a6 100644 --- a/benchmark/index.js +++ b/benchmark/index.js @@ -3,5 +3,5 @@ const execSync = require('child_process').execSync; const exec = cmd => execSync(cmd, { stdio: [0, 1, 2] }); -exec('node benchmark/tracer'); -exec('node benchmark/propagator'); +exec('node benchmark/tracer.js'); +exec('node benchmark/propagator.js'); diff --git a/benchmark/propagator.js b/benchmark/propagator.js index f28a78a3026..0c5c137c26d 100644 --- a/benchmark/propagator.js +++ b/benchmark/propagator.js @@ -1,7 +1,7 @@ 'use strict'; const benchmark = require('./benchmark'); -const opentelemetry = require('@opentelemetry/core'); +const opentelemetry = require('../packages/opentelemetry-core'); const setups = [ { @@ -26,7 +26,7 @@ const setups = [ for (const setup of setups) { console.log(`Beginning ${setup.name} Benchmark...`); const propagator = setup.propagator; - const suite = benchmark() + const suite = benchmark(100) .add('#Inject', function () { propagator.inject({ traceId: 'd4cda95b652f4a1592b449d5929fda1b', diff --git a/benchmark/tracer.js b/benchmark/tracer.js index 83700b0171d..a1a6c360cdf 100644 --- a/benchmark/tracer.js +++ b/benchmark/tracer.js @@ -1,28 +1,34 @@ 'use strict'; const benchmark = require('./benchmark'); -const opentelemetry = require('@opentelemetry/core'); -const { BasicTracerRegistry, BatchSpanProcessor, InMemorySpanExporter, SimpleSpanProcessor } = require('@opentelemetry/tracing'); -const { NodeTracerRegistry } = require('@opentelemetry/node'); +const opentelemetry = require('../packages/opentelemetry-core'); +const { BasicTracerRegistry, BatchSpanProcessor, InMemorySpanExporter, SimpleSpanProcessor } = require('../packages/opentelemetry-tracing'); -const exporter = new InMemorySpanExporter(); const logger = new opentelemetry.NoopLogger(); const setups = [ + { + name: 'NoopTracerRegistry', + registry: opentelemetry.getTracerRegistry() + }, { name: 'BasicTracerRegistry', registry: new BasicTracerRegistry({ logger }) }, { - name: 'NodeTracerRegistry', - registry: new NodeTracerRegistry({ logger }) + name: 'BasicTracerRegistry with SimpleSpanProcessor', + registry: getRegistry(new SimpleSpanProcessor(new InMemorySpanExporter())) + }, + { + name: 'BasicTracerRegistry with BatchSpanProcessor', + registry: getRegistry(new BatchSpanProcessor(new InMemorySpanExporter())) } ]; for (const setup of setups) { console.log(`Beginning ${setup.name} Benchmark...`); const tracer = setup.registry.getTracer("benchmark"); - const suite = benchmark() + const suite = benchmark(20) .add('#startSpan', function () { const span = tracer.startSpan('op'); span.end(); @@ -51,25 +57,14 @@ for (const setup of setups) { span.setAttribute('attr-key-' + j, 'attr-value-' + j); } span.end(); - }) - .add('#startSpan with SimpleSpanProcessor', function () { - const simpleSpanProcessor = new SimpleSpanProcessor(exporter); - - registry.addSpanProcessor(simpleSpanProcessor); - const span = tracer.startSpan('op'); - span.end(); - - simpleSpanProcessor.shutdown(); - }) - .add('#startSpan with BatchSpanProcessor', function () { - const batchSpanProcessor = new BatchSpanProcessor(exporter); - - registry.addSpanProcessor(batchSpanProcessor); - const span = tracer.startSpan('op'); - span.end(); - batchSpanProcessor.shutdown(); }); // run async suite.run({ async: false }); } +function getRegistry(processor) { + const registry = new BasicTracerRegistry({ logger }); + registry.addSpanProcessor(processor); + return registry; +} +