Documentation ¶
Index ¶
- func Convert(ent *entry.Entry) plog.Logs
- func ConvertFrom(pLogs plog.Logs) []*entry.Entry
- func GetStorageClient(ctx context.Context, host component.Host, storageID *component.ID, ...) (storage.Client, error)
- func HashResource(resource map[string]interface{}) uint64
- func NewFactory(logReceiverType LogReceiverType, sl component.StabilityLevel) rcvr.Factory
- type BaseConfig
- type Converter
- type FromPdataConverter
- type LogEmitter
- type LogReceiverType
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func Convert ¶
Convert converts one entry.Entry into plog.Logs. To be used in a stateless setting like tests where ease of use is more important than performance or throughput.
func ConvertFrom ¶
ConvertFrom converts plog.Logs into a slice of entry.Entry To be used in a stateless setting like tests where ease of use is more important than performance or throughput.
func GetStorageClient ¶
func HashResource ¶
HashResource will hash an entry.Entry.Resource
func NewFactory ¶
func NewFactory(logReceiverType LogReceiverType, sl component.StabilityLevel) rcvr.Factory
NewFactory creates a factory for a Stanza-based receiver
Types ¶
type BaseConfig ¶
type BaseConfig struct { config.ReceiverSettings `mapstructure:",squash"` Operators []operator.Config `mapstructure:"operators"` StorageID *component.ID `mapstructure:"storage"` }
BaseConfig is the common configuration of a stanza-based receiver
type Converter ¶
type Converter struct {
// contains filtered or unexported fields
}
Converter converts a batch of entry.Entry into plog.Logs aggregating translated entries into logs coming from the same Resource.
The diagram below illustrates the internal communication inside the Converter:
┌─────────────────────────────────┐ │ Batch() │ ┌─────────┤ Ingests batches of log entries │ │ │ and sends them onto workerChan │ │ └─────────────────────────────────┘ │ │ ┌───────────────────────────────────────────────────┐ ├─► workerLoop() │ │ │ ┌─────────────────────────────────────────────────┴─┐ ├─┼─► workerLoop() │ │ │ │ ┌─────────────────────────────────────────────────┴─┐ └─┼─┼─► workerLoop() │ └─┤ │ consumes sent log entries from workerChan, │ │ │ translates received entries to plog.LogRecords,│ └─┤ hashes them to generate an ID, and sends them │ │ onto batchChan │ └─────────────────────────┬─────────────────────────┘ │ ▼ ┌─────────────────────────────────────────────────────┐ │ aggregationLoop() │ │ consumes from batchChan, aggregates log records │ │ by marshaled Resource and sends the │ │ aggregated buffer to flushChan │ └───────────────────────────┬─────────────────────────┘ │ ▼ ┌─────────────────────────────────────────────────────┐ │ flushLoop() │ │ receives log records from flushChan and sends │ │ them onto pLogsChan which is consumed by │ │ downstream consumers via OutChannel() │ └─────────────────────────────────────────────────────┘
func NewConverter ¶
func (*Converter) Batch ¶
Batch takes in an entry.Entry and sends it to an available worker for processing.
func (*Converter) OutChannel ¶
OutChannel returns the channel on which converted entries will be sent to.
type FromPdataConverter ¶
type FromPdataConverter struct {
// contains filtered or unexported fields
}
FromPdataConverter converts a set of entry.Entry into plog.Logs
The diagram below illustrates the internal communication inside the FromPdataConverter:
┌─────────────────────────────────┐ │ Batch() │ ┌─────────┤ Ingests plog.Logs, splits up │ │ │ and places them on workerChan │ │ └─────────────────────────────────┘ │ │ ┌───────────────────────────────────────────────────┐ ├─► workerLoop() │ │ │ ┌─────────────────────────────────────────────────┴─┐ ├─┼─► workerLoop() │ │ │ │ ┌─────────────────────────────────────────────────┴─┐ └─┼─┼─► workerLoop() │ └─┤ │ consumes sent log entries from workerChan, │ │ │ translates received logs to entry.Entry, │ └─┤ and sends them along entriesChan │ └───────────────────────────────────────────────────┘
func NewFromPdataConverter ¶
func NewFromPdataConverter(workerCount int, logger *zap.Logger) *FromPdataConverter
func (*FromPdataConverter) Batch ¶
func (c *FromPdataConverter) Batch(pLogs plog.Logs) error
Batch takes in an set of plog.Logs and sends it to an available worker for processing.
func (*FromPdataConverter) OutChannel ¶
func (c *FromPdataConverter) OutChannel() <-chan []*entry.Entry
OutChannel returns the channel on which converted entries will be sent to.
func (*FromPdataConverter) Start ¶
func (c *FromPdataConverter) Start()
func (*FromPdataConverter) Stop ¶
func (c *FromPdataConverter) Stop()
type LogEmitter ¶
type LogEmitter struct { helper.OutputOperator // contains filtered or unexported fields }
LogEmitter is a stanza operator that emits log entries to a channel
func NewLogEmitter ¶
func NewLogEmitter(logger *zap.SugaredLogger) *LogEmitter
NewLogEmitter creates a new receiver output
func (*LogEmitter) OutChannel ¶
func (e *LogEmitter) OutChannel() <-chan []*entry.Entry
OutChannel returns the channel on which entries will be sent to.
func (*LogEmitter) Start ¶
func (e *LogEmitter) Start(_ operator.Persister) error
Start starts the goroutine(s) required for this operator
func (*LogEmitter) Stop ¶
func (e *LogEmitter) Stop() error
Stop will close the log channel and stop running goroutines