This documentation differs from the official API. Jadeite adds extra features to the API including: variable font sizes, constructions examples, placeholders for classes and methods, and auto-generated “See Also” links. Additionally it is missing some items found in standard Javadoc documentation, including: generics type information, “Deprecated” tags and comments, “See Also” links, along with other minor differences. Please send any questions or feedback to bam@cs.cmu.edu.


java.rmi.registry
interface Registry

All Superinterfaces:
Remote

Most common ways to construct:

Registry registry = LocateRegistry.getRegistry();

Based on 23 examples

 

Registry registry = LocateRegistry.getRegistry(2002);

Based on 22 examples

 

String host = …;
int port = …;

Registry registry = LocateRegistry.getRegistry(host, port);

Based on 20 examples


public interface Registry
extends Remote

Registry is a remote interface to a simple remote object registry that provides methods for storing and retrieving remote object references bound with arbitrary string names. The bind, unbind, and rebind methods are used to alter the name bindings in the registry, and the lookup and list methods are used to query the current name bindings.

In its typical usage, a Registry enables RMI client bootstrapping: it provides a simple means for a client to obtain an initial reference to a remote object. Therefore, a registry's remote object implementation is typically exported with a well-known address, such as with a well-known {@link java.rmi.server.ObjID#REGISTRY_ID ObjID} and TCP port number (default is {@link #REGISTRY_PORT 1099}).

The {@link LocateRegistry} class provides a programmatic API for constructing a bootstrap reference to a Registry at a remote address (see the static getRegistry methods) and for creating and exporting a Registry in the current VM on a particular local address (see the static createRegistry methods).

A Registry implementation may choose to restrict access to some or all of its methods (for example, methods that mutate the registry's bindings may be restricted to calls originating from the local host). If a Registry method chooses to deny access for a given invocation, its implementation may throw {@link java.rmi.AccessException}, which (because it extends {@link java.rmi.RemoteException}) will be wrapped in a {@link java.rmi.ServerException} when caught by a remote client.

The names used for bindings in a Registry are pure strings, not parsed. A service which stores its remote reference in a Registry may wish to use a package name as a prefix in the name binding to reduce the likelihood of name collisions in the registry.


Field Summary
static int REGISTRY_PORT
          Well known port for registry.
 
Method Summary
 void
bind(String name, Remote obj)

          Binds a remote reference to the specified name in this registry.
 String[]

          Returns an array of the names bound in this registry.
 Remote
lookup(String name)

          Returns the remote reference bound to the specified name in this registry.
 void
rebind(String name, Remote obj)

          Replaces the binding for the specified name in this registry with the supplied remote reference.
 void
unbind(String name)

          Removes the binding for the specified name in this registry.
 

Field Detail

REGISTRY_PORT

public static final int REGISTRY_PORT
Well known port for registry.
Method Detail

bind

public void bind(String name,
                 Remote obj)
          throws RemoteException,
                 AlreadyBoundException,
                 AccessException
Binds a remote reference to the specified name in this registry.

Parameters:
name - the name to associate with the remote reference
obj - a reference to a remote object (usually a stub)
Throws:
RemoteException - if remote communication with the registry failed; if exception is a ServerException containing an AccessException, then the registry denies the caller access to perform this operation (if originating from a non-local host, for example)
AlreadyBoundException - if name is already bound
AccessException - if this registry is local and it denies the caller access to perform this operation

list

public String[] list()
              throws RemoteException,
                     AccessException
Returns an array of the names bound in this registry. The array will contain a snapshot of the names bound in this registry at the time of the given invocation of this method.

Returns:
an array of the names bound in this registry
Throws:
RemoteException - if remote communication with the registry failed; if exception is a ServerException containing an AccessException, then the registry denies the caller access to perform this operation
AccessException - if this registry is local and it denies the caller access to perform this operation

lookup

public Remote lookup(String name)
              throws RemoteException,
                     NotBoundException,
                     AccessException
Returns the remote reference bound to the specified name in this registry.

Parameters:
name - the name for the remote reference to look up
Returns:
a reference to a remote object
Throws:
RemoteException - if remote communication with the registry failed; if exception is a ServerException containing an AccessException, then the registry denies the caller access to perform this operation
NotBoundException - if name is not currently bound
AccessException - if this registry is local and it denies the caller access to perform this operation

rebind

public void rebind(String name,
                   Remote obj)
            throws RemoteException,
                   AccessException
Replaces the binding for the specified name in this registry with the supplied remote reference. If there is an existing binding for the specified name, it is discarded.

Parameters:
name - the name to associate with the remote reference
obj - a reference to a remote object (usually a stub)
Throws:
RemoteException - if remote communication with the registry failed; if exception is a ServerException containing an AccessException, then the registry denies the caller access to perform this operation (if originating from a non-local host, for example)
AccessException - if this registry is local and it denies the caller access to perform this operation

unbind

public void unbind(String name)
            throws RemoteException,
                   NotBoundException,
                   AccessException
Removes the binding for the specified name in this registry.

Parameters:
name - the name of the binding to remove
Throws:
RemoteException - if remote communication with the registry failed; if exception is a ServerException containing an AccessException, then the registry denies the caller access to perform this operation (if originating from a non-local host, for example)
NotBoundException - if name is not currently bound
AccessException - if this registry is local and it denies the caller access to perform this operation


This documentation differs from the official API. Jadeite adds extra features to the API including: variable font sizes, constructions examples, placeholders for classes and methods, and auto-generated “See Also” links. Additionally it is missing some items found in standard Javadoc documentation, including: generics type information, “Deprecated” tags and comments, “See Also” links, along with other minor differences. Please send any questions or feedback to bam@cs.cmu.edu.
This page displays the Jadeite version of the documention, which is derived from the offical documentation that contains this copyright notice:
Copyright 2008 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.
The official Sun™ documentation can be found here at http://java.sun.com/javase/6/docs/api/.