streaming: Use a shorter LastGetTTL for the cache

pull/8825/head
Daniel Nephin 2020-10-08 12:10:38 -04:00
parent fcaf362c9f
commit b5b790d4c0
1 changed files with 13 additions and 0 deletions

View File

@ -28,6 +28,19 @@ type StreamingHealthServices struct {
deps MaterializerDeps deps MaterializerDeps
} }
// RegisterOptions returns options with a much shorter LastGetTTL than the default.
// Unlike other cache-types, StreamingHealthServices runs a materialized view in
// the background which will receive streamed events from a server. If the cache
// is not being used, that stream uses memory on the server and network transfer
// between the client and the server.
// The materialize view and the stream are stopped when the cache entry expires,
// so using a shorter TTL ensures the cache entry expires sooner.
func (c *StreamingHealthServices) RegisterOptions() cache.RegisterOptions {
opts := c.RegisterOptionsBlockingRefresh.RegisterOptions()
opts.LastGetTTL = 10 * time.Minute
return opts
}
// NewStreamingHealthServices creates a cache-type for watching for service // NewStreamingHealthServices creates a cache-type for watching for service
// health results via streaming updates. // health results via streaming updates.
func NewStreamingHealthServices(deps MaterializerDeps) *StreamingHealthServices { func NewStreamingHealthServices(deps MaterializerDeps) *StreamingHealthServices {