Class MBeanAccessor
This API provides a means to query MBeans, get and update MBean attributes, and invoke MBean operations. Ultimately this allows a client to use Coherence's transport to communicate with the MBeanServer to interrogate MBeans.
- Since:
- 12.2.1.4.0
- Author:
- sr/hr
- See Also:
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic classThe Remote.Function for theMBeanServerConnection.getAttributes method.static classThe Remote.Function for theMBeanServerConnection.invoke method.static classThe Query Builder for generating Coherence MBean queries.static classThe Remote.Function for theMBeanServerConnection.setAttributes method.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringThe "cluster" key in the ObjectName.protected final MBeanServerProxyTheMBeanServerProxyto be used for MBean operations.static final StringThe "member" key in the ObjectName.static final StringThe "name" key in the ObjectName.static final StringThe "nodeId" key in the ObjectName.static final StringThe "service" key in the ObjectName.static final StringMBean query to filter out StorageManager MBean of a specific cache and service, running on a specific node.static final StringThe "tier" key in the ObjectName.static final StringThe "type" key in the ObjectName.
- 
Constructor SummaryConstructorsConstructorDescriptionDefault Constructor.MBeanAccessor(MBeanServerProxy mBeanServerProxy) Create an instance of MBeanAccessor.
- 
Method SummaryModifier and TypeMethodDescriptionaggregate(MBeanAccessor.QueryBuilder.ParsedQuery query, String sLocator, String sAttribute, String sCollector) Process the request for MBean attributes.Return all the attributes that match the query expressed by the providedMBeanAccessor.QueryBuilder.getAttributes(MBeanAccessor.QueryBuilder.ParsedQuery query, Filter<MBeanAttributeInfo> filter, boolean fAddStorageMBeanAttributes) Return all the attributes that match the query expressed by the providedMBeanAccessor.QueryBuilder.invoke(MBeanAccessor.QueryBuilder.ParsedQuery query, String sOperationName, Object[] aoArguments, String[] asSignature) Invoke a JMX MBean operation on one or many MBeans determined by the providedMBeanAccessor.QueryBuilder.Return a list of MBean ObjectNames determined by the providedMBeanAccessor.QueryBuilder.update(MBeanAccessor.QueryBuilder.ParsedQuery query, Map<String, Object> mapAttributes) Update all JMX MBeans determined by evaluating the providedMBeanAccessor.QueryBuilder.
- 
Field Details- 
f_mbeanServerProxyTheMBeanServerProxyto be used for MBean operations.
- 
NAMEThe "name" key in the ObjectName.- See Also:
 
- 
TYPEThe "type" key in the ObjectName.- See Also:
 
- 
SERVICEThe "service" key in the ObjectName.
- 
TIERThe "tier" key in the ObjectName.- See Also:
 
- 
NODE_IDThe "nodeId" key in the ObjectName.
- 
MEMBERThe "member" key in the ObjectName.
- 
CLUSTERThe "cluster" key in the ObjectName.
- 
STORAGE_MANAGER_QUERYMBean query to filter out StorageManager MBean of a specific cache and service, running on a specific node.- See Also:
 
 
- 
- 
Constructor Details- 
MBeanAccessorpublic MBeanAccessor()Default Constructor.
- 
MBeanAccessorCreate an instance of MBeanAccessor.- Parameters:
- mBeanServerProxy- the- MBeanServerProxyto be used
 
 
- 
- 
Method Details- 
getAttributesReturn all the attributes that match the query expressed by the providedMBeanAccessor.QueryBuilder.Note: the return type is keyed by the full ObjectName registered with the MBeanServer and a Map of attribute name to value - Parameters:
- query- the- MBeanAccessor.QueryBuilder.ParsedQueryto be used to determine applicable MBeans
- Returns:
- a Map keyed by the full ObjectName registered with the MBeanServer and a Map of attribute name to value
 
- 
getAttributespublic Map<String,Map<String, getAttributesObject>> (MBeanAccessor.QueryBuilder.ParsedQuery query, Filter<MBeanAttributeInfo> filter, boolean fAddStorageMBeanAttributes) Return all the attributes that match the query expressed by the providedMBeanAccessor.QueryBuilder.Note: the return type is keyed by the full ObjectName registered with the MBeanServer and a Map of attribute name to value - Parameters:
- query- the- MBeanAccessor.QueryBuilder.ParsedQueryto be used to determine applicable MBeans
- filter- server side filter for what attributes to return
- fAddStorageMBeanAttributes- add storage MBean attributes to CacheMBean tier="back" attributes.
- Returns:
- a Map keyed by the full ObjectName registered with the MBeanServer and a Map of attribute name to value
 
- 
invokepublic Map<String,Object> invoke(MBeanAccessor.QueryBuilder.ParsedQuery query, String sOperationName, Object[] aoArguments, String[] asSignature) Invoke a JMX MBean operation on one or many MBeans determined by the providedMBeanAccessor.QueryBuilder.- Parameters:
- query- the- MBeanAccessor.QueryBuilder.ParsedQueryto be used to determine applicable MBeans
- sOperationName- the name of the operation
- aoArguments- the arguments of the operation
- asSignature- the signature of the operation
- Returns:
- a Map keyed by the full ObjectName registered with the MBeanServer and the value returned by invoking the operation
 
- 
updatepublic Map<String,Map<String, updateObject>> (MBeanAccessor.QueryBuilder.ParsedQuery query, Map<String, Object> mapAttributes) Update all JMX MBeans determined by evaluating the providedMBeanAccessor.QueryBuilder. All attributes in the provided map will be updated on the corresponding MBean(s) iff the attribute is present.A Set of ObjectNames corresponding to the updated MBeans is returned. These MBeans have been updated with the matching attributes provided to this update method. Attributes not present on the targeted MBean are silently ignored unless there are no attributes that match and therefore will be absent from the returned set of ObjectNames. - Parameters:
- query- the- MBeanAccessor.QueryBuilder.ParsedQueryto be used to determine applicable MBeans
- mapAttributes- the attributes to update
- Returns:
- a map keyed by ObjectNames updated with the map of attributes that were updated (based on the attributes present on the MBean)
 
- 
queryKeysReturn a list of MBean ObjectNames determined by the providedMBeanAccessor.QueryBuilder.- Parameters:
- query- the- MBeanAccessor.QueryBuilder.ParsedQueryto be used to determine applicable MBeans
- Returns:
- the Set of MBean ObjectNames
 
- 
aggregatepublic Map<String,Object> aggregate(MBeanAccessor.QueryBuilder.ParsedQuery query, String sLocator, String sAttribute, String sCollector) Process the request for MBean attributes.The requested MBean solely depends on the 'type' input. This may be one of the values specified in the mbean typesconstant.The processing can be modified in three ways: - reducing the data (querying)
- choosing the collector implementation (aggregating)
- select the attributes to return
 If the data is not reduced to a single MBean some attribute level aggregation is applied to the MBeans. By default this aggregation is a list, however each attribute may specify its own default as defined in the serviceorcacheenums.Either all attributes are returned or a single attribute based upon the absence or presence, respectively, of the attribute in the URI. - Parameters:
- query- the- MBeanAccessor.QueryBuilderto be used to generate MBean query
- sLocator- either a regex to be applied against nodeids or a role name
- sAttribute- the attribute to return
- sCollector- the collector to use instead of the default
- Returns:
- a Map of attribute name to attribute value; the attribute value may be the result of an aggregation based upon the request
 
 
-