2020-03-25 14:47:17 -07:00
|
|
|
// Copyright The OpenTelemetry Authors
|
2020-03-06 22:01:02 -08:00
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
package otlp
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"google.golang.org/grpc"
|
|
|
|
"google.golang.org/grpc/credentials"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
2020-04-02 22:34:57 +05:30
|
|
|
DefaultCollectorPort uint16 = 55680
|
2020-03-06 22:01:02 -08:00
|
|
|
DefaultCollectorHost string = "localhost"
|
2020-03-13 11:42:20 -07:00
|
|
|
DefaultNumWorkers uint = 1
|
2020-05-21 09:45:24 -07:00
|
|
|
|
|
|
|
// For more info on gRPC service configs:
|
|
|
|
// https://github.com/grpc/proposal/blob/master/A6-client-retries.md
|
|
|
|
//
|
|
|
|
// For more info on the RetryableStatusCodes we allow here:
|
|
|
|
// https://github.com/open-telemetry/oteps/blob/be2a3fcbaa417ebbf5845cd485d34fdf0ab4a2a4/text/0035-opentelemetry-protocol.md#export-response
|
2020-05-29 10:17:57 -07:00
|
|
|
//
|
|
|
|
// Note: MaxAttempts > 5 are treated as 5. See
|
|
|
|
// https://github.com/grpc/proposal/blob/master/A6-client-retries.md#validation-of-retrypolicy
|
|
|
|
// for more details.
|
2020-05-21 09:45:24 -07:00
|
|
|
DefaultGRPCServiceConfig = `{
|
2020-05-29 10:17:57 -07:00
|
|
|
"methodConfig":[{
|
|
|
|
"name":[
|
|
|
|
{ "service":"opentelemetry.proto.collector.metrics.v1.MetricsService" },
|
|
|
|
{ "service":"opentelemetry.proto.collector.trace.v1.TraceService" }
|
|
|
|
],
|
|
|
|
"retryPolicy":{
|
|
|
|
"MaxAttempts":5,
|
|
|
|
"InitialBackoff":"0.3s",
|
|
|
|
"MaxBackoff":"5s",
|
|
|
|
"BackoffMultiplier":2,
|
|
|
|
"RetryableStatusCodes":[
|
|
|
|
"UNAVAILABLE",
|
|
|
|
"CANCELLED",
|
|
|
|
"DEADLINE_EXCEEDED",
|
|
|
|
"RESOURCE_EXHAUSTED",
|
|
|
|
"ABORTED",
|
|
|
|
"OUT_OF_RANGE",
|
|
|
|
"UNAVAILABLE",
|
|
|
|
"DATA_LOSS"
|
|
|
|
]
|
|
|
|
}
|
|
|
|
}]
|
2020-05-21 09:45:24 -07:00
|
|
|
}`
|
2020-03-06 22:01:02 -08:00
|
|
|
)
|
|
|
|
|
|
|
|
type ExporterOption func(*Config)
|
|
|
|
|
|
|
|
type Config struct {
|
|
|
|
canDialInsecure bool
|
|
|
|
collectorAddr string
|
|
|
|
compressor string
|
|
|
|
reconnectionPeriod time.Duration
|
2020-05-21 09:45:24 -07:00
|
|
|
grpcServiceConfig string
|
2020-03-06 22:01:02 -08:00
|
|
|
grpcDialOptions []grpc.DialOption
|
|
|
|
headers map[string]string
|
|
|
|
clientCredentials credentials.TransportCredentials
|
2020-03-13 11:42:20 -07:00
|
|
|
numWorkers uint
|
|
|
|
}
|
|
|
|
|
|
|
|
// WorkerCount sets the number of Goroutines to use when processing telemetry.
|
|
|
|
func WorkerCount(n uint) ExporterOption {
|
|
|
|
if n == 0 {
|
|
|
|
n = DefaultNumWorkers
|
|
|
|
}
|
|
|
|
return func(cfg *Config) {
|
|
|
|
cfg.numWorkers = n
|
|
|
|
}
|
2020-03-06 22:01:02 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
// WithInsecure disables client transport security for the exporter's gRPC connection
|
2020-03-30 12:40:38 -07:00
|
|
|
// just like grpc.WithInsecure() https://pkg.go.dev/google.golang.org/grpc#WithInsecure
|
2020-03-06 22:01:02 -08:00
|
|
|
// does. Note, by default, client security is required unless WithInsecure is used.
|
|
|
|
func WithInsecure() ExporterOption {
|
|
|
|
return func(cfg *Config) {
|
|
|
|
cfg.canDialInsecure = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithAddress allows one to set the address that the exporter will
|
|
|
|
// connect to the collector on. If unset, it will instead try to use
|
|
|
|
// connect to DefaultCollectorHost:DefaultCollectorPort.
|
|
|
|
func WithAddress(addr string) ExporterOption {
|
|
|
|
return func(cfg *Config) {
|
|
|
|
cfg.collectorAddr = addr
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithReconnectionPeriod allows one to set the delay between next connection attempt
|
|
|
|
// after failing to connect with the collector.
|
|
|
|
func WithReconnectionPeriod(rp time.Duration) ExporterOption {
|
|
|
|
return func(cfg *Config) {
|
|
|
|
cfg.reconnectionPeriod = rp
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithCompressor will set the compressor for the gRPC client to use when sending requests.
|
|
|
|
// It is the responsibility of the caller to ensure that the compressor set has been registered
|
|
|
|
// with google.golang.org/grpc/encoding. This can be done by encoding.RegisterCompressor. Some
|
|
|
|
// compressors auto-register on import, such as gzip, which can be registered by calling
|
|
|
|
// `import _ "google.golang.org/grpc/encoding/gzip"`
|
|
|
|
func WithCompressor(compressor string) ExporterOption {
|
|
|
|
return func(cfg *Config) {
|
|
|
|
cfg.compressor = compressor
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-06-09 12:30:40 -07:00
|
|
|
// WithHeaders will send the provided headers with gRPC requests
|
2020-03-06 22:01:02 -08:00
|
|
|
func WithHeaders(headers map[string]string) ExporterOption {
|
|
|
|
return func(cfg *Config) {
|
|
|
|
cfg.headers = headers
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithTLSCredentials allows the connection to use TLS credentials
|
|
|
|
// when talking to the server. It takes in grpc.TransportCredentials instead
|
|
|
|
// of say a Certificate file or a tls.Certificate, because the retrieving
|
|
|
|
// these credentials can be done in many ways e.g. plain file, in code tls.Config
|
|
|
|
// or by certificate rotation, so it is up to the caller to decide what to use.
|
|
|
|
func WithTLSCredentials(creds credentials.TransportCredentials) ExporterOption {
|
|
|
|
return func(cfg *Config) {
|
|
|
|
cfg.clientCredentials = creds
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-21 09:45:24 -07:00
|
|
|
// WithGRPCServiceConfig defines the default gRPC service config used.
|
|
|
|
func WithGRPCServiceConfig(serviceConfig string) ExporterOption {
|
|
|
|
return func(cfg *Config) {
|
|
|
|
cfg.grpcServiceConfig = serviceConfig
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-03-06 22:01:02 -08:00
|
|
|
// WithGRPCDialOption opens support to any grpc.DialOption to be used. If it conflicts
|
|
|
|
// with some other configuration the GRPC specified via the collector the ones here will
|
|
|
|
// take preference since they are set last.
|
|
|
|
func WithGRPCDialOption(opts ...grpc.DialOption) ExporterOption {
|
|
|
|
return func(cfg *Config) {
|
|
|
|
cfg.grpcDialOptions = opts
|
|
|
|
}
|
|
|
|
}
|