- java.lang.Object
- 
- com.sun.tools.attach.VirtualMachine
 
- 
 public abstract class VirtualMachine extends Object A Java virtual machine.A VirtualMachinerepresents a Java virtual machine to which this Java virtual machine has attached. The Java virtual machine to which it is attached is sometimes called the target virtual machine, or target VM. An application (typically a tool such as a managemet console or profiler) uses a VirtualMachine to load an agent into the target VM. For example, a profiler tool written in the Java Language might attach to a running application and load its profiler agent to profile the running application.A VirtualMachine is obtained by invoking the attachmethod with an identifier that identifies the target virtual machine. The identifier is implementation-dependent but is typically the process identifier (or pid) in environments where each Java virtual machine runs in its own operating system process. Alternatively, aVirtualMachineinstance is obtained by invoking theattachmethod with aVirtualMachineDescriptorobtained from the list of virtual machine descriptors returned by thelistmethod. Once a reference to a virtual machine is obtained, theloadAgent,loadAgentLibrary, andloadAgentPathmethods are used to load agents into target virtual machine. TheloadAgentmethod is used to load agents that are written in the Java Language and deployed in aJAR file. (Seejava.lang.instrumentfor a detailed description on how these agents are loaded and started). TheloadAgentLibraryandloadAgentPathmethods are used to load agents that are deployed either in a dynamic library or statically linked into the VM and make use of the JVM Tools Interface.In addition to loading agents a VirtualMachine provides read access to the system propertiesin the target VM. This can be useful in some environments where properties such asjava.home,os.name, oros.archare used to construct the path to agent that will be loaded into the target VM.The following example demonstrates how VirtualMachine may be used: // attach to target VM VirtualMachine vm = VirtualMachine.attach("2177"); // start management agent Properties props = new Properties(); props.put("com.sun.management.jmxremote.port", "5000"); vm.startManagementAgent(props); // detach vm.detach();In this example we attach to a Java virtual machine that is identified by the process identifier 2177. Then the JMX management agent is started in the target process using the supplied arguments. Finally, the client detaches from the target VM.A VirtualMachine is safe for use by multiple concurrent threads. - Since:
- 1.6
 
- 
- 
Constructor SummaryConstructors Modifier Constructor Description protectedVirtualMachine(AttachProvider provider, String id)Initializes a new instance of this class.
 - 
Method SummaryAll Methods Static Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description static VirtualMachineattach(VirtualMachineDescriptor vmd)Attaches to a Java virtual machine.static VirtualMachineattach(String id)Attaches to a Java virtual machine.abstract voiddetach()Detach from the virtual machine.booleanequals(Object ob)Tests this VirtualMachine for equality with another object.abstract PropertiesgetAgentProperties()Returns the current agent properties in the target virtual machine.abstract PropertiesgetSystemProperties()Returns the current system properties in the target virtual machine.inthashCode()Returns a hash-code value for this VirtualMachine.Stringid()Returns the identifier for this Java virtual machine.static List<VirtualMachineDescriptor>list()Return a list of Java virtual machines.voidloadAgent(String agent)Loads an agent.abstract voidloadAgent(String agent, String options)Loads an agent.voidloadAgentLibrary(String agentLibrary)Loads an agent library.abstract voidloadAgentLibrary(String agentLibrary, String options)Loads an agent library.voidloadAgentPath(String agentPath)Load a native agent library by full pathname.abstract voidloadAgentPath(String agentPath, String options)Load a native agent library by full pathname.AttachProviderprovider()Returns the provider that created this virtual machine.abstract StringstartLocalManagementAgent()Starts the local JMX management agent in the target virtual machine.abstract voidstartManagementAgent(Properties agentProperties)Starts the JMX management agent in the target virtual machine.StringtoString()Returns the string representation of theVirtualMachine.
 
- 
- 
- 
Constructor Detail- 
VirtualMachineprotected VirtualMachine(AttachProvider provider, String id) Initializes a new instance of this class.- Parameters:
- provider- The attach provider creating this class.
- id- The abstract identifier that identifies the Java virtual machine.
- Throws:
- NullPointerException- If- provideror- idis- null.
 
 
- 
 - 
Method Detail- 
listpublic static List<VirtualMachineDescriptor> list() Return a list of Java virtual machines.This method returns a list of Java VirtualMachineDescriptorelements. The list is an aggregation of the virtual machine descriptor lists obtained by invoking thelistVirtualMachinesmethod of all installedattach providers. If there are no Java virtual machines known to any provider then an empty list is returned.- Returns:
- The list of virtual machine descriptors.
 
 - 
