Feeds within Cloudsoft AMP are used to populate an entity’s sensors. There are a variety of
feed types, which commonly poll to retrieve the raw metrics of the entity (for example polling an
HTTP management API, or over JMX).
Persistence
There are two ways to associate a feed with an entity.
The first way is (within the entity) to call feeds().addFeed(...).
This persists the feed: the feed will be automatically
added to the entity when the AMP server restarts. It is important that all configuration
of the feed is persistable (e.g. not using any in-line anonymous inner classes to define
functions).
The feed builders can be passed a uniqueTag(...), which will be used to ensure that on
rebind there will not be multiple copied of the feed (e.g. if rebind() had already re-created
the feed).
The second way is to just pass to the feed’s builder the entity. When using this mechanism,
the feed will be wired up to the entity but it will not be persisted. In this case, it is
important that the entity’s rebind() method recreates the feed.
Types of Feed
HTTP Feed
An HttpFeed polls over HTTP(S). An example is shown below:
SSH Feed
An SSH feed executes a command over ssh periodically. An example is shown below:
WinRm CMD Feed
A WinRM feed executes a Windows command over WinRM periodically. An example is shown below:
Windows Performance Counter Feed
This type of feed retrieves performance counters from a Windows host, and posts the values to sensors.
One must supply a collection of mappings between Windows performance counter names and AMP
attribute sensors.
This feed uses WinRM to invoke the Windows utility typeperf to query for a specific set
of performance counters, by name. The values are extracted from the response, and published to the
entity’s sensors. An example is shown below:
JMX Feed
This type of feed queries over JMX to retrieve sensor values. This can query attribute
values or call operations.
The JMX connection details can be automatically inferred from the entity’s standard attributes,
or it can be explicitly supplied.
An example is shown below:
Function Feed
This type of feed periodically executes something to compute the attribute values. This
can be a Callable, Supplier or Groovy Closure. It must be persistable (e.g. not use
an in-line anonymous inner classes).