mirror of
https://github.com/lightningnetwork/lnd.git
synced 2025-01-19 05:45:21 +01:00
84fd911b47
Fixes new lint errors caught by the latest version.
59 lines
2.4 KiB
Go
59 lines
2.4 KiB
Go
package lncfg
|
|
|
|
import (
|
|
"fmt"
|
|
"time"
|
|
)
|
|
|
|
const (
|
|
// MinRejectCacheSize is a floor on the maximum capacity allowed for
|
|
// channeldb's reject cache. This amounts to roughly 125 KB when full.
|
|
MinRejectCacheSize = 5000
|
|
|
|
// MinChannelCacheSize is a floor on the maximum capacity allowed for
|
|
// channeldb's channel cache. This amounts to roughly 2 MB when full.
|
|
MinChannelCacheSize = 1000
|
|
|
|
// DefaultRPCGraphCacheDuration is the default interval that the RPC
|
|
// response to DescribeGraph should be cached for.
|
|
DefaultRPCGraphCacheDuration = time.Minute
|
|
)
|
|
|
|
// Caches holds the configuration for various caches within lnd.
|
|
//
|
|
//nolint:lll
|
|
type Caches struct {
|
|
// RejectCacheSize is the maximum number of entries stored in lnd's
|
|
// reject cache, which is used for efficiently rejecting gossip updates.
|
|
// Memory usage is roughly 25b per entry.
|
|
RejectCacheSize int `long:"reject-cache-size" description:"Maximum number of entries contained in the reject cache, which is used to speed up filtering of new channel announcements and channel updates from peers. Each entry requires 25 bytes."`
|
|
|
|
// ChannelCacheSize is the maximum number of entries stored in lnd's
|
|
// channel cache, which is used reduce memory allocations in reply to
|
|
// peers querying for gossip traffic. Memory usage is roughly 2Kb per
|
|
// entry.
|
|
ChannelCacheSize int `long:"channel-cache-size" description:"Maximum number of entries contained in the channel cache, which is used to reduce memory allocations from gossip queries from peers. Each entry requires roughly 2Kb."`
|
|
|
|
// RPCGraphCacheDuration is used to control the flush interval of the
|
|
// channel graph cache.
|
|
RPCGraphCacheDuration time.Duration `long:"rpc-graph-cache-duration" description:"The period of time expressed as a duration (1s, 1m, 1h, etc) that the RPC response to DescribeGraph should be cached for."`
|
|
}
|
|
|
|
// Validate checks the Caches configuration for values that are too small to be
|
|
// sane.
|
|
func (c *Caches) Validate() error {
|
|
if c.RejectCacheSize < MinRejectCacheSize {
|
|
return fmt.Errorf("reject cache size %d is less than min: %d",
|
|
c.RejectCacheSize, MinRejectCacheSize)
|
|
}
|
|
if c.ChannelCacheSize < MinChannelCacheSize {
|
|
return fmt.Errorf("channel cache size %d is less than min: %d",
|
|
c.ChannelCacheSize, MinChannelCacheSize)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// Compile-time constraint to ensure Caches implements the Validator interface.
|
|
var _ Validator = (*Caches)(nil)
|