Skip to content

Commit

Permalink
Add .gitattributes & normalize line endings (#1230)
Browse files Browse the repository at this point in the history
Co-authored-by: Armin Ruech <[email protected]>
  • Loading branch information
Oberon00 and arminru authored Nov 26, 2020
1 parent 2aa62df commit d328331
Show file tree
Hide file tree
Showing 4 changed files with 91 additions and 87 deletions.
4 changes: 4 additions & 0 deletions .gitattributes
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
* text=auto eol=lf

*.cmd text eol=crlf
*.bat text eol=crlf
30 changes: 15 additions & 15 deletions docfx.cmd
Original file line number Diff line number Diff line change
@@ -1,15 +1,15 @@
SETLOCAL
SETLOCAL ENABLEEXTENSIONS

docfx.exe build docfx.json > docfx.log
@IF NOT %ERRORLEVEL% == 0 (
type docfx.log
ECHO Error: docfx build failed. 1>&2
EXIT /B %ERRORLEVEL%
)
@type docfx.log
@type docfx.log | findstr /C:"Build succeeded."
@IF NOT %ERRORLEVEL% == 0 (
ECHO Error: you have introduced build warnings. 1>&2
EXIT /B %ERRORLEVEL%
)
SETLOCAL
SETLOCAL ENABLEEXTENSIONS

docfx.exe build docfx.json > docfx.log
@IF NOT %ERRORLEVEL% == 0 (
type docfx.log
ECHO Error: docfx build failed. 1>&2
EXIT /B %ERRORLEVEL%
)
@type docfx.log
@type docfx.log | findstr /C:"Build succeeded."
@IF NOT %ERRORLEVEL% == 0 (
ECHO Error: you have introduced build warnings. 1>&2
EXIT /B %ERRORLEVEL%
)
140 changes: 70 additions & 70 deletions specification/performance-benchmark.md
Original file line number Diff line number Diff line change
@@ -1,70 +1,70 @@
# Performance Benchmark of OpenTelemetry API

This document describes common performance benchmark guidelines on how to
measure and report the performance of OpenTelemetry SDKs.

The goal of this benchmark is to provide a tool to get the basic performance
overhead of the OpenTelemetry SDK for given events throughput on the target
platform.

## Benchmark Configuration

### Span Configuration

- No parent `Span` and `SpanContext`.
- Default Span [Kind](./trace/api.md#spankind) and
[Status](./trace/api.md#set-status).
- Associated to a [resource](overview.md#resources) with attributes
`service.name`, `service.version` and 10 characters string value for each
attribute, and attribute `service.instance.id` with a unique UUID. See
[Service](./resource/semantic_conventions/README.md#service) for details.
- 1 [attribute](./common/common.md#attributes) with a signed 64-bit integer
value.
- 1 [event](./trace/api.md#add-events) without any attributes.
- The `AlwaysOn` sampler should be enabled.
- Each `Span` is created and immediately ended.

### Measurement Configuration

For the languages with bootstrap cost like JIT compilation, a warm-up phase is
recommended to take place before the measurement, which runs under the same
`Span` [configuration](#span-configuration).

## Throughput Measurement

### Create Spans

Number of spans which could be created and exported via OTLP exporter in 1
second per logical core and average number over all logical cores, with each
span containing 10 attributes, and each attribute containing two 20 characters
strings, one as attribute name the other as value.

## Instrumentation Cost

### CPU Usage Measurement

With given number of span throughput specified by user, or 10,000 spans per
second as default if user does not input the number, measure and report the CPU
usage for SDK with both default configured simple and batching span processors
together with OTLP exporter. The benchmark should create an out-of-process OTLP
receiver which listens on the exporting target or adopts existing OTLP exporter
which runs out-of-process, responds with success status immediately and drops
the data. The collector should not add significant CPU overhead to the
measurement. Because the benchmark does not include user processing logic, the
total CPU consumption of benchmark program could be considered as approximation
of SDK's CPU consumption.

The total running time for one test iteration is suggested to be at least 15
seconds. The average and peak CPU usage should be reported.

### Memory Usage Measurement

Measure dynamic memory consumption, e.g. heap, for the same scenario as above
CPU Usage section with 15 seconds duration.

## Report

### Report Format

All the numbers above should be measured multiple times (suggest 10 times at
least) and reported.
# Performance Benchmark of OpenTelemetry API

This document describes common performance benchmark guidelines on how to
measure and report the performance of OpenTelemetry SDKs.

The goal of this benchmark is to provide a tool to get the basic performance
overhead of the OpenTelemetry SDK for given events throughput on the target
platform.

## Benchmark Configuration

### Span Configuration

- No parent `Span` and `SpanContext`.
- Default Span [Kind](./trace/api.md#spankind) and
[Status](./trace/api.md#set-status).
- Associated to a [resource](overview.md#resources) with attributes
`service.name`, `service.version` and 10 characters string value for each
attribute, and attribute `service.instance.id` with a unique UUID. See
[Service](./resource/semantic_conventions/README.md#service) for details.
- 1 [attribute](./common/common.md#attributes) with a signed 64-bit integer
value.
- 1 [event](./trace/api.md#add-events) without any attributes.
- The `AlwaysOn` sampler should be enabled.
- Each `Span` is created and immediately ended.

### Measurement Configuration

For the languages with bootstrap cost like JIT compilation, a warm-up phase is
recommended to take place before the measurement, which runs under the same
`Span` [configuration](#span-configuration).

## Throughput Measurement

### Create Spans

Number of spans which could be created and exported via OTLP exporter in 1
second per logical core and average number over all logical cores, with each
span containing 10 attributes, and each attribute containing two 20 characters
strings, one as attribute name the other as value.

## Instrumentation Cost

### CPU Usage Measurement

With given number of span throughput specified by user, or 10,000 spans per
second as default if user does not input the number, measure and report the CPU
usage for SDK with both default configured simple and batching span processors
together with OTLP exporter. The benchmark should create an out-of-process OTLP
receiver which listens on the exporting target or adopts existing OTLP exporter
which runs out-of-process, responds with success status immediately and drops
the data. The collector should not add significant CPU overhead to the
measurement. Because the benchmark does not include user processing logic, the
total CPU consumption of benchmark program could be considered as approximation
of SDK's CPU consumption.

The total running time for one test iteration is suggested to be at least 15
seconds. The average and peak CPU usage should be reported.

### Memory Usage Measurement

Measure dynamic memory consumption, e.g. heap, for the same scenario as above
CPU Usage section with 15 seconds duration.

## Report

### Report Format

All the numbers above should be measured multiple times (suggest 10 times at
least) and reported.
4 changes: 2 additions & 2 deletions toc.yml
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
- name: OpenTelemetry Specification
href: ./README.md
- name: OpenTelemetry Specification
href: ./README.md

0 comments on commit d328331

Please sign in to comment.