ratelimiter

package
v0.6.0 Latest Latest
Warning

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

Go to latest
Published: Dec 1, 2022 License: MPL-2.0 Imports: 4 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type LogRateLimiter

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

LogRateLimiter represents the RateLimiter config for logs

func NewLogRateLimiter

func NewLogRateLimiter(setting RateLimiterSetting) (*LogRateLimiter, error)

NewLogRateLimiter creates RateLimiter implementation for logs using RateLimiterSetting

func (*LogRateLimiter) Acquire

func (rateLimiter *LogRateLimiter) Acquire() (bool, error)

Acquire checks if the requests count for logs is reached to maximum allocated quota per minute.

func (*LogRateLimiter) IncRequestCount

func (rateLimiter *LogRateLimiter) IncRequestCount()

IncRequestCount increaments the request count associated with logs by 1

func (*LogRateLimiter) ResetRequestCount

func (rateLimiter *LogRateLimiter) ResetRequestCount()

ResetRequestCount resets the request count associated with logs to 0

func (*LogRateLimiter) Run

func (rateLimiter *LogRateLimiter) Run(ctx context.Context)

Run starts the timer for reseting the logs request counter

func (*LogRateLimiter) Shutdown

func (rateLimiter *LogRateLimiter) Shutdown(_ context.Context)

Shutdown triggers the shutdown of the LogRateLimiter

type MetricsRateLimiter

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

MetricsRateLimiter represents the RateLimiter config for metrics

func NewMetricsRateLimiter

func NewMetricsRateLimiter(setting RateLimiterSetting) (*MetricsRateLimiter, error)

NewMetricsRateLimiter creates RateLimiter implementation for metrics using RateLimiterSetting

func (*MetricsRateLimiter) Acquire

func (rateLimiter *MetricsRateLimiter) Acquire() (bool, error)

Acquire checks if the requests count for metrics is reached to maximum allocated quota per minute.

func (*MetricsRateLimiter) IncRequestCount

func (rateLimiter *MetricsRateLimiter) IncRequestCount()

IncRequestCount increaments the request count associated with metrics by 1

func (*MetricsRateLimiter) ResetRequestCount

func (rateLimiter *MetricsRateLimiter) ResetRequestCount()

ResetRequestCount resets the request count associated with metrics to 0

func (*MetricsRateLimiter) Run

func (rateLimiter *MetricsRateLimiter) Run(ctx context.Context)

Run starts the timer for reseting the metrics request counter

func (*MetricsRateLimiter) Shutdown

func (rateLimiter *MetricsRateLimiter) Shutdown(_ context.Context)

Shutdown triggers the shutdown of the MetricsRateLimiter

type RateLimiter

type RateLimiter interface {
	IncRequestCount()
	Acquire() (bool, error)
	ResetRequestCount()
	Run(context.Context)
	Shutdown(context.Context)
}

RateLimiter represents the RateLimiter operations

type RateLimiterSetting

type RateLimiterSetting struct {
	RequestCount int
}

RateLimiterSetting represents the RateLimiter config

type TraceRateLimiter

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

TraceRateLimiter represents the RateLimiter config for traces

func NewTraceRateLimiter

func NewTraceRateLimiter(setting RateLimiterSetting) (*TraceRateLimiter, error)

NewTraceRateLimiter creates RateLimiter implementation for traces using RateLimiterSetting

func (*TraceRateLimiter) Acquire

func (rateLimiter *TraceRateLimiter) Acquire() (bool, error)

Acquire checks if the requests count for traces is reached to maximum allocated quota per minute.

func (*TraceRateLimiter) IncRequestCount

func (rateLimiter *TraceRateLimiter) IncRequestCount()

IncRequestCount increaments the request count associated with traces by 1

func (*TraceRateLimiter) ResetRequestCount

func (rateLimiter *TraceRateLimiter) ResetRequestCount()

ResetRequestCount resets the request count associated with traces to 0

func (*TraceRateLimiter) Run

func (rateLimiter *TraceRateLimiter) Run(ctx context.Context)

Run starts the timer for reseting the traces request counter

func (*TraceRateLimiter) Shutdown

func (rateLimiter *TraceRateLimiter) Shutdown(_ context.Context)

Shutdown triggers the shutdown of the LogRateLimiter

Jump to

Keyboard shortcuts

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