2019-02-18 09:52:04 -06:00
package instana
import (
"io"
2019-08-03 03:58:23 +02:00
"github.com/containous/traefik/v2/pkg/log"
2019-03-04 16:40:05 +01:00
instana "github.com/instana/go-sensor"
2019-02-18 09:52:04 -06:00
"github.com/opentracing/opentracing-go"
)
// Name sets the name of this tracer
const Name = "instana"
// Config provides configuration settings for a instana tracer
type Config struct {
2019-07-01 11:30:05 +02:00
LocalAgentHost string ` description:"Set instana-agent's host that the reporter will used." json:"localAgentHost,omitempty" toml:"localAgentHost,omitempty" yaml:"localAgentHost,omitempty" `
LocalAgentPort int ` description:"Set instana-agent's port that the reporter will used." json:"localAgentPort,omitempty" toml:"localAgentPort,omitempty" yaml:"localAgentPort,omitempty" `
LogLevel string ` description:"Set instana-agent's log level. ('error','warn','info','debug')" json:"logLevel,omitempty" toml:"logLevel,omitempty" yaml:"logLevel,omitempty" export:"true" `
2019-02-18 09:52:04 -06:00
}
2019-06-17 11:48:05 +02:00
// SetDefaults sets the default values.
func ( c * Config ) SetDefaults ( ) {
c . LocalAgentPort = 42699
c . LogLevel = "info"
}
2019-02-18 09:52:04 -06:00
// Setup sets up the tracer
func ( c * Config ) Setup ( serviceName string ) ( opentracing . Tracer , io . Closer , error ) {
// set default logLevel
logLevel := instana . Info
// check/set logLevel overrides
switch c . LogLevel {
case "error" :
logLevel = instana . Error
case "warn" :
logLevel = instana . Warn
case "debug" :
logLevel = instana . Debug
}
tracer := instana . NewTracerWithOptions ( & instana . Options {
Service : serviceName ,
LogLevel : logLevel ,
AgentPort : c . LocalAgentPort ,
AgentHost : c . LocalAgentHost ,
} )
// Without this, child spans are getting the NOOP tracer
opentracing . SetGlobalTracer ( tracer )
log . WithoutContext ( ) . Debug ( "Instana tracer configured" )
return tracer , nil , nil
}