attachpublic static VirtualMachine attach(String id) throws AttachNotSupportedException, IOException Attaches to a Java virtual machine.This method obtains the list of attach providers by invoking the AttachProvider.providers()method. It then iterates overs the list and invokes each provider'sattachVirtualMachinemethod in turn. If a provider successfully attaches then the iteration terminates, and the VirtualMachine created by the provider that successfully attached is returned by this method. If theattachVirtualMachinemethod of all providers throwsAttachNotSupportedExceptionthen this method also throwsAttachNotSupportedException. This means thatAttachNotSupportedExceptionis thrown when the identifier provided to this method is invalid, or the identifier corresponds to a Java virtual machine that does not exist, or none of the providers can attach to it. This exception is also thrown ifAttachProvider.providers()returns an empty list.- Parameters:
- id- The abstract identifier that identifies the Java virtual machine.
- Returns:
- A VirtualMachine representing the target VM.
- Throws:
- SecurityException- If a security manager has been installed and it denies- AttachPermission- ("attachVirtualMachine"), or another permission required by the implementation.
- AttachNotSupportedException- If the- attachVirtualmachinemethod of all installed providers throws- AttachNotSupportedException, or there aren't any providers installed.
- IOException- If an I/O error occurs
- NullPointerException- If- idis- null.
 
 - 
attachpublic static VirtualMachine attach(VirtualMachineDescriptor vmd) throws AttachNotSupportedException, IOException Attaches to a Java virtual machine.This method first invokes the provider()method of the given virtual machine descriptor to obtain the attach provider. It then invokes the attach provider'sattachVirtualMachineto attach to the target VM.- Parameters:
- vmd- The virtual machine descriptor.
- Returns:
- A VirtualMachine representing the target VM.
- Throws:
- SecurityException- If a security manager has been installed and it denies- AttachPermission- ("attachVirtualMachine"), or another permission required by the implementation.
- AttachNotSupportedException- If the attach provider's- attachVirtualmachinethrows- AttachNotSupportedException.
- IOException- If an I/O error occurs
- NullPointerException- If- vmdis- null.
 
 - 
detachpublic abstract void detach() throws IOExceptionDetach from the virtual machine.After detaching from the virtual machine, any further attempt to invoke operations on that virtual machine will cause an IOExceptionto be thrown. If an operation (such asloadAgentfor example) is in progress when this method is invoked then the behaviour is implementation dependent. In other words, it is implementation specific if the operation completes or throwsIOException.If already detached from the virtual machine then invoking this method has no effect. - Throws:
- IOException- If an I/O error occurs
 
 - 
providerpublic final AttachProvider provider() Returns the provider that created this virtual machine.- Returns:
- The provider that created this virtual machine.
 
 - 
idpublic final String id() Returns the identifier for this Java virtual machine.- Returns:
- The identifier for this Java virtual machine.
 
 - 
loadAgentLibrarypublic abstract void loadAgentLibrary(String agentLibrary, String options) throws AgentLoadException, AgentInitializationException, IOException Loads an agent library.A JVM TI client is called an agent. It is developed in a native language. A JVM TI agent is deployed in a platform specific manner but it is typically the platform equivalent of a dynamic library. Alternatively, it may be statically linked into the VM. This method causes the given agent library to be loaded into the target VM (if not already loaded or if not statically linked into the VM). It then causes the target VM to invoke the Agent_OnAttachfunction or, for a statically linked agent named 'L', theAgent_OnAttach_Lfunction as specified in the JVM Tools Interface specification. Note that theAgent_OnAttach[_L]function is invoked even if the agent library was loaded prior to invoking this method.The agent library provided is the name of the agent library. It is interpreted in the target virtual machine in an implementation-dependent manner. Typically an implementation will expand the library name into an operating system specific file name. For example, on UNIX systems, the name Lmight be expanded tolibL.so, and located using the search path specified by theLD_LIBRARY_PATHenvironment variable. If the agent named 'L' is statically linked into the VM then the VM must export a function namedAgent_OnAttach_L.If the Agent_OnAttach[_L]function in the agent library returns an error then anAgentInitializationExceptionis thrown. The return value from theAgent_OnAttach[_L]can then be obtained by invoking thereturnValuemethod on the exception.- Parameters:
- agentLibrary- The name of the agent library.
- options- The options to provide to the- Agent_OnAttach[_L]function (can be- null).
- Throws:
- AgentLoadException- If the agent library does not exist, the agent library is not statically linked with the VM, or the agent library cannot be loaded for another reason.
- AgentInitializationException- If the- Agent_OnAttach[_L]function returns an error.
- IOException- If an I/O error occurs
- NullPointerException- If- agentLibraryis- null.
- See Also:
- AgentInitializationException.returnValue()
 
 - 
