1
0
mirror of https://github.com/open-telemetry/opentelemetry-go.git synced 2024-12-12 10:04:29 +02:00
OpenTelemetry Go API and SDK https://opentelemetry.io/
Go to file
dependabot[bot] cfe2b09c31
Bump google.golang.org/grpc from 1.30.0 to 1.31.0 in /exporters/stdout (#1005)
* Bump google.golang.org/grpc from 1.30.0 to 1.31.0 in /exporters/stdout

Bumps [google.golang.org/grpc](https://github.com/grpc/grpc-go) from 1.30.0 to 1.31.0.
- [Release notes](https://github.com/grpc/grpc-go/releases)
- [Commits](https://github.com/grpc/grpc-go/compare/v1.30.0...v1.31.0)

Signed-off-by: dependabot[bot] <support@github.com>

* Auto-fix go.sum changes in dependent modules

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: dependabot[bot] <dependabot[bot]@users.noreply.github.com>
Co-authored-by: Tyler Yahn <MrAlias@users.noreply.github.com>
2020-08-04 13:33:32 -07:00
.circleci Bump CircleCI instance size (#917) 2020-07-07 10:35:37 -07:00
.github Make the stdout exporter a package (#963) 2020-07-24 20:44:51 -07:00
api Rename api/standard package to semconv (#1016) 2020-08-04 07:51:09 -07:00
bridge/opentracing Rename kv.Infer to kv.Any (#969) (#972) 2020-07-27 09:29:22 -07:00
example Bump google.golang.org/grpc from 1.30.0 to 1.31.0 in /exporters/stdout (#1005) 2020-08-04 13:33:32 -07:00
exporters Bump google.golang.org/grpc from 1.30.0 to 1.31.0 in /exporters/stdout (#1005) 2020-08-04 13:33:32 -07:00
instrumentation Rename api/standard package to semconv (#1016) 2020-08-04 07:51:09 -07:00
internal Unify trace and metric exporter helpers (#944) 2020-07-22 11:57:48 -07:00
sdk Add Noop and InMemory SpanBatcher, help with testing integrations (#994) 2020-07-30 15:48:19 -07:00
semconv Rename api/standard package to semconv (#1016) 2020-08-04 07:51:09 -07:00
tools Bump github.com/golangci/golangci-lint from 1.29.0 to 1.30.0 in /tools (#1021) 2020-08-04 07:59:44 -07:00
.gitignore Import open-telemetry/opentelemetry-proto submodule and generate protobuf bindings locally (#942) 2020-07-16 13:59:14 -07:00
.gitmodules Import open-telemetry/opentelemetry-proto submodule and generate protobuf bindings locally (#942) 2020-07-16 13:59:14 -07:00
.golangci.yml Remove nolint and update misspell to ignore cancelled 2020-05-29 11:11:19 -07:00
CHANGELOG.md Rename api/standard package to semconv (#1016) 2020-08-04 07:51:09 -07:00
CODEOWNERS paivagustavo to emeritus for now (#960) 2020-07-23 11:19:58 -07:00
CONTRIBUTING.md Update Contributing style guide section (#971) 2020-07-28 10:23:47 -07:00
doc.go Alias api/global types, functions to root 2020-05-03 16:01:15 +08:00
get_main_pkgs.sh Update License header for all source files (#586) 2020-03-23 22:41:10 -07:00
go.mod Expose optional ResponseWriter interfaces. (#979) 2020-07-30 10:30:47 -07:00
go.sum Expose optional ResponseWriter interfaces. (#979) 2020-07-30 10:30:47 -07:00
LICENSE Initial commit 2019-05-16 12:05:27 -07:00
Makefile Create protobuf generation GitHub action (#938) 2020-07-16 10:07:59 -07:00
Makefile.proto Create protobuf generation GitHub action (#938) 2020-07-16 10:07:59 -07:00
otel.go rm api/global alias functions 2020-05-07 00:41:11 +08:00
pre_release.sh fix pre_release.sh to update version in sdk/opentelemetry.go (#607) 2020-03-31 12:02:56 -07:00
README.md Remove unnecessary schedule from readme (#997) 2020-07-30 10:36:26 -07:00
RELEASING.md Update release documentation (#993) 2020-07-31 10:08:50 -07:00
tag.sh Backport tag script from contrib repo (#934) 2020-07-13 16:09:59 -04:00
verify_examples.sh Clean up tools (#762) 2020-05-26 11:35:34 -07:00

OpenTelemetry-Go

Circle CI Docs Go Report Card Gitter

The Go OpenTelemetry client.

Installation

This repository includes multiple packages. The api package contains core data types, interfaces and no-op implementations that comprise the OpenTelemetry API following the specification. The sdk package is the reference implementation of the API.

Libraries that produce telemetry data should only depend on api and defer the choice of the SDK to the application developer. Applications may depend on sdk or another package that implements the API.

All packages are published to go.opentelemetry.io/otel and is the preferred location to import from.

Additional resources:

Quick Start

Below is a brief example of importing OpenTelemetry, initializing a tracer and creating some simple spans.

package main

import (
	"context"
	"log"

	"go.opentelemetry.io/otel/api/global"
	"go.opentelemetry.io/otel/exporters/stdout"
	sdktrace "go.opentelemetry.io/otel/sdk/trace"
)

func main() {
	pusher, err := stdout.InstallNewPipeline(nil, nil)
	if err != nil {
		log.Fatal(err)
	}
	defer pusher.Stop()

	tracer := global.Tracer("ex.com/basic")

	tracer.WithSpan(context.Background(), "foo",
		func(ctx context.Context) error {
			tracer.WithSpan(ctx, "bar",
				func(ctx context.Context) error {
					tracer.WithSpan(ctx, "baz",
						func(ctx context.Context) error {
							return nil
						},
					)
					return nil
				},
			)
			return nil
		},
	)
}

See the API documentation for more detail, and the opentelemetry-example-app for a complete example.

Compatible Exporters

See the Go packages depending upon sdk/export/trace and sdk/export/metric for a list of all exporters compatible with OpenTelemetry's Go SDK.

Compatible Libraries

See the opentelemetry-go-contrib repo for packages that facilitates instrumenting other useful Go libraries with opentelemetry-go for distributed tracing and monitoring.

Contributing

See the contributing file.