Documentation ¶
Overview ¶
Package transform provides some intermediate nodes that might filter/process/transform the events
Index ¶
- Constants
- func KubeDecoratorProvider(ctxInfo *global.ContextInfo, kubeDecorator *KubernetesDecorator) pipe.MiddleProvider[[]request.Span, []request.Span]
- func NameResolutionProvider(ctxInfo *global.ContextInfo, cfg *NameResolverConfig) pipe.MiddleProvider[[]request.Span, []request.Span]
- func RoutesProvider(rc *RoutesConfig) pipe.MiddleProvider[[]request.Span, []request.Span]
- type IgnoreMode
- type KubeEnableFlag
- type KubernetesDecorator
- type NameResolver
- type NameResolverConfig
- type RoutesConfig
- type UnmatchType
Constants ¶
View Source
const ( EnabledTrue = KubeEnableFlag("true") EnabledFalse = KubeEnableFlag("false") EnabledAutodetect = KubeEnableFlag("autodetect") EnabledDefault = EnabledFalse )
View Source
const ( // UnmatchUnset leaves the Route field as empty UnmatchUnset = UnmatchType("unset") // UnmatchPath sets the Route field to the same values as the Path UnmatchPath = UnmatchType("path") // UnmatchWildcard sets the route field to a generic asterisk symbol UnmatchWildcard = UnmatchType("wildcard") // UnmatchHeuristic detects the route field using a heuristic UnmatchHeuristic = UnmatchType("heuristic") UnmatchDefault = UnmatchWildcard )
View Source
const ( // IgnoreMetrics prevents sending metric events for ignored patterns IgnoreMetrics = IgnoreMode("metrics") // IgnoreTraces prevents sending trace events for ignored patterns IgnoreTraces = IgnoreMode("traces") // IgnoreAll prevents sending both metrics and traces for ignored patterns IgnoreAll = IgnoreMode("all") IgnoreDefault = IgnoreAll )
Variables ¶
This section is empty.
Functions ¶
func KubeDecoratorProvider ¶
func KubeDecoratorProvider( ctxInfo *global.ContextInfo, kubeDecorator *KubernetesDecorator, ) pipe.MiddleProvider[[]request.Span, []request.Span]
func NameResolutionProvider ¶
func NameResolutionProvider(ctxInfo *global.ContextInfo, cfg *NameResolverConfig) pipe.MiddleProvider[[]request.Span, []request.Span]
func RoutesProvider ¶
func RoutesProvider(rc *RoutesConfig) pipe.MiddleProvider[[]request.Span, []request.Span]
Types ¶
type IgnoreMode ¶
type IgnoreMode string
type KubeEnableFlag ¶
type KubeEnableFlag string
type KubernetesDecorator ¶
type KubernetesDecorator struct { Enable KubeEnableFlag `yaml:"enable" env:"BEYLA_KUBE_METADATA_ENABLE"` // ClusterName overrides cluster name. If empty, the NetO11y module will try to retrieve // it from the Cloud Provider Metadata (EC2, GCP and Azure), and leave it empty if it fails to. ClusterName string `yaml:"cluster_name" env:"BEYLA_KUBE_CLUSTER_NAME"` // KubeconfigPath is optional. If unset, it will look in the usual location. KubeconfigPath string `yaml:"kubeconfig_path" env:"KUBECONFIG"` InformersSyncTimeout time.Duration `yaml:"informers_sync_timeout" env:"BEYLA_KUBE_INFORMERS_SYNC_TIMEOUT"` // DropExternal will drop, in NetO11y component, any flow where the source or destination // IPs are not matched to any kubernetes entity, assuming they are cluster-external DropExternal bool `yaml:"drop_external" env:"BEYLA_NETWORK_DROP_EXTERNAL"` }
func (KubernetesDecorator) Enabled ¶
func (d KubernetesDecorator) Enabled() bool
type NameResolver ¶
type NameResolver struct {
// contains filtered or unexported fields
}
type NameResolverConfig ¶
type NameResolverConfig struct { // CacheLen specifies the max size of the LRU cache that is checked before // performing the name lookup. Default: 256 CacheLen int `yaml:"cache_len" env:"BEYLA_NAME_RESOLVER_CACHE_LEN"` // CacheTTL specifies the time-to-live of a cached IP->hostname entry. After the // cached entry becomes older than this time, the IP->hostname entry will be looked // up again. CacheTTL time.Duration `yaml:"cache_expiry" env:"BEYLA_NAME_RESOLVER_CACHE_TTL"` }
type RoutesConfig ¶
type RoutesConfig struct { // Unmatch specifies what to do when a route pattern is not matched Unmatch UnmatchType `yaml:"unmatched"` // Patterns of the paths that will match to a route Patterns []string `yaml:"patterns"` IgnorePatterns []string `yaml:"ignored_patterns"` IgnoredEvents IgnoreMode `yaml:"ignore_mode"` }
RoutesConfig allows grouping URLs sharing a given pattern.
type UnmatchType ¶
type UnmatchType string
UnmatchType defines which actions to do when a route pattern is not recognized
Click to show internal directories.
Click to hide internal directories.