Documentation ¶
Index ¶
- Constants
- func HasFeature(features, flag Features) bool
- type DefaultForwarder
- func (f *DefaultForwarder) Start() error
- func (f *DefaultForwarder) State() uint32
- func (f *DefaultForwarder) Stop()
- func (f *DefaultForwarder) SubmitAgentChecksMetadata(payload Payloads, extra http.Header) error
- 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) SubmitOrchestratorChecks(payload Payloads, extra http.Header, payloadType int) (chan Response, error)
- func (f *DefaultForwarder) SubmitProcessChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (f *DefaultForwarder) SubmitProcessDiscoveryChecks(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 Features
- type Forwarder
- type Options
- type Payloads
- type Response
- type SyncForwarder
- func (f *SyncForwarder) Start() error
- func (f *SyncForwarder) Stop()
- func (f *SyncForwarder) SubmitAgentChecksMetadata(payload Payloads, extra http.Header) error
- func (f *SyncForwarder) SubmitConnectionChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (f *SyncForwarder) SubmitContainerChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (f *SyncForwarder) SubmitEvents(payload Payloads, extra http.Header) error
- func (f *SyncForwarder) SubmitHostMetadata(payload Payloads, extra http.Header) error
- func (f *SyncForwarder) SubmitMetadata(payload Payloads, extra http.Header) error
- func (f *SyncForwarder) SubmitOrchestratorChecks(payload Payloads, extra http.Header, payloadType int) (chan Response, error)
- func (f *SyncForwarder) SubmitProcessChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (f *SyncForwarder) SubmitProcessDiscoveryChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (f *SyncForwarder) SubmitRTContainerChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (f *SyncForwarder) SubmitRTProcessChecks(payload Payloads, extra http.Header) (chan Response, error)
- func (f *SyncForwarder) SubmitSeries(payload Payloads, extra http.Header) error
- func (f *SyncForwarder) SubmitServiceChecks(payload Payloads, extra http.Header) error
- func (f *SyncForwarder) SubmitSketchSeries(payload Payloads, extra http.Header) error
- func (f *SyncForwarder) SubmitV1CheckRuns(payload Payloads, extra http.Header) error
- func (f *SyncForwarder) SubmitV1Intake(payload Payloads, extra http.Header) error
- func (f *SyncForwarder) SubmitV1Series(payload Payloads, extra http.Header) error
- 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 ¶
func HasFeature ¶
HasFeature lets you know if a specific feature flag is set in a feature set
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) SubmitAgentChecksMetadata ¶
func (f *DefaultForwarder) SubmitAgentChecksMetadata(payload Payloads, extra http.Header) error
SubmitAgentChecksMetadata will send a agentchecks_metadata tag type payload to Datadog backend.
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) SubmitOrchestratorChecks ¶
func (f *DefaultForwarder) SubmitOrchestratorChecks(payload Payloads, extra http.Header, payloadType int) (chan Response, error)
SubmitOrchestratorChecks sends orchestrator checks
func (*DefaultForwarder) SubmitProcessChecks ¶
func (f *DefaultForwarder) SubmitProcessChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitProcessChecks sends process checks
func (*DefaultForwarder) SubmitProcessDiscoveryChecks ¶
func (f *DefaultForwarder) SubmitProcessDiscoveryChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitProcessDiscoveryChecks sends process discovery 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 timeseries to the v2 endpoint
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 Features ¶
type Features uint8
Features is a bitmask to enable specific forwarder features
const ( // CoreFeatures bitmask to enable specific core features CoreFeatures Features = 1 << iota // TraceFeatures bitmask to enable specific trace features TraceFeatures // ProcessFeatures bitmask to enable specific process features ProcessFeatures // SysProbeFeatures bitmask to enable specific system-probe features SysProbeFeatures )
func ClearFeature ¶
ClearFeature clears forwarder features from a feature set
func SetFeature ¶
SetFeature sets forwarder features in a feature set
func ToggleFeature ¶
ToggleFeature toggles forwarder features in a feature set
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 SubmitEvents(payload Payloads, extra http.Header) error SubmitServiceChecks(payload Payloads, extra http.Header) error SubmitSeries(payload Payloads, extra http.Header) error SubmitSketchSeries(payload Payloads, extra http.Header) error SubmitHostMetadata(payload Payloads, extra http.Header) error SubmitAgentChecksMetadata(payload Payloads, extra http.Header) error SubmitMetadata(payload Payloads, extra http.Header) error SubmitProcessChecks(payload Payloads, extra http.Header) (chan Response, error) SubmitProcessDiscoveryChecks(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) SubmitOrchestratorChecks(payload Payloads, extra http.Header, payloadType int) (chan Response, error) }
Forwarder interface allows packages to send payload to the backend
type Options ¶
type Options struct { NumberOfWorkers int RetryQueuePayloadsTotalMaxSize int DisableAPIKeyChecking bool EnabledFeatures Features APIKeyValidationInterval time.Duration DomainResolvers map[string]resolver.DomainResolver ConnectionResetInterval time.Duration CompletionHandler transaction.HTTPCompletionHandler }
Options contain the configuration options for the DefaultForwarder
func NewOptions ¶
NewOptions creates new Options with default values
func NewOptionsWithResolvers ¶
func NewOptionsWithResolvers(domainResolvers map[string]resolver.DomainResolver) *Options
NewOptionsWithResolvers 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 SyncForwarder ¶
type SyncForwarder struct {
// contains filtered or unexported fields
}
SyncForwarder is a very simple Forwarder synchronously sending the data to the intake.
func NewSyncForwarder ¶
func NewSyncForwarder(domainResolvers map[string]resolver.DomainResolver, timeout time.Duration) *SyncForwarder
NewSyncForwarder returns a new synchronous forwarder.
func (*SyncForwarder) Start ¶
func (f *SyncForwarder) Start() error
Start starts the sync forwarder: nothing to do.
func (*SyncForwarder) Stop ¶
func (f *SyncForwarder) Stop()
Stop stops the sync forwarder: nothing to do.
func (*SyncForwarder) SubmitAgentChecksMetadata ¶
func (f *SyncForwarder) SubmitAgentChecksMetadata(payload Payloads, extra http.Header) error
SubmitAgentChecksMetadata will send a agentchecks_metadata tag type payload to Datadog backend.
func (*SyncForwarder) SubmitConnectionChecks ¶
func (f *SyncForwarder) SubmitConnectionChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitConnectionChecks sends connection checks
func (*SyncForwarder) SubmitContainerChecks ¶
func (f *SyncForwarder) SubmitContainerChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitContainerChecks sends container checks
func (*SyncForwarder) SubmitEvents ¶
func (f *SyncForwarder) SubmitEvents(payload Payloads, extra http.Header) error
SubmitEvents will send an event type payload to Datadog backend.
func (*SyncForwarder) SubmitHostMetadata ¶
func (f *SyncForwarder) SubmitHostMetadata(payload Payloads, extra http.Header) error
SubmitHostMetadata will send a host_metadata tag type payload to Datadog backend.
func (*SyncForwarder) SubmitMetadata ¶
func (f *SyncForwarder) SubmitMetadata(payload Payloads, extra http.Header) error
SubmitMetadata will send a metadata type payload to Datadog backend.
func (*SyncForwarder) SubmitOrchestratorChecks ¶
func (f *SyncForwarder) SubmitOrchestratorChecks(payload Payloads, extra http.Header, payloadType int) (chan Response, error)
SubmitOrchestratorChecks sends orchestrator checks
func (*SyncForwarder) SubmitProcessChecks ¶
func (f *SyncForwarder) SubmitProcessChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitProcessChecks sends process checks
func (*SyncForwarder) SubmitProcessDiscoveryChecks ¶
func (f *SyncForwarder) SubmitProcessDiscoveryChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitProcessDiscoveryChecks sends process discovery checks
func (*SyncForwarder) SubmitRTContainerChecks ¶
func (f *SyncForwarder) SubmitRTContainerChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitRTContainerChecks sends real time container checks
func (*SyncForwarder) SubmitRTProcessChecks ¶
func (f *SyncForwarder) SubmitRTProcessChecks(payload Payloads, extra http.Header) (chan Response, error)
SubmitRTProcessChecks sends real time process checks
func (*SyncForwarder) SubmitSeries ¶
func (f *SyncForwarder) SubmitSeries(payload Payloads, extra http.Header) error
SubmitSeries will send timeseries to the v2 endpoint
func (*SyncForwarder) SubmitServiceChecks ¶
func (f *SyncForwarder) SubmitServiceChecks(payload Payloads, extra http.Header) error
SubmitServiceChecks will send a service check type payload to Datadog backend.
func (*SyncForwarder) SubmitSketchSeries ¶
func (f *SyncForwarder) SubmitSketchSeries(payload Payloads, extra http.Header) error
SubmitSketchSeries will send payloads to Datadog backend - PROTOTYPE FOR PERCENTILE
func (*SyncForwarder) SubmitV1CheckRuns ¶
func (f *SyncForwarder) 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 (*SyncForwarder) SubmitV1Intake ¶
func (f *SyncForwarder) SubmitV1Intake(payload Payloads, extra http.Header) error
SubmitV1Intake will send payloads to the universal `/intake/` endpoint used by Agent v.5
func (*SyncForwarder) SubmitV1Series ¶
func (f *SyncForwarder) 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 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.Transaction // LowPrio is the channel used to receive low priority transaction from the Forwarder. LowPrio <-chan transaction.Transaction // RequeueChan is the channel used to send failed transaction back to the Forwarder. RequeueChan chan<- transaction.Transaction // contains filtered or unexported fields }
Worker consumes Transaction (aka transactions) from the Forwarder and processes them. If the transaction fails to be processed the Worker will send it back to the Forwarder to be retried later.
func NewWorker ¶
func NewWorker( highPrioChan <-chan transaction.Transaction, lowPrioChan <-chan transaction.Transaction, requeueChan chan<- transaction.Transaction, blocked *blockedEndpoints) *Worker
NewWorker returns a new worker to consume Transaction from inputChan and push back erroneous ones into requeueChan.
func (*Worker) ScheduleConnectionReset ¶
func (w *Worker) ScheduleConnectionReset()
ScheduleConnectionReset allows signaling the worker that all connections should be recreated before sending the next transaction. Returns immediately.
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Package endpoints stores a collection of `transaction.Endpoint` mainly used by the forwarder package to send data to Datadog using the right request path for a given type of data.
|
Package endpoints stores a collection of `transaction.Endpoint` mainly used by the forwarder package to send data to Datadog using the right request path for a given type of data. |
internal
|
|