loki

package
v0.16.1 Latest Latest
Warning

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

Go to latest
Published: Jun 22, 2021 License: Apache-2.0 Imports: 19 Imported by: 0

Documentation

Overview

Package loki implements Loki logs support for the Grafana Agent.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Config

type Config struct {
	PositionsDirectory string            `yaml:"positions_directory,omitempty"`
	Configs            []*InstanceConfig `yaml:"configs,omitempty"`
}

Config controls the configuration of the Loki log scraper.

func (*Config) ApplyDefaults added in v0.12.0

func (c *Config) ApplyDefaults() error

ApplyDefaults applies defaults to the Config and ensures that it is valid.

Validations:

  1. No two InstanceConfigs may have the same name.
  2. No two InstanceConfigs may have the same positions path.
  3. No InstanceConfig may have an empty name.
  4. If InstanceConfig positions path is empty, shared PositionsDirectory must not be empty.

Defaults:

  1. If a positions config is empty, it will be generated based on the InstanceConfig name and Config.PositionsDirectory.

func (*Config) UnmarshalYAML

func (c *Config) UnmarshalYAML(unmarshal func(interface{}) error) error

UnmarshalYAML implements yaml.Unmarshaler.

type Instance added in v0.13.0

type Instance struct {
	// contains filtered or unexported fields
}

Instance is an individual Loki instance.

func NewInstance added in v0.13.0

func NewInstance(reg prometheus.Registerer, c *InstanceConfig, l log.Logger) (*Instance, error)

NewInstance creates and starts a Loki instance.

func (*Instance) ApplyConfig added in v0.13.0

func (i *Instance) ApplyConfig(c *InstanceConfig) error

ApplyConfig will apply a new InstanceConfig. If the config hasn't changed, then nothing will happen, otherwise the old Promtail will be stopped and then replaced with a new one.

func (*Instance) SendEntry added in v0.14.0

func (i *Instance) SendEntry(entry api.Entry, dur time.Duration) bool

SendEntry passes an entry to the internal promtail client and returns true if successfully sent. It is best effort and not guaranteed to succeed.

func (*Instance) Stop added in v0.13.0

func (i *Instance) Stop()

Stop stops the Promtail instance.

type InstanceConfig added in v0.12.0

type InstanceConfig struct {
	Name string `yaml:"name,omitempty"`

	ClientConfigs   []client.Config       `yaml:"clients,omitempty"`
	PositionsConfig positions.Config      `yaml:"positions,omitempty"`
	ScrapeConfig    []scrapeconfig.Config `yaml:"scrape_configs,omitempty"`
	TargetConfig    file.Config           `yaml:"target_config,omitempty"`
}

InstanceConfig is an individual Promtail config.

func (*InstanceConfig) UnmarshalYAML added in v0.12.0

func (c *InstanceConfig) UnmarshalYAML(unmarshal func(interface{}) error) error

UnmarshalYAML implements yaml.Unmarshaler.

type Loki

type Loki struct {
	// contains filtered or unexported fields
}

Loki is a Loki log collection. It uses multiple distinct sets of Loki Promtail agents to collect logs and send them to a Loki server.

func New

func New(reg prometheus.Registerer, c Config, l log.Logger) (*Loki, error)

New creates and starts Loki log collection.

func (*Loki) ApplyConfig added in v0.13.0

func (l *Loki) ApplyConfig(c Config) error

ApplyConfig updates Loki with a new Config.

func (*Loki) Instance added in v0.14.0

func (l *Loki) Instance(name string) *Instance

Instance is used to retrieve a named Loki instance

func (*Loki) Stop

func (l *Loki) Stop()

Stop stops the log collector.

Jump to

Keyboard shortcuts

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