Documentation ¶
Index ¶
- Constants
- type DefaultForwarder
- func (f *DefaultForwarder) Start() error
- func (f *DefaultForwarder) State() uint32
- func (f *DefaultForwarder) Stop()
- func (f *DefaultForwarder) SubmitConnectionChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (f *DefaultForwarder) SubmitContainerChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (f *DefaultForwarder) SubmitEvents(payload Payloads, extra http.Header) error
- func (f *DefaultForwarder) SubmitHostMetadata(payload Payloads, extra http.Header) error
- func (f *DefaultForwarder) SubmitMetadata(payload Payloads, extra http.Header) error
- func (f *DefaultForwarder) SubmitPodChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (f *DefaultForwarder) SubmitProcessChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (f *DefaultForwarder) SubmitRTContainerChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (f *DefaultForwarder) SubmitRTProcessChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (f *DefaultForwarder) SubmitSeries(payload Payloads, extra http.Header) error
- func (f *DefaultForwarder) SubmitServiceChecks(payload Payloads, extra http.Header) error
- func (f *DefaultForwarder) SubmitSketchSeries(payload Payloads, extra http.Header) error
- func (f *DefaultForwarder) SubmitV1CheckRuns(payload Payloads, extra http.Header) error
- func (f *DefaultForwarder) SubmitV1Intake(payload Payloads, extra http.Header) error
- func (f *DefaultForwarder) SubmitV1Series(payload Payloads, extra http.Header) error
- type Forwarder
- type HTTPAttemptHandler
- type HTTPCompletionHandler
- type HTTPTransaction
- type MockedForwarder
- func (tf *MockedForwarder) Start() error
- func (tf *MockedForwarder) Stop()
- func (tf *MockedForwarder) SubmitConnectionChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (tf *MockedForwarder) SubmitContainerChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (tf *MockedForwarder) SubmitEvents(payload Payloads, extra http.Header) error
- func (tf *MockedForwarder) SubmitHostMetadata(payload Payloads, extra http.Header) error
- func (tf *MockedForwarder) SubmitMetadata(payload Payloads, extra http.Header) error
- func (tf *MockedForwarder) SubmitPodChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (tf *MockedForwarder) SubmitProcessChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (tf *MockedForwarder) SubmitRTContainerChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (tf *MockedForwarder) SubmitRTProcessChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (tf *MockedForwarder) SubmitSeries(payload Payloads, extra http.Header) error
- func (tf *MockedForwarder) SubmitServiceChecks(payload Payloads, extra http.Header) error
- func (tf *MockedForwarder) SubmitSketchSeries(payload Payloads, extra http.Header) error
- func (tf *MockedForwarder) SubmitV1CheckRuns(payload Payloads, extra http.Header) error
- func (tf *MockedForwarder) SubmitV1Intake(payload Payloads, extra http.Header) error
- func (tf *MockedForwarder) SubmitV1Series(payload Payloads, extra http.Header) error
- type Options
- type Payloads
- type Response
- type Transaction
- type Worker
Constants ¶
const ( // Stopped represent the internal state of an unstarted Forwarder. Stopped uint32 = iota // Started represent the internal state of an started Forwarder. Started )
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type DefaultForwarder ¶
type DefaultForwarder struct { // NumberOfWorkers Number of concurrent HTTP request made by the DefaultForwarder (default 4). NumberOfWorkers int // contains filtered or unexported fields }
DefaultForwarder is the default implementation of the Forwarder.
func NewDefaultForwarder ¶
func NewDefaultForwarder(options *Options) *DefaultForwarder
NewDefaultForwarder returns a new DefaultForwarder.
func (*DefaultForwarder) Start ¶
func (f *DefaultForwarder) Start() error
Start initialize and runs the forwarder.
func (*DefaultForwarder) State ¶
func (f *DefaultForwarder) State() uint32
State returns the internal state of the forwarder (Started or Stopped)
func (*DefaultForwarder) Stop ¶
func (f *DefaultForwarder) Stop()
Stop all the component of a forwarder and free resources
func (*DefaultForwarder) SubmitConnectionChecks ¶
func (f *DefaultForwarder) SubmitConnectionChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitConnectionChecks sends connection checks
func (*DefaultForwarder) SubmitContainerChecks ¶
func (f *DefaultForwarder) SubmitContainerChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitContainerChecks sends container checks
func (*DefaultForwarder) SubmitEvents ¶
func (f *DefaultForwarder) SubmitEvents(payload Payloads, extra http.Header) error
SubmitEvents will send an event type payload to Datadog backend.
func (*DefaultForwarder) SubmitHostMetadata ¶
func (f *DefaultForwarder) SubmitHostMetadata(payload Payloads, extra http.Header) error
SubmitHostMetadata will send a host_metadata tag type payload to Datadog backend.
func (*DefaultForwarder) SubmitMetadata ¶
func (f *DefaultForwarder) SubmitMetadata(payload Payloads, extra http.Header) error
SubmitMetadata will send a metadata type payload to Datadog backend.
func (*DefaultForwarder) SubmitPodChecks ¶
func (f *DefaultForwarder) SubmitPodChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitPodChecks sends pod checks
func (*DefaultForwarder) SubmitProcessChecks ¶
func (f *DefaultForwarder) SubmitProcessChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitProcessChecks sends process checks
func (*DefaultForwarder) SubmitRTContainerChecks ¶
func (f *DefaultForwarder) SubmitRTContainerChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitRTContainerChecks sends real time container checks
func (*DefaultForwarder) SubmitRTProcessChecks ¶
func (f *DefaultForwarder) SubmitRTProcessChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitRTProcessChecks sends real time process checks
func (*DefaultForwarder) SubmitSeries ¶
func (f *DefaultForwarder) SubmitSeries(payload Payloads, extra http.Header) error
SubmitSeries will send a series type payload to Datadog backend.
func (*DefaultForwarder) SubmitServiceChecks ¶
func (f *DefaultForwarder) SubmitServiceChecks(payload Payloads, extra http.Header) error
SubmitServiceChecks will send a service check type payload to Datadog backend.
func (*DefaultForwarder) SubmitSketchSeries ¶
func (f *DefaultForwarder) SubmitSketchSeries(payload Payloads, extra http.Header) error
SubmitSketchSeries will send payloads to Datadog backend - PROTOTYPE FOR PERCENTILE
func (*DefaultForwarder) SubmitV1CheckRuns ¶
func (f *DefaultForwarder) SubmitV1CheckRuns(payload Payloads, extra http.Header) error
SubmitV1CheckRuns will send service checks to v1 endpoint (this will be removed once the backend handles v2 endpoints).
func (*DefaultForwarder) SubmitV1Intake ¶
func (f *DefaultForwarder) SubmitV1Intake(payload Payloads, extra http.Header) error
SubmitV1Intake will send payloads to the universal `/intake/` endpoint used by Agent v.5
func (*DefaultForwarder) SubmitV1Series ¶
func (f *DefaultForwarder) SubmitV1Series(payload Payloads, extra http.Header) error
SubmitV1Series will send timeserie to v1 endpoint (this will be remove once the backend handles v2 endpoints).
type Forwarder ¶
type Forwarder interface { Start() error Stop() SubmitV1Series(payload Payloads, extra http.Header) error SubmitV1Intake(payload Payloads, extra http.Header) error SubmitV1CheckRuns(payload Payloads, extra http.Header) error SubmitSeries(payload Payloads, extra http.Header) error SubmitEvents(payload Payloads, extra http.Header) error SubmitServiceChecks(payload Payloads, extra http.Header) error SubmitSketchSeries(payload Payloads, extra http.Header) error SubmitHostMetadata(payload Payloads, extra http.Header) error SubmitMetadata(payload Payloads, extra http.Header) error SubmitProcessChecks(payload Payloads, extra http.Header) (chan Response, error) SubmitRTProcessChecks(payload Payloads, extra http.Header) (chan Response, error) SubmitContainerChecks(payload Payloads, extra http.Header) (chan Response, error) SubmitRTContainerChecks(payload Payloads, extra http.Header) (chan Response, error) SubmitConnectionChecks(payload Payloads, extra http.Header) (chan Response, error) SubmitPodChecks(payload Payloads, extra http.Header) (chan Response, error) }
Forwarder interface allows packages to send payload to the backend
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 string // Headers are the HTTP headers used by the HTTPTransaction. Headers http.Header // Payload is the content delivered to the backend. Payload *[]byte // ErrorCount is the number of times this HTTPTransaction failed to be processed. ErrorCount int // contains filtered or unexported fields }
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) GetTarget ¶
func (t *HTTPTransaction) GetTarget() string
GetTarget return the url used by the transaction
type MockedForwarder ¶
MockedForwarder a mocked forwarder to be use in other module to test their dependencies with the forwarder
func (*MockedForwarder) Start ¶
func (tf *MockedForwarder) Start() error
Start updates the internal mock struct
func (*MockedForwarder) Stop ¶
func (tf *MockedForwarder) Stop()
Stop updates the internal mock struct
func (*MockedForwarder) SubmitConnectionChecks ¶
func (tf *MockedForwarder) SubmitConnectionChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitConnectionChecks mock
func (*MockedForwarder) SubmitContainerChecks ¶
func (tf *MockedForwarder) SubmitContainerChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitContainerChecks mock
func (*MockedForwarder) SubmitEvents ¶
func (tf *MockedForwarder) SubmitEvents(payload Payloads, extra http.Header) error
SubmitEvents updates the internal mock struct
func (*MockedForwarder) SubmitHostMetadata ¶
func (tf *MockedForwarder) SubmitHostMetadata(payload Payloads, extra http.Header) error
SubmitHostMetadata updates the internal mock struct
func (*MockedForwarder) SubmitMetadata ¶
func (tf *MockedForwarder) SubmitMetadata(payload Payloads, extra http.Header) error
SubmitMetadata updates the internal mock struct
func (*MockedForwarder) SubmitPodChecks ¶
func (tf *MockedForwarder) SubmitPodChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitPodChecks mock
func (*MockedForwarder) SubmitProcessChecks ¶
func (tf *MockedForwarder) SubmitProcessChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitProcessChecks mock
func (*MockedForwarder) SubmitRTContainerChecks ¶
func (tf *MockedForwarder) SubmitRTContainerChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitRTContainerChecks mock
func (*MockedForwarder) SubmitRTProcessChecks ¶
func (tf *MockedForwarder) SubmitRTProcessChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitRTProcessChecks mock
func (*MockedForwarder) SubmitSeries ¶
func (tf *MockedForwarder) SubmitSeries(payload Payloads, extra http.Header) error
SubmitSeries updates the internal mock struct
func (*MockedForwarder) SubmitServiceChecks ¶
func (tf *MockedForwarder) SubmitServiceChecks(payload Payloads, extra http.Header) error
SubmitServiceChecks updates the internal mock struct
func (*MockedForwarder) SubmitSketchSeries ¶
func (tf *MockedForwarder) SubmitSketchSeries(payload Payloads, extra http.Header) error
SubmitSketchSeries updates the internal mock struct
func (*MockedForwarder) SubmitV1CheckRuns ¶
func (tf *MockedForwarder) SubmitV1CheckRuns(payload Payloads, extra http.Header) error
SubmitV1CheckRuns updates the internal mock struct
func (*MockedForwarder) SubmitV1Intake ¶
func (tf *MockedForwarder) SubmitV1Intake(payload Payloads, extra http.Header) error
SubmitV1Intake updates the internal mock struct
func (*MockedForwarder) SubmitV1Series ¶
func (tf *MockedForwarder) SubmitV1Series(payload Payloads, extra http.Header) error
SubmitV1Series updates the internal mock struct
type Options ¶
type Options struct { NumberOfWorkers int RetryQueueSize int EnableHealthChecking bool KeysPerDomain map[string][]string }
Options contain the configuration options for the DefaultForwarder
func NewOptions ¶
NewOptions creates new Options with default values
type Payloads ¶
type Payloads []*[]byte
Payloads is a slice of pointers to byte arrays, an alias for the slices of payloads we pass into the forwarder
type Transaction ¶
type Transaction interface { Process(ctx context.Context, client *http.Client) error GetCreatedAt() time.Time GetTarget() string }
Transaction represents the task to process for a Worker.
type Worker ¶
type Worker struct { // Client the http client used to processed transactions. Client *http.Client // HighPrio is the channel used to receive high priority transaction from the Forwarder. HighPrio <-chan Transaction // LowPrio is the channel used to receive low priority transaction from the Forwarder. LowPrio <-chan Transaction // RequeueChan is the channel used to send failed transaction back to the Forwarder. RequeueChan chan<- Transaction // contains filtered or unexported fields }
Worker comsumes Transaction (aka transactions) from the Forwarder and process them. If the transaction fail to be processed the Worker will send it back to the Forwarder to be retried later.
func NewWorker ¶
func NewWorker(highPrioChan <-chan Transaction, lowPrioChan <-chan Transaction, requeueChan chan<- Transaction, blocked *blockedEndpoints) *Worker
NewWorker returns a new worker to consume Transaction from inputChan and push back erroneous ones into requeueChan.