Save This Page
Home » openjdk-7 » javax » management » remote » rmi » [javadoc | source]
javax.management.remote.rmi
public class: RMIConnectorServer [javadoc | source]
java.lang.Object
   javax.management.NotificationBroadcasterSupport
      javax.management.remote.JMXConnectorServer
         javax.management.remote.rmi.RMIConnectorServer

All Implemented Interfaces:
    JMXAddressable, MBeanRegistration, JMXConnectorServerMBean, NotificationEmitter

A JMX API connector server that creates RMI-based connections from remote clients. Usually, such connector servers are made using JMXConnectorServerFactory . However, specialized applications can use this class directly, for example with an RMIServerImpl object.

Field Summary
public static final  String JNDI_REBIND_ATTRIBUTE   

Name of the attribute that specifies whether the RMIServer stub that represents an RMI connector server should override an existing stub at the same address. The value associated with this attribute, if any, should be a string that is equal, ignoring case, to "true" or "false". The default value is false.

 
public static final  String RMI_CLIENT_SOCKET_FACTORY_ATTRIBUTE   

Name of the attribute that specifies the RMIClientSocketFactory for the RMI objects created in conjunction with this connector. The value associated with this attribute must be of type RMIClientSocketFactory and can only be specified in the Map argument supplied when creating a connector server.

 
public static final  String RMI_SERVER_SOCKET_FACTORY_ATTRIBUTE   

Name of the attribute that specifies the RMIServerSocketFactory for the RMI objects created in conjunction with this connector. The value associated with this attribute must be of type RMIServerSocketFactory and can only be specified in the Map argument supplied when creating a connector server.

 
Fields inherited from javax.management.remote.JMXConnectorServer:
AUTHENTICATOR
Constructor:
 public RMIConnectorServer(JMXServiceURL url,
    Map environment) throws IOException 
    Parameters:
    url - the URL defining how to create the connector server. Cannot be null.
    environment - attributes governing the creation and storing of the RMI object. Can be null, which is equivalent to an empty Map.
    Throws:
    IllegalArgumentException - if url is null.
    MalformedURLException - if url does not conform to the syntax for an RMI connector, or if its protocol is not recognized by this implementation. Only "rmi" and "iiop" are valid when this constructor is used.
    IOException - if the connector server cannot be created for some reason or if it is inevitable that its start method will fail.
    exception: IllegalArgumentException - if url is null.
    exception: MalformedURLException - if url does not conform to the syntax for an RMI connector, or if its protocol is not recognized by this implementation. Only "rmi" and "iiop" are valid when this constructor is used.
    exception: IOException - if the connector server cannot be created for some reason or if it is inevitable that its start method will fail.
 public RMIConnectorServer(JMXServiceURL url,
    Map environment,
    MBeanServer mbeanServer) throws IOException 
    Parameters:
    url - the URL defining how to create the connector server. Cannot be null.
    environment - attributes governing the creation and storing of the RMI object. Can be null, which is equivalent to an empty Map.
    mbeanServer - the MBean server to which the new connector server is attached, or null if it will be attached by being registered as an MBean in the MBean server.
    Throws:
    IllegalArgumentException - if url is null.
    MalformedURLException - if url does not conform to the syntax for an RMI connector, or if its protocol is not recognized by this implementation. Only "rmi" and "iiop" are valid when this constructor is used.
    IOException - if the connector server cannot be created for some reason or if it is inevitable that its start method will fail.
    exception: IllegalArgumentException - if url is null.
    exception: MalformedURLException - if url does not conform to the syntax for an RMI connector, or if its protocol is not recognized by this implementation. Only "rmi" and "iiop" are valid when this constructor is used.
    exception: IOException - if the connector server cannot be created for some reason or if it is inevitable that its start method will fail.
 public RMIConnectorServer(JMXServiceURL url,
    Map environment,
    RMIServerImpl rmiServerImpl,
    MBeanServer mbeanServer) throws IOException 

    Makes an RMIConnectorServer for the given MBean server.

    Parameters:
    url - the URL defining how to create the connector server. Cannot be null.
    environment - attributes governing the creation and storing of the RMI object. Can be null, which is equivalent to an empty Map.
    rmiServerImpl - An implementation of the RMIServer interface, consistent with the protocol type specified in url. If this parameter is non null, the protocol type specified by url is not constrained, and is assumed to be valid. Otherwise, only "rmi" and "iiop" will be recognized.
    mbeanServer - the MBean server to which the new connector server is attached, or null if it will be attached by being registered as an MBean in the MBean server.
    Throws:
    IllegalArgumentException - if url is null.
    MalformedURLException - if url does not conform to the syntax for an RMI connector, or if its protocol is not recognized by this implementation. Only "rmi" and "iiop" are recognized when rmiServerImpl is null.
    IOException - if the connector server cannot be created for some reason or if it is inevitable that its start method will fail.
    Also see:
    start
    exception: IllegalArgumentException - if url is null.
    exception: MalformedURLException - if url does not conform to the syntax for an RMI connector, or if its protocol is not recognized by this implementation. Only "rmi" and "iiop" are recognized when rmiServerImpl is null.
    exception: IOException - if the connector server cannot be created for some reason or if it is inevitable that its start method will fail.
