transaction

package
v0.60.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 18, 2024 License: Apache-2.0 Imports: 16 Imported by: 2

Documentation

Overview

Package transaction defines the transaction of the forwarder

Index

Constants

View Source
const (
	// Series is the transaction type for metrics series
	Series = iota
	// Sketches is the transaction type for distribution sketches
	Sketches
	// ServiceChecks is the transaction type for service checks
	ServiceChecks
	// Events is the transaction type for events
	Events
	// CheckRuns is the transaction type for agent check runs
	CheckRuns
	// Metadata is the transaction type for metadata payloads
	Metadata
	// Process is the transaction type for live-process monitoring payloads
	Process
)
View Source
const (
	// AllRegions indicates the transaction should be sent to all regions (default behavior)
	AllRegions = iota
	// PrimaryOnly indicates the transaction should be sent to the primary region during MRF
	PrimaryOnly
	// SecondaryOnly indicates the transaction should be sent to the secondary region during MRF
	SecondaryOnly
	// LocalOnly indicates the transaction should be sent to the local endpoint (cluster-agent) only
	LocalOnly
)

Variables

View Source
var (
	// ForwarderExpvars is the root for expvars in the forwarder.
	ForwarderExpvars = expvar.NewMap("forwarder")

	// TransactionsExpvars the transactions Expvars
	TransactionsExpvars = expvar.Map{}

	// TransactionsDropped is the number of transaction dropped.
	TransactionsDropped = expvar.Int{}

	// TransactionsDroppedByEndpoint is the number of transaction dropped by endpoint.
	TransactionsDroppedByEndpoint = expvar.Map{}

	// TransactionsSuccessByEndpoint is the number of transaction succeeded by endpoint.
	TransactionsSuccessByEndpoint = expvar.Map{}

	// TlmTxDropped is a telemetry counter that counts the number transaction dropped.
	TlmTxDropped = telemetry.NewCounter("transactions", "dropped",
		[]string{"domain", "endpoint"}, "Transaction drop count")
)

Functions

func GetClientTrace

func GetClientTrace(log log.Component) *httptrace.ClientTrace

GetClientTrace is an httptrace.ClientTrace instance that traces the events within HTTP client requests.

Types

type BytesPayload

type BytesPayload struct {
	Destination Destination
	// contains filtered or unexported fields
}

BytesPayload is a payload stored as bytes. It contains metadata about the payload.

func NewBytesPayload

func NewBytesPayload(payload []byte, pointCount int) *BytesPayload

NewBytesPayload creates a new instance of BytesPayload.

func NewBytesPayloadWithoutMetaData

func NewBytesPayloadWithoutMetaData(payload []byte) *BytesPayload

NewBytesPayloadWithoutMetaData creates a new instance of BytesPayload without metadata.

func (*BytesPayload) GetContent

func (p *BytesPayload) GetContent() []byte

GetContent returns the content of the payload

func (*BytesPayload) GetPointCount

func (p *BytesPayload) GetPointCount() int

GetPointCount returns the number of points in this payload

func (*BytesPayload) Len

func (p *BytesPayload) Len() int

Len returns the length as bytes of the payload

type BytesPayloads

type BytesPayloads []*BytesPayload

BytesPayloads is a collection of BytesPayload

func NewBytesPayloadsWithoutMetaData

func NewBytesPayloadsWithoutMetaData(payloads []*[]byte) BytesPayloads

NewBytesPayloadsWithoutMetaData creates BytesPayloads without metadata.

type Destination added in v0.56.0

type Destination int

Destination indicates which regions the transaction should be sent to

func (Destination) String added in v0.56.0

func (d Destination) String() string

type Endpoint

type Endpoint struct {
	// Route to hit in the HTTP transaction
	Route string
	// Name of the endpoint for the telemetry metrics
	Name string
}

Endpoint is an endpoint

func (Endpoint) String

func (e Endpoint) String() string

String returns the route of the endpoint

type HTTPAttemptHandler

type HTTPAttemptHandler func(transaction *HTTPTransaction)

HTTPAttemptHandler is an event handler that will get called each time this transaction is attempted

type HTTPCompletionHandler

type HTTPCompletionHandler func(transaction *HTTPTransaction, statusCode int, body []byte, err error)

HTTPCompletionHandler is an event handler that will get called after this transaction has completed

type HTTPTransaction