loadAgentLibrarypublic void loadAgentLibrary(String agentLibrary) throws AgentLoadException, AgentInitializationException, IOException Loads an agent library.This convenience method works as if by invoking: loadAgentLibrary(agentLibrary, null);- Parameters:
- agentLibrary- The name of the agent library.
- Throws:
- AgentLoadException- If the agent library does not exist, the agent library is not statically linked with the VM, or the agent library cannot be loaded for another reason.
- AgentInitializationException- If the- Agent_OnAttach[_L]function returns an error.
- IOException- If an I/O error occurs
- NullPointerException- If- agentLibraryis- null.
 
 - 
loadAgentPathpublic abstract void loadAgentPath(String agentPath, String options) throws AgentLoadException, AgentInitializationException, IOException Load a native agent library by full pathname.A JVM TI client is called an agent. It is developed in a native language. A JVM TI agent is deployed in a platform specific manner but it is typically the platform equivalent of a dynamic library. Alternatively, the native library specified by the agentPath parameter may be statically linked with the VM. The parsing of the agentPath parameter into a statically linked library name is done in a platform specific manner in the VM. For example, in UNIX, an agentPath parameter of /a/b/libL.sowould name a library 'L'. See the JVM TI Specification for more details. This method causes the given agent library to be loaded into the target VM (if not already loaded or if not statically linked into the VM). It then causes the target VM to invoke theAgent_OnAttachfunction or, for a statically linked agent named 'L', theAgent_OnAttach_Lfunction as specified in the JVM Tools Interface specification. Note that theAgent_OnAttach[_L]function is invoked even if the agent library was loaded prior to invoking this method.The agent library provided is the absolute path from which to load the agent library. Unlike loadAgentLibrary, the library name is not expanded in the target virtual machine.If the Agent_OnAttach[_L]function in the agent library returns an error then anAgentInitializationExceptionis thrown. The return value from theAgent_OnAttach[_L]can then be obtained by invoking thereturnValuemethod on the exception.- Parameters:
- agentPath- The full path of the agent library.
- options- The options to provide to the- Agent_OnAttach[_L]function (can be- null).
- Throws:
- AgentLoadException- If the agent library does not exist, the agent library is not statically linked with the VM, or the agent library cannot be loaded for another reason.
- AgentInitializationException- If the- Agent_OnAttach[_L]function returns an error.
- IOException- If an I/O error occurs
- NullPointerException- If- agentPathis- null.
- See Also:
- AgentInitializationException.returnValue()
 
 - 
loadAgentPathpublic void loadAgentPath(String agentPath) throws AgentLoadException, AgentInitializationException, IOException Load a native agent library by full pathname.This convenience method works as if by invoking: loadAgentPath(agentLibrary, null);- Parameters:
- agentPath- The full path to the agent library.
- Throws:
- AgentLoadException- If the agent library does not exist, the agent library is not statically linked with the VM, or the agent library cannot be loaded for another reason.
- AgentInitializationException- If the- Agent_OnAttach[_L]function returns an error.
- IOException- If an I/O error occurs
- NullPointerException- If- agentPathis- null.
 
 - 
loadAgentpublic abstract void loadAgent(String agent, String options) throws AgentLoadException, AgentInitializationException, IOException Loads an agent.The agent provided to this method is a path name to a JAR file on the file system of the target virtual machine. This path is passed to the target virtual machine where it is interpreted. The target virtual machine attempts to start the agent as specified by the java.lang.instrumentspecification. That is, the specified JAR file is added to the system class path (of the target virtual machine), and theagentmainmethod of the agent class, specified by theAgent-Classattribute in the JAR manifest, is invoked. This method completes when theagentmainmethod completes.- Parameters:
- agent- Path to the JAR file containing the agent.
- options- The options to provide to the agent's- agentmainmethod (can be- null).
- Throws:
- AgentLoadException- If the agent does not exist, or cannot be started in the manner specified in the- java.lang.instrumentspecification.
- AgentInitializationException- If the- agentmainthrows an exception
- IOException- If an I/O error occurs
- NullPointerException- If- agentis- null.
 
 - 
loadAgentpublic void loadAgent(String agent) throws AgentLoadException, AgentInitializationException, IOException Loads an agent.This convenience method works as if by invoking: loadAgent(agent, null);- Parameters:
- agent- Path to the JAR file containing the agent.
- Throws:
- AgentLoadException- If the agent does not exist, or cannot be started in the manner specified in the- java.lang.instrumentspecification.
- AgentInitializationException- If the- agentmainthrows an exception
- IOException- If an I/O error occurs
- NullPointerException- If- agentis- null.
 
 - 
