Documentation ¶
Overview ¶
Package otelsql instruments the database/sql package.
otelsql will trace every interface from database/sql/driver package which has context except driver.Pinger.
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func Register ¶
Register initializes and registers our OTel wrapped database driver identified by its driverName, using provided Option. It is possible to register multiple wrappers for the same database driver if needing different Option for different connections. Parameter dbSystem is an identifier for the database management system (DBMS) product being used.
For more information, see semantic conventions for database https://github.com/open-telemetry/opentelemetry-specification/blob/master/specification/trace/semantic_conventions/database.md
func WrapDriver ¶
WrapDriver takes a SQL driver and wraps it with OTel instrumentation. Parameter dbSystem is an identifier for the database management system (DBMS) product being used.
For more information, see semantic conventions for database https://github.com/open-telemetry/opentelemetry-specification/blob/master/specification/trace/semantic_conventions/database.md
Types ¶
type Event ¶
type Event string
Event specifics events in the database/sql package.
const (
EventRowsNext Event = "sql.rows.next"
)
type Method ¶
type Method string
Method specifics operation in the database/sql package.
const ( MethodConnPing Method = "sql.conn.ping" MethodConnExec Method = "sql.conn.exec" MethodConnQuery Method = "sql.conn.query" MethodConnPrepare Method = "sql.conn.prepare" MethodConnBeginTx Method = "sql.conn.begin_tx" MethodConnResetSession Method = "sql.conn.reset_session" MethodTxCommit Method = "sql.tx.commit" MethodTxRollback Method = "sql.tx.rollback" MethodStmtExec Method = "sql.stmt.exec" MethodStmtQuery Method = "sql.stmt.query" MethodRows Method = "sql.rows" )
type Option ¶
type Option interface {
// Apply sets the Option value of a config.
Apply(*config)
}
Option is the interface that applies a configuration option.
func WithAttributes ¶
WithAttributes specifies attributes that will be set to each span.
func WithSpanNameFormatter ¶
func WithSpanNameFormatter(spanNameFormatter SpanNameFormatter) Option
WithSpanNameFormatter takes an interface that will be called on every operation and the returned string will become the span name.
func WithSpanOptions ¶
func WithSpanOptions(opts SpanOptions) Option
WithSpanOptions specifies configuration for span to decide whether to enable some features.
func WithTracerProvider ¶
func WithTracerProvider(provider trace.TracerProvider) Option
WithTracerProvider specifies a tracer provider to use for creating a tracer. If none is specified, the global provider is used.
type OptionFunc ¶
type OptionFunc func(*config)
OptionFunc implements the Option interface.
func (OptionFunc) Apply ¶
func (f OptionFunc) Apply(c *config)
type SpanNameFormatter ¶
type SpanNameFormatter interface {
Format(ctx context.Context, method Method, query string) string
}
SpanNameFormatter is an interface that used to format span names.
type SpanOptions ¶
type SpanOptions struct { // Ping, if set to true, will enable the creation of spans on Ping requests. Ping bool // RowsNext, if set to true, will enable the creation of events in spans on RowsNext // calls. This can result in many events. RowsNext bool // DisableErrSkip, if set to true, will suppress driver.ErrSkip errors in spans. DisableErrSkip bool // DisableQuery if set to true, will suppress db.statement in spans. DisableQuery bool // RecordError, if set, will be invoked with the current error, and if the func returns true // the record will be recorded on the current span. // // If this is not set it will default to record all errors (possible not ErrSkip, see option // DisableErrSkip). RecordError func(err error) bool // AllowRoot, if set to true, will create root spans in absence of existing spans or even context. AllowRoot bool }
SpanOptions holds configuration of tracing span to decide whether to enable some features. By default all options are set to false intentionally when creating a wrapped driver and provide the most sensible default with both performance and security in mind.