|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object | +--java.lang.ClassLoader | +--java.security.SecureClassLoader | +--java.net.URLClassLoader | +--javax.management.loading.MLet
Allows you to instantiate and register one or several MBeans in the MBean server coming from a remote URL. M-let is a shortcut for management applet. The m-let service does this by loading an m-let text file, which specifies information on the MBeans to be obtained. The information on each MBean is specified in a single instance of a tag, called the MLET tag The location of the m-let text file is specified by a URL.
The MLET tag has the following syntax:
< MLET
CODE = class | OBJECT = serfile
ARCHIVE = "archiveList"
[CODEBASE = codebaseURL]
[NAME = mbeanname]
[VERSION = version]
>
[arglist]
< /MLET>
where:
CODE = class
This attribute specifies the full Java class name, including package name,
of the MBean to be obtained. The compiled .class file of the MBean must be
contained in one of the .jar files specified by the ARCHIVE attribute.
Either CODE or OBJECT must be present.
OBJECT = serfile
This attribute specifies the .ser file that contains a serialized
representation of the MBean to be obtained. This file must be contained
in one of the .jar files specified by the ARCHIVE attribute. If the .jar
file contains a directory hierarchy, specify the path of the file within
this hierarchy. Otherwise a match will not be found. Either CODE or OBJECT
must be present.
ARCHIVE = "archiveList"
This mandatory attribute specifies one or more .jar files containing
MBeans or other resources used by the MBean to be obtained. One of the
.jar files must contain the file specified by the CODE or OBJECT attribute.
If archivelist contains more than one file:
Each file must be separated from the one that follows it by a comma (,).
archivelist must be enclosed in double quote marks.
All .jar files in archivelist must be stored in the directory specified
by the code base URL.
CODEBASE = codebaseURL
This optional attribute specifies the code base URL of the MBean to be
obtained. It identifies the directory that contains the .jar files
specified by the ARCHIVE attribute. Specify this attribute only if the
.jar files are not in the same directory as the m-let text file. If this
attribute is not specified, the base URL of the m-let text file is used.
NAME = mbeanname
This optional attribute specifies the object name to be assigned to the
MBean instance when the m-let service registers it. If mbeanname starts
with the colon character (:), the domain part of the object name is the
domain of the agent. The m-let service invokes the getDomain() method of
the Framework class to obtain this information.
VERSION = version
This optional attribute specifies the version number of the MBean and
associated .jar files to be obtained. This version number can be used to
specify that the .jar files are loaded from the server to update those
stored locally in the cache the next time the m-let text file is loaded.
version must be a series of non-negative decimal integers each separated
by a period from the one that precedes it.
arglist
This optional attribute specifies a list of one or more parameters for
the MBean to be instantiated. This list describes the parameters to be
passed the MBean's constructor. Use the following syntax to specify each
item in arglist:
< ARG TYPE=argumentType VALUE=value>
where argumentType is the type of the argument that will be
passed as parameter to the MBean's constructor.
The arguments' type in the argument list should be a Java primitive
type or a Java basic type (java.lang.Boolean,
java.lang.Byte, java.lang.Short
,
java.lang.Long, java.lang.Integer
,
java.lang.Float, java.lang.Double
,
java.lang.String).
When an m-let text file is loaded, an instance of each MBean specified in the file is created and registered. The m-let Service extends the java.net.URLClassLoader and can be used to load remote classes and jar files in the VM of the agent.
Note - The MLet class loader uses the DefaultLoaderRepository to load classes that could not be found in the loaded jar files.
Constructor Summary | |
MLet()
Constructs a new MLet using the default delegation parent ClassLoader. |
|
MLet(java.net.URL[] urls)
Constructs a new MLet for the specified URLs using the default delegation parent ClassLoader. |
|
MLet(java.net.URL[] urls,
java.lang.ClassLoader parent)
Constructs a new MLet for the given URLs. |
|
MLet(java.net.URL[] urls,
java.lang.ClassLoader parent,
java.net.URLStreamHandlerFactory factory)
Constructs a new MLet for the specified URLs, parent class loader, and URLStreamHandlerFactory. |
Method Summary | |
void |
addURL(java.lang.String url)
Appends the specified URL to the list of URLs to search for classes and resources. |
void |
addURL(java.net.URL url)
Appends the specified URL to the list of URLs to search for classes and resources. |
protected java.lang.Class |
findClass(java.lang.String name)
This is the main method for class loaders that is being redefined. |
protected java.lang.String |
findLibrary(java.lang.String libname)
Returns the absolute path name of a native library. |
java.lang.String |
getLibraryDirectory()
Gets the current directory used by the library loader for storing native libraries before they are loaded into memory. |
java.util.Set |
getMBeansFromURL(java.lang.String url)
Loads a text file containing MLET tags that define the MBeans to be added to the agent. |
java.util.Set |
getMBeansFromURL(java.net.URL url)
Loads a text file containing MLET tags that define the MBeans to be added to the agent. |
java.net.URL[] |
getURLs()
Returns the search path of URLs for loading classes and resources. |
void |
postDeregister()
Allows the m-let to perform any operations needed after having been de-registered in the MBean server. |
void |
postRegister(java.lang.Boolean registrationDone)
Allows the m-let to perform any operations needed after having been registered in the MBean server or after the registration has failed. |
void |
preDeregister()
Allows the m-let to perform any operations it needs before being de-registered by the MBean server. |
ObjectName |
preRegister(MBeanServer server,
ObjectName name)
Allows the m-let to perform any operations it needs before being registered in the MBean server. |
void |
readExternal(java.io.ObjectInput in)
This method reads the object's contents during Object Serialization. |
void |
setLibraryDirectory(java.lang.String libdir)
Sets the directory used by the library loader for storing native libraries before they are loaded into memory. |
void |
writeExternal(java.io.ObjectOutput out)
This method saves the object's contents during Object Serialization. |
Methods inherited from class java.net.URLClassLoader |
definePackage,
findResource,
findResources,
getPermissions,
newInstance,
newInstance |
Methods inherited from class java.security.SecureClassLoader |
defineClass |
Methods inherited from class java.lang.ClassLoader |
defineClass,
defineClass,
defineClass,
definePackage,
findLoadedClass,
findSystemClass,
getPackage,
getPackages,
getParent,
getResource,
getResourceAsStream,
getResources,
getSystemClassLoader,
getSystemResource,
getSystemResourceAsStream,
getSystemResources,
loadClass,
loadClass,
resolveClass,
setSigners |
Methods inherited from class java.lang.Object |
clone,
equals,
finalize,
getClass,
hashCode,
notify,
notifyAll,
toString,
wait,
wait,
wait |
Constructor Detail |
public MLet()
public MLet(java.net.URL[] urls)
urls
- The URLs from which to load classes and resources.public MLet(java.net.URL[] urls, java.lang.ClassLoader parent)
urls
- The URLs from which to load classes and resources.parent
- The parent class loader for delegation.public MLet(java.net.URL[] urls, java.lang.ClassLoader parent, java.net.URLStreamHandlerFactory factory)
urls
- The URLs from which to load classes and resources.parent
- The parent class loader for delegation.factory
- The URLStreamHandlerFactory to use when creating URLs.Method Detail |
public void addURL(java.lang.String url) throws ServiceNotFoundException
url
- the URL to be appendedpublic void addURL(java.net.URL url)
url
- the URL to be appendedpublic java.net.URL[] getURLs()
protected java.lang.Class findClass(java.lang.String name) throws java.lang.ClassNotFoundException
name
- The name of the class.protected java.lang.String findLibrary(java.lang.String libname)
1 libstat.so
2 SunOS/sparc/5.7/lib/libstat.so
the library stat on Windows NT 4.0 will be searched in the JAR file as:1 stat.dll
2 WindowsNT/x86/4.0/lib/stat.dll
If this method returns null, i.e. the libraries were not found in any of the JAR files loaded with this class loader, the VM searches the library along the path specified as the java.library.path property. If the library is found inside one of the JAR files, it will be copied locally in the directory set by a previous call to setLibraryDirectory, provided that this call has been done and that we can write into it. If the library already exists in the specified directory, it will not be copied again.libname
- The library name.public java.lang.String getLibraryDirectory()
public void setLibraryDirectory(java.lang.String libdir)
libdir
- The directory used by the library loader.public java.util.Set getMBeansFromURL(java.lang.String url) throws ServiceNotFoundException
url
- The URL of the text file to be loaded as String object.public java.util.Set getMBeansFromURL(java.net.URL url) throws ServiceNotFoundException
url
- The URL of the text file to be loaded as String object.public ObjectName preRegister(MBeanServer server, ObjectName name)
server
- The MBean server in which the m-let will be registered.name
- The object name of the m-let.public void postRegister(java.lang.Boolean registrationDone)
registrationDone
- Indicates whether or not the m-let has been
successfully registered in the MBean server. The value false
means that either the registration phase has failed.public void preDeregister() throws java.lang.Exception
public void postDeregister()
public void readExternal(java.io.ObjectInput in) throws java.io.IOException, java.lang.ClassNotFoundException
in
- The serialization input stream.public void writeExternal(java.io.ObjectOutput out) throws java.io.IOException
out
- - The serialization output stream.
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |