Package com.tangosol.net
Class ConfigurableAddressProvider
- java.lang.Object
- 
- java.util.AbstractCollection<E>
- 
- java.util.AbstractSet
- 
- com.tangosol.net.ConfigurableAddressProvider
 
 
 
- 
- All Implemented Interfaces:
- AddressProvider,- DescribableAddressProvider,- SocketAddressProvider,- Iterable,- Collection,- Set
 - Direct Known Subclasses:
- ConfigurableLocalAddressProvider
 
 public class ConfigurableAddressProvider extends AbstractSet implements DescribableAddressProvider ConfigurableAddressProvider is an implementation of the AddressProvider interface based on a static list of addresses configured in an XML element that contains one or more items in the following format:<socket-address> <address>...</address> <port>...</port> </socket-address> ... <address>...</address> The order of items in the configured list will be randomized to provide basic load balancing.This implementation is not thread safe. - Since:
- Coherence 3.4
- Author:
- gg 2008-08-18
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classConfigurableAddressProvider.AddressHolderA stateful holder for an obtaining an InetSocketAddress object.
 - 
Field SummaryFields Modifier and Type Field Description booleanm_fResolveDeprecated.protected booleanm_fSafeSpecifies if the provider is only to return resolved addresses.protected intm_iLastIndex of the last returned address.protected Iterator<InetSocketAddress>m_iterAddrAn address iterator for the previously resolved address.protected List<ConfigurableAddressProvider.AddressHolder>m_listHoldersA read-only list of ProvidedAddress objects.
 - 
Constructor SummaryConstructors Constructor Description ConfigurableAddressProvider(XmlElement xmlConfig)Deprecated.ConfigurableAddressProvider(XmlElement xmlConfig, boolean fSafe)Deprecated.ConfigurableAddressProvider(Iterable<ConfigurableAddressProvider.AddressHolder> addressHolders, boolean fSafe)Constructs aConfigurableAddressProviderusing the specifiedConfigurableAddressProvider.AddressHolders.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voidaccept()This method should be called by the client immediately after it determines that it can successfully use an address returned by theSocketAddressProvider.getNextAddress()method.protected voidconfigure(XmlElement xmlConfig)Deprecated.booleanequals(Object o)AddressProvider instances should compare to be equals() iff they should be expected to consistently produce the same resulting set of addresses.String[]getAddressDescriptions()Retrieve a human readable description of underlying addresses.InetSocketAddressgetNextAddress()Covariant ofSocketAddressProvider.getNextAddress()which returns anInetSocketAddress.inthashCode()Return the hash code for this AddressProvider.Iteratoriterator()Returns an iterator over the elements contained in this collection.static AddressProvidermakeProvider(XmlElement xmlConfig)Deprecated.voidreject(Throwable eCause)This method should be called by the client immediately after it determines that an attempt to use an address returned by theSocketAddressProvider.getNextAddress()method has failed.protected voidreset()Make all addresses iterable, starting at the first address.protected voidreset(int iLast)Make all addresses iterable, starting at the index after the specified one.protected Iterator<InetSocketAddress>resolveAddress(String sHost, int nPort)Resolve an address and port.intsize()Returns the number of elements in this collection.protected ListsortHolders(List list)Sort the holders in the order to be returned by thegetNextAddress()method.StringtoString()Return a string representation of this ConfigurableAddressProvider.- 
Methods inherited from class java.util.AbstractSetremoveAll
 - 
Methods inherited from class java.util.AbstractCollectionadd, addAll, clear, contains, containsAll, isEmpty, remove, retainAll, toArray, toArray
 - 
Methods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface java.util.CollectionparallelStream, removeIf, stream, toArray
 
- 
 
- 
- 
- 
Field Detail- 
m_listHoldersprotected List<ConfigurableAddressProvider.AddressHolder> m_listHolders A read-only list of ProvidedAddress objects.
 - 
m_iterAddrprotected Iterator<InetSocketAddress> m_iterAddr An address iterator for the previously resolved address.
 - 
m_iLastprotected int m_iLast Index of the last returned address.
 - 
m_fSafeprotected boolean m_fSafe Specifies if the provider is only to return resolved addresses.
 - 
m_fResolve@Deprecated public boolean m_fResolve Deprecated.Specifies if the list of address need DNS resolution.
 
- 
 - 
Constructor Detail- 
ConfigurableAddressProvider@Deprecated public ConfigurableAddressProvider(XmlElement xmlConfig) Deprecated.Construct an instance of ConfigurableAddressProvider based on the specified XML element.Unresolvable addresses will be skipped. - Parameters:
- xmlConfig- the XML element that contains the configuration info
 
 - 
ConfigurableAddressProviderpublic ConfigurableAddressProvider(Iterable<ConfigurableAddressProvider.AddressHolder> addressHolders, boolean fSafe) Constructs aConfigurableAddressProviderusing the specifiedConfigurableAddressProvider.AddressHolders.- Parameters:
- addressHolders- the- ConfigurableAddressProvider.AddressHolders
- fSafe- true if the provider skips unresolved addresses
 
 - 
ConfigurableAddressProvider@Deprecated public ConfigurableAddressProvider(XmlElement xmlConfig, boolean fSafe) Deprecated.Construct an instance of ConfigurableAddressProvider based on the specified XML element.- Parameters:
- xmlConfig- the XML element that contains the configuration info
- fSafe- true if the provider skips unresolved addresses
 
 
- 
 - 
Method Detail- 
makeProvider@Deprecated public static AddressProvider makeProvider(XmlElement xmlConfig) Deprecated.Creates an instances of ConfigurableAddressProvider or RefreshableAddressProvider that refresh the address list of the ConfigurableAddressProvider asynchronously.- Parameters:
- xmlConfig- the XML element that contains the configuration info
- Returns:
- an instance of the corresponding AddressProvider implementation
 
 - 
getNextAddresspublic InetSocketAddress getNextAddress() Covariant ofSocketAddressProvider.getNextAddress()which returns anInetSocketAddress.- Specified by:
- getNextAddressin interface- AddressProvider
- Specified by:
- getNextAddressin interface- SocketAddressProvider
- Returns:
- the next available address or null if the list of available addresses was exhausted
 
 - 
acceptpublic void accept() This method should be called by the client immediately after it determines that it can successfully use an address returned by theSocketAddressProvider.getNextAddress()method.- Specified by:
- acceptin interface- SocketAddressProvider
 
 - 
rejectpublic void reject(Throwable eCause) This method should be called by the client immediately after it determines that an attempt to use an address returned by theSocketAddressProvider.getNextAddress()method has failed.- Specified by:
- rejectin interface- SocketAddressProvider
- Parameters:
- eCause- (optional) an exception that carries the reason why the the caller rejected the previously returned address
 
 - 
sizepublic int size() Returns the number of elements in this collection. If the collection contains more than Integer.MAX_VALUE elements, returns Integer.MAX_VALUE.- Specified by:
- sizein interface- Collection
- Specified by:
- sizein interface- Set
- Specified by:
- sizein class- AbstractCollection
- Returns:
- the number of elements in this collection
 
 - 
iteratorpublic Iterator iterator() Returns an iterator over the elements contained in this collection.- Specified by:
- iteratorin interface- Collection
- Specified by:
- iteratorin interface- Iterable
- Specified by:
- iteratorin interface- Set
- Specified by:
- iteratorin class- AbstractCollection
- Returns:
- an iterator over the elements contained in this collection
 
 - 
resetprotected void reset() Make all addresses iterable, starting at the first address.
 - 
resetprotected void reset(int iLast) Make all addresses iterable, starting at the index after the specified one.- Parameters:
- iLast- the index of the last address returned
 
 - 
configure@Deprecated protected void configure(XmlElement xmlConfig) Deprecated.Configure this ConfigurableAddressProvider based on the specified XML.- Parameters:
- xmlConfig- the XML element that contains the configuration info
 
 - 
sortHoldersprotected List sortHolders(List list) Sort the holders in the order to be returned by thegetNextAddress()method. This implementation randomizes the holder list for simple load balancing.- Parameters:
- list- the original list retrieved from the configuration
- Returns:
- the re-ordered list
 
 - 
equalspublic boolean equals(Object o) AddressProvider instances should compare to be equals() iff they should be expected to consistently produce the same resulting set of addresses.Note: the general contract of hashCode and equals() should be preserved; AddressProviders which compare equals() should have the same hashCode. - Specified by:
- equalsin interface- Collection
- Specified by:
- equalsin interface- Set
- Specified by:
- equalsin interface- SocketAddressProvider
- Overrides:
- equalsin class- AbstractSet
- Parameters:
- o- the Object to compare this AddressProvider to for equality
- Returns:
- true iff this AddressProvider is equal to the specified object
 
 - 
hashCodepublic int hashCode() Return the hash code for this AddressProvider.- Specified by:
- hashCodein interface- Collection
- Specified by:
- hashCodein interface- Set
- Specified by:
- hashCodein interface- SocketAddressProvider
- Overrides:
- hashCodein class- AbstractSet
- Returns:
- the hash code for this AddressProvider
 
 - 
toStringpublic String toString() Return a string representation of this ConfigurableAddressProvider.- Overrides:
- toStringin class- AbstractCollection
- Returns:
- a string representation of the list of configured addresses
 
 - 
getAddressDescriptionspublic String[] getAddressDescriptions() Retrieve a human readable description of underlying addresses.- Specified by:
- getAddressDescriptionsin interface- DescribableAddressProvider
- Returns:
- a string array of addresses in human readable format
 
 - 
resolveAddressprotected Iterator<InetSocketAddress> resolveAddress(String sHost, int nPort) Resolve an address and port.- Parameters:
- sHost- the host
- nPort- the port
- Returns:
- the InetSocketAddress
 
 
- 
 
-