mirror of https://github.com/status-im/consul.git
submatview: godoc
This commit is contained in:
parent
d9537411b8
commit
46b7d0b573
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue