submatview: godoc

This commit is contained in:
Daniel Nephin 2021-04-27 15:39:26 -04:00
parent d9537411b8
commit 46b7d0b573
2 changed files with 22 additions and 2 deletions

View File

@ -9,7 +9,7 @@ import (
"github.com/hashicorp/consul/proto/pbsubscribe" "github.com/hashicorp/consul/proto/pbsubscribe"
) )
// TODO: godoc // Client provides access to service health data.
type Client struct { type Client struct {
NetRPC NetRPC NetRPC NetRPC
Cache CacheGetter Cache CacheGetter

View File

@ -13,6 +13,12 @@ import (
"github.com/hashicorp/consul/lib/ttlcache" "github.com/hashicorp/consul/lib/ttlcache"
) )
// Store of Materializers. Store implements an interface similar to
// agent/cache.Cache, and allows a single Materliazer to fulfill multiple requests
// as long as the requests are identical.
// Store is used in place of agent/cache.Cache because with the streaming
// backend there is no longer any need to run a background goroutine to refresh
// stored values.
type Store struct { type Store struct {
logger hclog.Logger logger hclog.Logger
lock sync.RWMutex lock sync.RWMutex
@ -34,6 +40,8 @@ type entry struct {
requests int requests int
} }
// NewStore creates and returns a Store that is ready for use. The caller must
// call Store.Run (likely in a separate goroutine) to start the expiration loop.
func NewStore(logger hclog.Logger) *Store { func NewStore(logger hclog.Logger) *Store {
return &Store{ return &Store{
logger: logger, logger: logger,
@ -54,10 +62,14 @@ func (s *Store) Run(ctx context.Context) {
case <-ctx.Done(): case <-ctx.Done():
timer.Stop() timer.Stop()
return return
// the first item in the heap has changed, restart the timer with the
// new TTL.
case <-s.expiryHeap.NotifyCh: case <-s.expiryHeap.NotifyCh:
timer.Stop() timer.Stop()
continue continue
// the TTL for the first item has been reached, attempt an expiration.
case <-timer.Wait(): case <-timer.Wait():
s.lock.Lock() s.lock.Lock()
@ -77,10 +89,18 @@ func (s *Store) Run(ctx context.Context) {
} }
} }
// TODO: godoc // Request is used to request data from the Store.
// Note that cache.Request is required, but some of the fields cache.RequestInfo
// fields are ignored (ex: MaxAge, and MustRevalidate).
type Request interface { type Request interface {
cache.Request cache.Request
// NewMaterializer will be called if there is no active materializer to fulfil
// the request. It should return a Materializer appropriate for streaming
// data to fulfil this request.
NewMaterializer() (*Materializer, error) NewMaterializer() (*Materializer, error)
// Type should return a string which uniquely identifies this type of request.
// The returned value is used as the prefix of the key used to index
// entries in the Store.
Type() string Type() string
} }