Method from javax.management.remote.rmi.RMIConnectorServer Summary:
bind,   connectionClosed,   connectionFailed,   connectionOpened,   encodeIIOPStub,   encodeJRMPStub,   encodeStub,   getAddress,   getAttributes,   isActive,   isIiopURL,   newServer,   setMBeanServerForwarder,   start,   stop,   toJMXConnector
Methods from javax.management.remote.JMXConnectorServer:
connectionClosed,   connectionFailed,   connectionOpened,   getConnectionIds,   getMBeanServer,   getNotificationInfo,   postDeregister,   postRegister,   preDeregister,   preRegister,   setMBeanServerForwarder,   toJMXConnector
Methods from javax.management.NotificationBroadcasterSupport:
addNotificationListener,   getNotificationInfo,   handleNotification,   removeNotificationListener,   removeNotificationListener,   sendNotification
Methods from java.lang.Object:
clone,   equals,   finalize,   getClass,   hashCode,   notify,   notifyAll,   toString,   wait,   wait,   wait
Method from javax.management.remote.rmi.RMIConnectorServer Detail:
  void bind(String jndiUrl,
    Hashtable attributes,
    RMIServer rmiServer,
    boolean rebind) throws MalformedURLException, NamingException 
    Bind a stub to a registry.
 protected  void connectionClosed(String connectionId,
    String message,
    Object userData) 
 protected  void connectionFailed(String connectionId,
    String message,
    Object userData) 
 protected  void connectionOpened(String connectionId,
    String message,
    Object userData) 
 static String encodeIIOPStub(RMIServer rmiServer,
    Map env) throws IOException 
 static String encodeJRMPStub(RMIServer rmiServer,
    Map env) throws IOException 
 static String encodeStub(RMIServer rmiServer,
    Map env) throws IOException 
    Returns the IOR of the given rmiServer.
 public JMXServiceURL getAddress() 
 public Map getAttributes() 
 public synchronized boolean isActive() 
 static boolean isIiopURL(JMXServiceURL directoryURL,
    boolean strict) throws MalformedURLException 
 RMIServerImpl newServer() throws IOException 
    Creates a new RMIServerImpl.
 public synchronized  void setMBeanServerForwarder(MBeanServerForwarder mbsf) 
 public synchronized  void start() throws IOException 

    Activates the connector server, that is starts listening for client connections. Calling this method when the connector server is already active has no effect. Calling this method when the connector server has been stopped will generate an IOException.

    The behavior of this method when called for the first time depends on the parameters that were supplied at construction, as described below.

    First, an object of a subclass of RMIServerImpl is required, to export the connector server through RMI:

    • If an RMIServerImpl was supplied to the constructor, it is used.
    • Otherwise, if the protocol part of the JMXServiceURL supplied to the constructor was iiop, an object of type RMIIIOPServerImpl is created.
    • Otherwise, if the JMXServiceURL was null, or its protocol part was rmi, an object of type RMIJRMPServerImpl is created.
    • Otherwise, the implementation can create an implementation-specific RMIServerImpl or it can throw MalformedURLException .

    If the given address includes a JNDI directory URL as specified in the package documentation for javax.management.remote.rmi , then this RMIConnectorServer will bootstrap by binding the RMIServerImpl to the given address.

    If the URL path part of the JMXServiceURL was empty or a single slash (/), then the RMI object will not be bound to a directory. Instead, a reference to it will be encoded in the URL path of the RMIConnectorServer address (returned by #getAddress() ). The encodings for rmi and iiop are described in the package documentation for javax.management.remote.rmi .

    The behavior when the URL path is neither empty nor a JNDI directory URL, or when the protocol is neither rmi nor iiop, is implementation defined, and may include throwing MalformedURLException when the connector server is created or when it is started.

 public  void stop() throws IOException 

    Deactivates the connector server, that is, stops listening for client connections. Calling this method will also close all client connections that were made by this server. After this method returns, whether normally or with an exception, the connector server will not create any new client connections.

    Once a connector server has been stopped, it cannot be started again.

    Calling this method when the connector server has already been stopped has no effect. Calling this method when the connector server has not yet been started will disable the connector server object permanently.

    If closing a client connection produces an exception, that exception is not thrown from this method. A JMXConnectionNotification is emitted from this MBean with the connection ID of the connection that could not be closed.

    Closing a connector server is a potentially slow operation. For example, if a client machine with an open connection has crashed, the close operation might have to wait for a network protocol timeout. Callers that do not want to block in a close operation should do it in a separate thread.

    This method calls the method close on the connector server's RMIServerImpl object.

    If the RMIServerImpl was bound to a JNDI directory by the start method, it is unbound from the directory by this method.

 public JMXConnector toJMXConnector(Map env) throws IOException 

    Returns a client stub for this connector server. A client stub is a serializable object whose connect method can be used to make one new connection to this connector server.