getSystemPropertiespublic abstract Properties getSystemProperties() throws IOException Returns the current system properties in the target virtual machine.This method returns the system properties in the target virtual machine. Properties whose key or value is not a Stringare omitted. The method is approximately equivalent to the invocation of the methodSystem.getPropertiesin the target virtual machine except that properties with a key or value that is not aStringare not included.This method is typically used to decide which agent to load into the target virtual machine with loadAgent, orloadAgentLibrary. For example, thejava.homeoruser.dirproperties might be use to create the path to the agent library or JAR file.- Returns:
- The system properties
- Throws:
- AttachOperationFailedException- If the target virtual machine is unable to complete the attach operation. A more specific error message will be given by- Throwable.getMessage().
- IOException- If an I/O error occurs, a communication error for example, that cannot be identified as an error to indicate that the operation failed in the target VM.
- See Also:
- System.getProperties(),- loadAgentLibrary(java.lang.String, java.lang.String),- loadAgent(java.lang.String, java.lang.String)
 
 - 
getAgentPropertiespublic abstract Properties getAgentProperties() throws IOException Returns the current agent properties in the target virtual machine.The target virtual machine can maintain a list of properties on behalf of agents. The manner in which this is done, the names of the properties, and the types of values that are allowed, is implementation specific. Agent properties are typically used to store communication end-points and other agent configuration details. For example, a debugger agent might create an agent property for its transport address. This method returns the agent properties whose key and value is a String. Properties whose key or value is not aStringare omitted. If there are no agent properties maintained in the target virtual machine then an empty property list is returned.- Returns:
- The agent properties
- Throws:
- AttachOperationFailedException- If the target virtual machine is unable to complete the attach operation. A more specific error message will be given by- Throwable.getMessage().
- IOException- If an I/O error occurs, a communication error for example, that cannot be identified as an error to indicate that the operation failed in the target VM.
 
 - 
startManagementAgentpublic abstract void startManagementAgent(Properties agentProperties) throws IOException Starts the JMX management agent in the target virtual machine.The configuration properties are the same as those specified on the command line when starting the JMX management agent. In the same way as on the command line, you need to specify at least the com.sun.management.jmxremote.portproperty.See the online documentation for Monitoring and Management Using JMX Technology for further details. - Parameters:
- agentProperties- A Properties object containing the configuration properties for the agent.
- Throws:
- AttachOperationFailedException- If the target virtual machine is unable to complete the attach operation. A more specific error message will be given by- Throwable.getMessage().
- IOException- If an I/O error occurs, a communication error for example, that cannot be identified as an error to indicate that the operation failed in the target VM.
- IllegalArgumentException- If keys or values in agentProperties are invalid.
- NullPointerException- If agentProperties is null.
- Since:
- 1.8
 
 - 
startLocalManagementAgentpublic abstract String startLocalManagementAgent() throws IOException Starts the local JMX management agent in the target virtual machine.See the online documentation for Monitoring and Management Using JMX Technology for further details. - Returns:
- The String representation of the local connector's service address.
          The value can be parsed by the
          JMXServiceURL(String)constructor.
- Throws:
- AttachOperationFailedException- If the target virtual machine is unable to complete the attach operation. A more specific error message will be given by- Throwable.getMessage().
- IOException- If an I/O error occurs, a communication error for example, that cannot be identified as an error to indicate that the operation failed in the target VM.
- Since:
- 1.8
 
 - 
hashCodepublic int hashCode() Returns a hash-code value for this VirtualMachine. The hash code is based upon the VirtualMachine's components, and satifies the general contract of theObject.hashCodemethod.- Overrides:
- hashCodein class- Object
- Returns:
- A hash-code value for this virtual machine
- See Also:
- Object.equals(java.lang.Object)
 
 - 
equalspublic boolean equals(Object ob) Tests this VirtualMachine for equality with another object.If the given object is not a VirtualMachine then this method returns false. For two VirtualMachines to be considered equal requires that they both reference the same provider, and theiridentifiersare equal.This method satisfies the general contract of the Object.equalsmethod.- Overrides:
- equalsin class- Object
- Parameters:
- ob- The object to which this object is to be compared
- Returns:
- trueif, and only if, the given object is a VirtualMachine that is equal to this VirtualMachine.
- See Also:
- Object.hashCode()
 
 
- 
 
-