Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Fingerprint ¶ added in v0.12.0
type Fingerprint struct {
FirstBytes []byte
}
Fingerprint is used to identify a file A file's fingerprint is the first N bytes of the file, where N is the fingerprintSize on the file_input operator
func (Fingerprint) Copy ¶ added in v0.12.0
func (f Fingerprint) Copy() *Fingerprint
Copy creates a new copy of the fingerprint
func (Fingerprint) StartsWith ¶ added in v0.13.3
func (f Fingerprint) StartsWith(old *Fingerprint) bool
StartsWith returns true if the fingerprints are the same or if the new fingerprint starts with the old one This is important functionality for tracking new files, since their initial size is typically less than that of a fingerprint. As the file grows, its fingerprint is updated until it reaches a maximum size, as configured on the operator
type FingerprintUpdatingReader ¶ added in v0.12.0
type FingerprintUpdatingReader struct {
// contains filtered or unexported fields
}
FingerprintUpdatingReader wraps another reader, and updates the fingerprint with each read in the first fingerPrintSize bytes
func NewFingerprintUpdatingReader ¶ added in v0.12.0
func NewFingerprintUpdatingReader(r io.Reader, offset int64, f *Fingerprint, fingerprintSize int) *FingerprintUpdatingReader
NewFingerprintUpdatingReader creates a new FingerprintUpdatingReader starting starting at the given offset
type InputConfig ¶
type InputConfig struct { helper.InputConfig `yaml:",inline"` Include []string `json:"include,omitempty" yaml:"include,omitempty"` Exclude []string `json:"exclude,omitempty" yaml:"exclude,omitempty"` PollInterval helper.Duration `json:"poll_interval,omitempty" yaml:"poll_interval,omitempty"` Multiline helper.MultilineConfig `json:"multiline,omitempty" yaml:"multiline,omitempty"` IncludeFileName bool `json:"include_file_name,omitempty" yaml:"include_file_name,omitempty"` IncludeFilePath bool `json:"include_file_path,omitempty" yaml:"include_file_path,omitempty"` IncludeFileNameResolved bool `json:"include_file_name_resolved,omitempty" yaml:"include_file_name_resolved,omitempty"` IncludeFilePathResolved bool `json:"include_file_path_resolved,omitempty" yaml:"include_file_path_resolved,omitempty"` StartAt string `json:"start_at,omitempty" yaml:"start_at,omitempty"` FingerprintSize helper.ByteSize `json:"fingerprint_size,omitempty" yaml:"fingerprint_size,omitempty"` MaxLogSize helper.ByteSize `json:"max_log_size,omitempty" yaml:"max_log_size,omitempty"` MaxConcurrentFiles int `json:"max_concurrent_files,omitempty" yaml:"max_concurrent_files,omitempty"` Encoding helper.EncodingConfig `json:",inline,omitempty" yaml:",inline,omitempty"` }
InputConfig is the configuration of a file input operator
func NewInputConfig ¶
func NewInputConfig(operatorID string) *InputConfig
NewInputConfig creates a new input config with default values
func (InputConfig) Build ¶
func (c InputConfig) Build(context operator.BuildContext) ([]operator.Operator, error)
Build will build a file input operator from the supplied configuration
type InputOperator ¶
type InputOperator struct { helper.InputOperator Include []string Exclude []string FilePathField entry.Field FileNameField entry.Field FilePathResolvedField entry.Field FileNameResolvedField entry.Field PollInterval time.Duration SplitFunc bufio.SplitFunc MaxLogSize int MaxConcurrentFiles int SeenPaths map[string]struct{} // contains filtered or unexported fields }
InputOperator is an operator that monitors files for entries
func (*InputOperator) NewFingerprint ¶ added in v0.13.7
func (f *InputOperator) NewFingerprint(file *os.File) (*Fingerprint, error)
NewFingerprint creates a new fingerprint from an open file
func (*InputOperator) NewReader ¶ added in v0.13.7
func (f *InputOperator) NewReader(path string, file *os.File, fp *Fingerprint) (*Reader, error)
NewReader creates a new file reader
func (*InputOperator) Start ¶
func (f *InputOperator) Start() error
Start will start the file monitoring process
func (*InputOperator) Stop ¶
func (f *InputOperator) Stop() error
Stop will stop the file monitoring process
type PositionalScanner ¶
PositionalScanner is a scanner that maintains position
func NewPositionalScanner ¶
func NewPositionalScanner(r io.Reader, maxLogSize int, startOffset int64, splitFunc bufio.SplitFunc) *PositionalScanner
NewPositionalScanner creates a new positional scanner
func (*PositionalScanner) Pos ¶
func (ps *PositionalScanner) Pos() int64
Pos returns the current position of the scanner
type Reader ¶ added in v0.12.0
type Reader struct { Fingerprint *Fingerprint Offset int64 *zap.SugaredLogger `json:"-"` // contains filtered or unexported fields }
Reader manages a single file
func (*Reader) InitializeOffset ¶ added in v0.12.0
InitializeOffset sets the starting offset