type HTTPTransaction struct {
	// Domain represents the domain target by the HTTPTransaction.
	Domain string
	// Endpoint is the API Endpoint used by the HTTPTransaction.
	Endpoint Endpoint
	// Headers are the HTTP headers used by the HTTPTransaction.
	Headers http.Header
	// Payload is the content delivered to the backend.
	Payload *BytesPayload
	// ErrorCount is the number of times this HTTPTransaction failed to be processed.
	ErrorCount int

	CreatedAt time.Time
	// Retryable indicates whether this transaction can be retried
	Retryable bool

	// StorableOnDisk indicates whether this transaction can be stored on disk
	StorableOnDisk bool

	// AttemptHandler will be called with a transaction before the attempting to send the request
	// This field is not restored when a transaction is deserialized from the disk (the default value is used).
	AttemptHandler HTTPAttemptHandler
	// CompletionHandler will be called with a transaction after it has been successfully sent
	// This field is not restored when a transaction is deserialized from the disk (the default value is used).
	CompletionHandler HTTPCompletionHandler

	Priority Priority

	Kind Kind

	Destination Destination
}

HTTPTransaction represents one Payload for one Endpoint on one Domain.

func NewHTTPTransaction

func NewHTTPTransaction() *HTTPTransaction

NewHTTPTransaction returns a new HTTPTransaction.

func (*HTTPTransaction) GetCreatedAt

func (t *HTTPTransaction) GetCreatedAt() time.Time

GetCreatedAt returns the creation time of the HTTPTransaction.

func (*HTTPTransaction) GetDestination added in v0.56.0

func (t *HTTPTransaction) GetDestination() Destination

GetDestination returns the region(s) this transaction should be sent to.

func (*HTTPTransaction) GetEndpointName

func (t *HTTPTransaction) GetEndpointName() string

GetEndpointName returns the name of the endpoint used by the transaction

func (*HTTPTransaction) GetKind

func (t *HTTPTransaction) GetKind() Kind

GetKind returns the transaction kind

func (*HTTPTransaction) GetPayloadSize

func (t *HTTPTransaction) GetPayloadSize() int

GetPayloadSize returns the size of the payload.

func (*HTTPTransaction) GetPointCount

func (t *HTTPTransaction) GetPointCount() int

GetPointCount gets the number of points in the payload of this transaction.

func (*HTTPTransaction) GetPriority

func (t *HTTPTransaction) GetPriority() Priority

GetPriority returns the priority

func (*HTTPTransaction) GetTarget

func (t *HTTPTransaction) GetTarget() string

GetTarget return the url used by the transaction

func (*HTTPTransaction) Process

func (t *HTTPTransaction) Process(ctx context.Context, config config.Component, log log.Component, client *http.Client) error

Process sends the Payload of the transaction to the right Endpoint and Domain.

func (*HTTPTransaction) SerializeTo

func (t *HTTPTransaction) SerializeTo(log log.Component, serializer TransactionsSerializer) error

SerializeTo serializes the transaction using TransactionsSerializer

func (*HTTPTransaction) SetDefaultHandlers

func (t *HTTPTransaction) SetDefaultHandlers()

SetDefaultHandlers sets the default handlers for AttemptHandler and CompletionHandler

type Kind

type Kind int

Kind defines de kind of transaction (metrics, metadata, process, ...)

type Priority

type Priority int

Priority defines the priority of a transaction Transactions with priority `TransactionPriorityNormal` are dropped from the retry queue before dropping transactions with priority `TransactionPriorityHigh`.

const (
	// TransactionPriorityNormal defines a transaction with a normal priority
	TransactionPriorityNormal Priority = iota

	// TransactionPriorityHigh defines a transaction with an high priority
	TransactionPriorityHigh Priority = iota
)

type SortByCreatedTimeAndPriority

type SortByCreatedTimeAndPriority struct {
	HighPriorityFirst bool
}

SortByCreatedTimeAndPriority sorts transactions by creation time and priority

func (SortByCreatedTimeAndPriority) Sort

func (s SortByCreatedTimeAndPriority) Sort(transactions []Transaction)

Sort sorts transactions by creation time and priority

type Transaction

type Transaction interface {
	Process(ctx context.Context, config config.Component, log log.Component, client *http.Client) error
	GetCreatedAt() time.Time
	GetTarget() string
	GetPriority() Priority
	GetKind() Kind
	GetEndpointName() string
	GetPayloadSize() int
	GetPointCount() int
	GetDestination() Destination

	// This method serializes the transaction to `TransactionsSerializer`.
	// It forces a new implementation of `Transaction` to define how to
	// serialize the transaction to `TransactionsSerializer` as a `Transaction`
	// must be serializable in domainForwarder.
	SerializeTo(log.Component, TransactionsSerializer) error
}

Transaction represents the task to process for a Worker.

type TransactionsSerializer

type TransactionsSerializer interface {
	Add(transaction *HTTPTransaction) error
}

TransactionsSerializer serializes Transaction instances.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL