@InterfaceAudience.Public @InterfaceStability.Stable public class Configuration extends Object implements Iterable<Map.Entry<String,String>>, Writable
Configurations are specified by resources. A resource contains a set of
 name/value pairs as XML data. Each resource is named by either a 
 String or by a Path. If named by a String, 
 then the classpath is examined for a file with that name.  If named by a 
 Path, then the local filesystem is examined directly, without 
 referring to the classpath.
 
Unless explicitly turned off, Hadoop by default specifies two resources, loaded in-order from the classpath:
Configuration parameters may be declared final. Once a resource declares a value final, no subsequently-loaded resource can alter that value. For example, one might define a final parameter with:
  <property>
    <name>dfs.hosts.include</name>
    <value>/etc/hadoop/conf/hosts.include</value>
    <final>true</final>
  </property>Value strings are first processed for variable expansion. The available properties are:
System.getenv() if a name starts with
 "env.", orSystem.getProperties().For example, if a configuration resource contains the following property definitions:
  <property>
    <name>basedir</name>
    <value>/user/${user.name}</value>
  </property>
  
  <property>
    <name>tempdir</name>
    <value>${basedir}/tmp</value>
  </property>
  <property>
    <name>otherdir</name>
    <value>${env.BASE_DIR}/other</value>
  </property>
  When conf.get("tempdir") is called, then ${basedir} will be resolved to another property in this Configuration, while ${user.name} would then ordinarily be resolved to the value of the System property with that name.
When conf.get("otherdir") is called, then ${env.BASE_DIR} will be resolved to the value of the ${BASE_DIR} environment variable. It supports ${env.NAME:-default} and ${env.NAME-default} notations. The former is resolved to "default" if ${NAME} environment variable is undefined or its value is empty. The latter behaves the same way only if ${NAME} is undefined.
By default, warnings will be given to any deprecated configuration parameters and these are suppressible by configuring log4j.logger.org.apache.hadoop.conf.Configuration.deprecation in log4j.properties file.
Optionally we can tag related properties together by using tag attributes. System tags are defined by hadoop.tags.system property. Users can define there own custom tags in hadoop.tags.custom property.
For example, we can tag existing property as:
  <property>
    <name>dfs.replication</name>
    <value>3</value>
    <tag>HDFS,REQUIRED</tag>
  </property>
  <property>
    <name>dfs.data.transfer.protection</name>
    <value>3</value>
    <tag>HDFS,SECURITY</tag>
  </property>
 Properties marked with tags can be retrieved with conf .getAllPropertiesByTag("HDFS") or conf.getAllPropertiesByTags (Arrays.asList("YARN","SECURITY")).
| Constructor and Description | 
|---|
| Configuration()A new configuration. | 
| Configuration(boolean loadDefaults)A new configuration where the behavior of reading from the default 
 resources can be turned off. | 
| Configuration(Configuration other)A new configuration with the same settings cloned from another. | 
| Modifier and Type | Method and Description | 
|---|---|
| static void | addDefaultResource(String name)Add a default resource. | 
| static void | addDeprecation(String key,
              String newKey)Adds the deprecated key to the global deprecation map when no custom
 message is provided. | 
| static void | addDeprecation(String key,
              String[] newKeys)Deprecated. 
 use  addDeprecation(String key, String newKey)instead | 
| static void | addDeprecation(String key,
              String[] newKeys,
              String customMessage)Deprecated. 
 | 
| static void | addDeprecation(String key,
              String newKey,
              String customMessage)Adds the deprecated key to the global deprecation map. | 
| static void | addDeprecations(org.apache.hadoop.conf.Configuration.DeprecationDelta[] deltas)Adds a set of deprecated keys to the global deprecations. | 
| void | addResource(Configuration conf)Add a configuration resource. | 
| void | addResource(InputStream in)Add a configuration resource. | 
| void | addResource(InputStream in,
           boolean restrictedParser) | 
| void | addResource(InputStream in,
           String name)Add a configuration resource. | 
| void | addResource(InputStream in,
           String name,
           boolean restrictedParser) | 
| void | addResource(Path file)Add a configuration resource. | 
| void | addResource(Path file,
           boolean restrictedParser) | 
| void | addResource(String name)Add a configuration resource. | 
| void | addResource(String name,
           boolean restrictedParser) | 
| void | addResource(URL url)Add a configuration resource. | 
| void | addResource(URL url,
           boolean restrictedParser) | 
| void | addTags(Properties prop)Add tags defined in HADOOP_TAGS_SYSTEM, HADOOP_TAGS_CUSTOM. | 
| void | clear()Clears all keys from the configuration. | 
| static void | dumpConfiguration(Configuration config,
                 String propertyName,
                 Writer out)Writes properties and their attributes (final and resource)
  to the given  Writer. | 
| static void | dumpConfiguration(Configuration config,
                 Writer out)Writes out all properties and their attributes (final and resource) to
  the given  Writer, the format of the output would be, | 
| static void | dumpDeprecatedKeys() | 
| String | get(String name)Get the value of the  nameproperty,nullif
 no such property exists. | 
| String | get(String name,
   String defaultValue)Get the value of the  name. | 
| Properties | getAllPropertiesByTag(String tag)Get all properties belonging to tag. | 
| Properties | getAllPropertiesByTags(List<String> tagList)Get all properties belonging to list of input tags. | 
| boolean | getBoolean(String name,
          boolean defaultValue)Get the value of the  nameproperty as aboolean. | 
| Class<?> | getClass(String name,
        Class<?> defaultValue)Get the value of the  nameproperty as aClass. | 
| <U> Class<? extends U> | getClass(String name,
        Class<? extends U> defaultValue,
        Class<U> xface)Get the value of the  nameproperty as aClassimplementing the interface specified byxface. | 
| Class<?> | getClassByName(String name)Load a class by name. | 
| Class<?> | getClassByNameOrNull(String name)Load a class by name, returning null rather than throwing an exception
 if it couldn't be loaded. | 
| Class<?>[] | getClasses(String name,
          Class<?>... defaultValue)Get the value of the  nameproperty
 as an array ofClass. | 
| ClassLoader | getClassLoader()Get the  ClassLoaderfor this job. | 
| InputStream | getConfResourceAsInputStream(String name)Get an input stream attached to the configuration resource with the
 given  name. | 
| Reader | getConfResourceAsReader(String name)Get a  Readerattached to the configuration resource with the
 givenname. | 
| double | getDouble(String name,
         double defaultValue)Get the value of the  nameproperty as adouble. | 
| <T extends Enum<T>> | getEnum(String name,
       T defaultValue)Return value matching this enumerated type. | 
| File | getFile(String dirsProp,
       String path)Get a local file name under a directory named in dirsProp with
 the given path. | 
| Set<String> | getFinalParameters()Get the set of parameters marked final. | 
| float | getFloat(String name,
        float defaultValue)Get the value of the  nameproperty as afloat. | 
| <U> List<U> | getInstances(String name,
            Class<U> xface)Get the value of the  nameproperty as aListof objects implementing the interface specified byxface. | 
| int | getInt(String name,
      int defaultValue)Get the value of the  nameproperty as anint. | 
| int[] | getInts(String name)Get the value of the  nameproperty as a set of comma-delimitedintvalues. | 
| Path | getLocalPath(String dirsProp,
            String path)Get a local file under a directory named by dirsProp with
 the given path. | 
| long | getLong(String name,
       long defaultValue)Get the value of the  nameproperty as along. | 
| long | getLongBytes(String name,
            long defaultValue)Get the value of the  nameproperty as alongor
 human readable format. | 
| char[] | getPassword(String name)Get the value for a known password configuration element. | 
| protected char[] | getPasswordFromConfig(String name)Fallback to clear text passwords in configuration. | 
| char[] | getPasswordFromCredentialProviders(String name)Try and resolve the provided element name as a credential provider
 alias. | 
| Pattern | getPattern(String name,
          Pattern defaultValue)Get the value of the  nameproperty as aPattern. | 
| String[] | getPropertySources(String name)Gets information about why a property was set. | 
| protected Properties | getProps() | 
| Map<String,String> | getPropsWithPrefix(String confPrefix)Constructs a mapping of configuration and includes all properties that
 start with the specified configuration prefix. | 
| org.apache.hadoop.conf.Configuration.IntegerRanges | getRange(String name,
        String defaultValue)Parse the given attribute as a set of integer ranges. | 
| String | getRaw(String name)Get the value of the  nameproperty, without doing
 variable expansion.If the key is 
 deprecated, it returns the value of the first key which replaces 
 the deprecated key and is not null. | 
| URL | getResource(String name)Get the  URLfor the named resource. | 
| InetSocketAddress | getSocketAddr(String name,
             String defaultAddress,
             int defaultPort)Get the socket address for  nameproperty as aInetSocketAddress. | 
| InetSocketAddress | getSocketAddr(String hostProperty,
             String addressProperty,
             String defaultAddressValue,
             int defaultPort)Get the socket address for  hostPropertyas aInetSocketAddress. | 
| double | getStorageSize(String name,
              double defaultValue,
              org.apache.hadoop.conf.StorageUnit targetUnit)Gets storage size from a config file. | 
| double | getStorageSize(String name,
              String defaultValue,
              org.apache.hadoop.conf.StorageUnit targetUnit)Gets the Storage Size from the config, or returns the defaultValue. | 
| Collection<String> | getStringCollection(String name)Get the comma delimited values of the  nameproperty as 
 a collection ofStrings. | 
| String[] | getStrings(String name)Get the comma delimited values of the  nameproperty as 
 an array ofStrings. | 
| String[] | getStrings(String name,
          String... defaultValue)Get the comma delimited values of the  nameproperty as 
 an array ofStrings. | 
| long | getTimeDuration(String name,
               long defaultValue,
               TimeUnit unit)Return time duration in the given time unit. | 
| long | getTimeDuration(String name,
               long defaultValue,
               TimeUnit defaultUnit,
               TimeUnit returnUnit)Return time duration in the given time unit. | 
| long | getTimeDuration(String name,
               String defaultValue,
               TimeUnit unit) | 
| long | getTimeDuration(String name,
               String defaultValue,
               TimeUnit defaultUnit,
               TimeUnit returnUnit) | 
| long | getTimeDurationHelper(String name,
                     String vStr,
                     TimeUnit unit)Return time duration in the given time unit. | 
| long[] | getTimeDurations(String name,
                TimeUnit unit) | 
| String | getTrimmed(String name)Get the value of the  nameproperty as a trimmedString,nullif no such property exists. | 
| String | getTrimmed(String name,
          String defaultValue)Get the value of the  nameproperty as a trimmedString,defaultValueif no such property exists. | 
| Collection<String> | getTrimmedStringCollection(String name)Get the comma delimited values of the  nameproperty as 
 a collection ofStrings, trimmed of the leading and trailing whitespace. | 
| String[] | getTrimmedStrings(String name)Get the comma delimited values of the  nameproperty as 
 an array ofStrings, trimmed of the leading and trailing whitespace. | 
| String[] | getTrimmedStrings(String name,
                 String... defaultValue)Get the comma delimited values of the  nameproperty as 
 an array ofStrings, trimmed of the leading and trailing whitespace. | 
| Map<String,String> | getValByRegex(String regex)get keys matching the the regex. | 
| static boolean | hasWarnedDeprecation(String name)Returns whether or not a deprecated name has been warned. | 
| static boolean | isDeprecated(String key)checks whether the given  keyis deprecated. | 
| boolean | isPropertyTag(String tagStr)Get Property tag Enum corresponding to given source. | 
| Iterator<Map.Entry<String,String>> | iterator()Get an  Iteratorto go through the list ofStringkey-value pairs in the configuration. | 
| static void | main(String[] args)For debugging. | 
| boolean | onlyKeyExists(String name)Return existence of the  nameproperty, but only for
 names which have no valid value, usually non-existent or commented
 out in XML. | 
| void | readFields(DataInput in)Deserialize the fields of this object from  in. | 
| void | reloadConfiguration()Reload configuration from previously added resources. | 
| static void | reloadExistingConfigurations()Reload existing configuration instances. | 
| void | set(String name,
   String value)Set the  valueof thenameproperty. | 
| void | set(String name,
   String value,
   String source)Set the  valueof thenameproperty. | 
| void | setAllowNullValueProperties(boolean val)Set Configuration to allow keys without values during setup. | 
| void | setBoolean(String name,
          boolean value)Set the value of the  nameproperty to aboolean. | 
| void | setBooleanIfUnset(String name,
                 boolean value)Set the given property, if it is currently unset. | 
| void | setClass(String name,
        Class<?> theClass,
        Class<?> xface)Set the value of the  nameproperty to the name of atheClassimplementing the given interfacexface. | 
| void | setClassLoader(ClassLoader classLoader)Set the class loader that will be used to load the various objects. | 
| void | setDeprecatedProperties()Sets all deprecated properties that are not currently set but have a
 corresponding new property that is set. | 
| void | setDouble(String name,
         double value)Set the value of the  nameproperty to adouble. | 
| <T extends Enum<T>> | setEnum(String name,
       T value)Set the value of the  nameproperty to the given type. | 
| void | setFloat(String name,
        float value)Set the value of the  nameproperty to afloat. | 
| void | setIfUnset(String name,
          String value)Sets a property if it is currently unset. | 
| void | setInt(String name,
      int value)Set the value of the  nameproperty to anint. | 
| void | setLong(String name,
       long value)Set the value of the  nameproperty to along. | 
| void | setPattern(String name,
          Pattern pattern)Set the given property to  Pattern. | 
| void | setQuietMode(boolean quietmode)Set the quietness-mode. | 
| void | setRestrictSystemProperties(boolean val) | 
| static void | setRestrictSystemPropertiesDefault(boolean val) | 
| void | setRestrictSystemProps(boolean val) | 
| void | setSocketAddr(String name,
             InetSocketAddress addr)Set the socket address for the  nameproperty as
 ahost:port. | 
| void | setStorageSize(String name,
              double value,
              org.apache.hadoop.conf.StorageUnit unit)Sets Storage Size for the specified key. | 
| void | setStrings(String name,
          String... values)Set the array of string values for the  nameproperty as 
 as comma delimited values. | 
| void | setTimeDuration(String name,
               long value,
               TimeUnit unit)Set the value of  nameto the given time duration. | 
| int | size()Return the number of keys in the configuration. | 
| String | toString() | 
| void | unset(String name)Unset a previously set property. | 
| InetSocketAddress | updateConnectAddr(String name,
                 InetSocketAddress addr)Set the socket address a client can use to connect for the
  nameproperty as ahost:port. | 
| InetSocketAddress | updateConnectAddr(String hostProperty,
                 String addressProperty,
                 String defaultAddressValue,
                 InetSocketAddress addr)Set the socket address a client can use to connect for the
  nameproperty as ahost:port. | 
| void | write(DataOutput out)Serialize the fields of this object to  out. | 
| void | writeXml(OutputStream out)Write out the non-default properties in this configuration to the given
  OutputStreamusing UTF-8 encoding. | 
| void | writeXml(String propertyName,
        Writer out)Write out the non-default properties in this configuration to the
 given  Writer. | 
| void | writeXml(Writer out) | 
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitforEach, spliteratorpublic Configuration()
public Configuration(boolean loadDefaults)
loadDefaults is false, the new instance
 will not load resources from the default files.loadDefaults - specifies whether to load from the default filespublic Configuration(Configuration other)
other - the configuration from which to clone settings.public static void addDeprecations(org.apache.hadoop.conf.Configuration.DeprecationDelta[] deltas)
deltas - The deprecations to add.@Deprecated public static void addDeprecation(String key, String[] newKeys, String customMessage)
addDeprecation(String key, String newKey,
      String customMessage) insteadkey - to be deprecatednewKeys - list of keys that take up the values of deprecated keycustomMessage - depcrication messagepublic static void addDeprecation(String key, String newKey, String customMessage)
key - to be deprecatednewKey - key that take up the values of deprecated keycustomMessage - deprecation message@Deprecated public static void addDeprecation(String key, String[] newKeys)
addDeprecation(String key, String newKey) insteadkey - Key that is to be deprecatednewKeys - list of keys that take up the values of deprecated keypublic static void addDeprecation(String key, String newKey)
key - Key that is to be deprecatednewKey - key that takes up the value of deprecated keypublic static boolean isDeprecated(String key)
key is deprecated.key - the parameter which is to be checked for deprecationtrue if the key is deprecated and 
         false otherwise.public void setDeprecatedProperties()
public static void reloadExistingConfigurations()
public static void addDefaultResource(String name)
name - file name. File should be present in the classpath.public static void setRestrictSystemPropertiesDefault(boolean val)
public void setRestrictSystemProperties(boolean val)
public void addResource(String name)
name - resource to be added, the classpath is examined for a file 
             with that name.public void addResource(String name, boolean restrictedParser)
public void addResource(URL url)
url - url of the resource to be added, the local filesystem is 
            examined directly to find the resource, without referring to 
            the classpath.public void addResource(URL url, boolean restrictedParser)
public void addResource(Path file)
file - file-path of resource to be added, the local filesystem is
             examined directly to find the resource, without referring to 
             the classpath.public void addResource(Path file, boolean restrictedParser)
public void addResource(InputStream in)
in - InputStream to deserialize the object from. In will be read from
 when a get or set is called next.  After it is read the stream will be
 closed.public void addResource(InputStream in, boolean restrictedParser)
public void addResource(InputStream in, String name)
in - InputStream to deserialize the object from.name - the name of the resource because InputStream.toString is not
 very descriptive some times.public void addResource(InputStream in, String name, boolean restrictedParser)
public void addResource(Configuration conf)
conf - Configuration object from which to load propertiespublic void reloadConfiguration()
public String get(String name)
name property, null if
 no such property exists. If the key is deprecated, it returns the value of
 the first key which replaces the deprecated key and is not null.
 
 Values are processed for variable expansion 
 before being returned.
 As a side effect get loads the properties from the sources if called for
 the first time as a lazy init.name - the property name, will be trimmed before get value.name or its replacing property, 
         or null if no such property exists.@VisibleForTesting public void setAllowNullValueProperties(boolean val)
val - If true, will allow Configuration to store keys without valuespublic void setRestrictSystemProps(boolean val)
@VisibleForTesting public boolean onlyKeyExists(String name)
name property, but only for
 names which have no valid value, usually non-existent or commented
 out in XML.name - the property namename exists without valuepublic String getTrimmed(String name)
name property as a trimmed String, 
 null if no such property exists. 
 If the key is deprecated, it returns the value of
 the first key which replaces the deprecated key and is not null
 
 Values are processed for variable expansion 
 before being returned.name - the property name.name or its replacing property, 
         or null if no such property exists.public String getTrimmed(String name, String defaultValue)
name property as a trimmed String, 
 defaultValue if no such property exists. 
 See @{Configuration#getTrimmed} for more details.name - the property name.defaultValue - the property default value.name or defaultValue
                      if it is not set.public String getRaw(String name)
name property, without doing
 variable expansion.If the key is 
 deprecated, it returns the value of the first key which replaces 
 the deprecated key and is not null.name - the property name.name property or 
         its replacing property and null if no such property exists.public void set(String name, String value)
value of the name property. If 
 name is deprecated or there is a deprecated name associated to it,
 it sets the value to both names. Name will be trimmed before put into
 configuration.name - property name.value - property value.public void set(String name, String value, String source)
value of the name property. If 
 name is deprecated, it also sets the value to
 the keys that replace the deprecated key. Name will be trimmed before put
 into configuration.name - property name.value - property value.source - the place that this configuration value came from 
 (For debugging).IllegalArgumentException - when the value or name is null.public void unset(String name)
name - the property namepublic void setIfUnset(String name, String value)
name - the property namevalue - the new valuepublic String get(String name, String defaultValue)
name. If the key is deprecated,
 it returns the value of the first key which replaces the deprecated key
 and is not null.
 If no such property exists,
 then defaultValue is returned.name - property name, will be trimmed before get value.defaultValue - default value.defaultValue if the property 
         doesn't exist.public int getInt(String name, int defaultValue)
name property as an int.
   
 If no such property exists, the provided default value is returned,
 or if the specified value is not a valid int,
 then an error is thrown.name - property name.defaultValue - default value.int, 
         or defaultValue.NumberFormatException - when the value is invalidpublic int[] getInts(String name)
name property as a set of comma-delimited
 int values.
 
 If no such property exists, an empty array is returned.name - property nameint valuespublic void setInt(String name, int value)
name property to an int.name - property name.value - int value of the property.public long getLong(String name, long defaultValue)
name property as a long.  
 If no such property exists, the provided default value is returned,
 or if the specified value is not a valid long,
 then an error is thrown.name - property name.defaultValue - default value.long, 
         or defaultValue.NumberFormatException - when the value is invalidpublic long getLongBytes(String name, long defaultValue)
name property as a long or
 human readable format. If no such property exists, the provided default
 value is returned, or if the specified value is not a valid
 long or human readable format, then an error is thrown. You
 can use the following suffix (case insensitive): k(kilo), m(mega), g(giga),
 t(tera), p(peta), e(exa)name - property name.defaultValue - default value.long,
         or defaultValue.NumberFormatException - when the value is invalidpublic void setLong(String name, long value)
name property to a long.name - property name.value - long value of the property.public float getFloat(String name, float defaultValue)
name property as a float.  
 If no such property exists, the provided default value is returned,
 or if the specified value is not a valid float,
 then an error is thrown.name - property name.defaultValue - default value.float, 
         or defaultValue.NumberFormatException - when the value is invalidpublic void setFloat(String name, float value)
name property to a float.name - property name.value - property value.public double getDouble(String name, double defaultValue)
name property as a double.  
 If no such property exists, the provided default value is returned,
 or if the specified value is not a valid double,
 then an error is thrown.name - property name.defaultValue - default value.double, 
         or defaultValue.NumberFormatException - when the value is invalidpublic void setDouble(String name, double value)
name property to a double.name - property name.value - property value.public boolean getBoolean(String name, boolean defaultValue)
name property as a boolean.  
 If no such property is specified, or if the specified value is not a valid
 boolean, then defaultValue is returned.name - property name.defaultValue - default value.boolean, 
         or defaultValue.public void setBoolean(String name, boolean value)
name property to a boolean.name - property name.value - boolean value of the property.public void setBooleanIfUnset(String name, boolean value)
name - property namevalue - new valuepublic <T extends Enum<T>> void setEnum(String name, T value)
name property to the given type. This
 is equivalent to set(<name>, value.toString()).T - enumeration typename - property namevalue - new valuepublic <T extends Enum<T>> T getEnum(String name, T defaultValue)
T - enumeration typename - Property namedefaultValue - Value returned if no mapping existsIllegalArgumentException - If mapping is illegal for the type
 providedpublic void setTimeDuration(String name, long value, TimeUnit unit)
name to the given time duration. This
 is equivalent to set(<name>, value + <time suffix>).name - Property namevalue - Time durationunit - Unit of timepublic long getTimeDuration(String name, long defaultValue, TimeUnit unit)
name - Property namedefaultValue - Value returned if no mapping exists.unit - Unit to convert the stored property, if it exists.NumberFormatException - If the property stripped of its unit is not
         a numberpublic long getTimeDuration(String name, long defaultValue, TimeUnit defaultUnit, TimeUnit returnUnit)
name - Property namedefaultValue - Value returned if no mapping exists.defaultUnit - Default time unit if no valid suffix is provided.returnUnit - The unit used for the returned value.NumberFormatException - If the property stripped of its unit is not
         a numberpublic long getTimeDuration(String name, String defaultValue, TimeUnit defaultUnit, TimeUnit returnUnit)
public long getTimeDurationHelper(String name, String vStr, TimeUnit unit)
name - Property namevStr - The string value with time unit suffix to be converted.unit - Unit to convert the stored property, if it exists.public double getStorageSize(String name, String defaultValue, org.apache.hadoop.conf.StorageUnit targetUnit)
name - - Key NamedefaultValue - - Default Value -- e.g. 100MBtargetUnit - - The units that we want result to be in.public double getStorageSize(String name, double defaultValue, org.apache.hadoop.conf.StorageUnit targetUnit)
name - - Key to read.defaultValue - - The default value to return in case the key is
 not present.targetUnit - - The Storage unit that should be used
 for the return value.public void setStorageSize(String name, double value, org.apache.hadoop.conf.StorageUnit unit)
name - - Key to set.value - - The numeric value to set.unit - - Storage Unit to be used.public Pattern getPattern(String name, Pattern defaultValue)
name property as a Pattern.
 If no such property is specified, or if the specified value is not a valid
 Pattern, then DefaultValue is returned.
 Note that the returned value is NOT trimmed by this method.name - property namedefaultValue - default valuepublic void setPattern(String name, Pattern pattern)
Pattern.
 If the pattern is passed as null, sets the empty pattern which results in
 further calls to getPattern(...) returning the default value.name - property namepattern - new value@InterfaceStability.Unstable public String[] getPropertySources(String name)
name - - The property name to get the source of.public org.apache.hadoop.conf.Configuration.IntegerRanges getRange(String name, String defaultValue)
name - the attribute namedefaultValue - the default value if it is not setpublic Collection<String> getStringCollection(String name)
name property as 
 a collection of Strings.  
 If no such property is specified then empty collection is returned.
 
 This is an optimized version of getStrings(String)
name - property name.Strings.public String[] getStrings(String name)
name property as 
 an array of Strings.  
 If no such property is specified then null is returned.name - property name.Strings, 
         or null.public String[] getStrings(String name, String... defaultValue)
name property as 
 an array of Strings.  
 If no such property is specified then default value is returned.name - property name.defaultValue - The default valueStrings, 
         or default value.public Collection<String> getTrimmedStringCollection(String name)
name property as 
 a collection of Strings, trimmed of the leading and trailing whitespace.  
 If no such property is specified then empty Collection is returned.name - property name.Strings, or empty Collectionpublic String[] getTrimmedStrings(String name)
name property as 
 an array of Strings, trimmed of the leading and trailing whitespace.
 If no such property is specified then an empty array is returned.name - property name.Strings, 
         or empty array.public String[] getTrimmedStrings(String name, String... defaultValue)
name property as 
 an array of Strings, trimmed of the leading and trailing whitespace.
 If no such property is specified then default value is returned.name - property name.defaultValue - The default valueStrings, 
         or default value.public void setStrings(String name, String... values)
name property as 
 as comma delimited values.name - property name.values - The valuespublic char[] getPassword(String name) throws IOException
name - property nameIOException - when error in fetching passwordpublic char[] getPasswordFromCredentialProviders(String name) throws IOException
name - alias of the provisioned credentialIOException - when error in fetching passwordprotected char[] getPasswordFromConfig(String name)
name - the property name.public InetSocketAddress getSocketAddr(String hostProperty, String addressProperty, String defaultAddressValue, int defaultPort)
hostProperty as a
 InetSocketAddress. If hostProperty is
 null, addressProperty will be used. This
 is useful for cases where we want to differentiate between host
 bind address and address clients should use to establish connection.hostProperty - bind host property name.addressProperty - address property name.defaultAddressValue - the default valuedefaultPort - the default portpublic InetSocketAddress getSocketAddr(String name, String defaultAddress, int defaultPort)
name property as a
 InetSocketAddress.name - property name.defaultAddress - the default valuedefaultPort - the default portpublic void setSocketAddr(String name, InetSocketAddress addr)
name property as
 a host:port.name - property name.addr - inetSocketAddress addr.public InetSocketAddress updateConnectAddr(String hostProperty, String addressProperty, String defaultAddressValue, InetSocketAddress addr)
name property as a host:port.  The wildcard
 address is replaced with the local host's address. If the host and address
 properties are configured the host component of the address will be combined
 with the port component of the addr to generate the address.  This is to allow
 optional control over which host name is used in multi-home bind-host
 cases where a host can have multiple nameshostProperty - the bind-host configuration nameaddressProperty - the service address configuration namedefaultAddressValue - the service default address configuration valueaddr - InetSocketAddress of the service listenerpublic InetSocketAddress updateConnectAddr(String name, InetSocketAddress addr)
name property as a host:port.  The wildcard
 address is replaced with the local host's address.name - property name.addr - InetSocketAddress of a listener to store in the given propertypublic Class<?> getClassByName(String name) throws ClassNotFoundException
name - the class name.ClassNotFoundException - if the class is not found.public Class<?> getClassByNameOrNull(String name)
name - the class namepublic Class<?>[] getClasses(String name, Class<?>... defaultValue)
name property
 as an array of Class.
 The value of the property specifies a list of comma separated class names.  
 If no such property is specified, then defaultValue is 
 returned.name - the property name.defaultValue - default value.Class[], 
         or defaultValue.public Class<?> getClass(String name, Class<?> defaultValue)
name property as a Class.  
 If no such property is specified, then defaultValue is 
 returned.name - the conf key name.defaultValue - default value.Class, 
         or defaultValue.public <U> Class<? extends U> getClass(String name, Class<? extends U> defaultValue, Class<U> xface)
name property as a Class
 implementing the interface specified by xface.
   
 If no such property is specified, then defaultValue is 
 returned.
 
 An exception is thrown if the returned class does not implement the named
 interface.U - Interface class type.name - the conf key name.defaultValue - default value.xface - the interface implemented by the named class.Class, 
         or defaultValue.public <U> List<U> getInstances(String name, Class<U> xface)
name property as a List
 of objects implementing the interface specified by xface.
 
 An exception is thrown if any of the classes does not exist, or if it does
 not implement the named interface.U - Interface class type.name - the property name.xface - the interface implemented by the classes named by
        name.List of objects implementing xface.public void setClass(String name, Class<?> theClass, Class<?> xface)
name property to the name of a 
 theClass implementing the given interface xface.
 
 An exception is thrown if theClass does not implement the 
 interface xface.name - property name.theClass - property value.xface - the interface implemented by the named class.public Path getLocalPath(String dirsProp, String path) throws IOException
dirsProp - directory in which to locate the file.path - file-path.IOException - raised on errors performing I/O.public File getFile(String dirsProp, String path) throws IOException
dirsProp - directory in which to locate the file.path - file-path.IOException - raised on errors performing I/O.public URL getResource(String name)
URL for the named resource.name - resource name.public InputStream getConfResourceAsInputStream(String name)
name.name - configuration resource name.public Reader getConfResourceAsReader(String name)
Reader attached to the configuration resource with the
 given name.name - configuration resource name.public Set<String> getFinalParameters()
protected Properties getProps()
public int size()
public void clear()
public Iterator<Map.Entry<String,String>> iterator()
Iterator to go through the list of String 
 key-value pairs in the configuration.public Map<String,String> getPropsWithPrefix(String confPrefix)
confPrefix - configuration prefixpublic void addTags(Properties prop)
prop - properties.public void writeXml(OutputStream out) throws IOException
OutputStream using UTF-8 encoding.out - the output stream to write to.IOException - raised on errors performing I/O.public void writeXml(Writer out) throws IOException
IOExceptionpublic void writeXml(@Nullable String propertyName, Writer out) throws IOException, IllegalArgumentException
Writer.
 Writer.
 Writer.
 IllegalArgumentException.
 propertyName - xml property name.out - the writer to write to.IOException - raised on errors performing I/O.IllegalArgumentExceptionpublic static void dumpConfiguration(Configuration config, String propertyName, Writer out) throws IOException
Writer.
  
  {
    "property": {
      "key" : "key1",
      "value" : "value1",
      "isFinal" : "key1.isFinal",
      "resource" : "key1.resource"
    }
  }
  
  dumpConfiguration(Configuration, Writer), the
  output would be,
  
  { "properties" :
      [ { key : "key1",
          value : "value1",
          isFinal : "key1.isFinal",
          resource : "key1.resource" },
        { key : "key2",
          value : "value2",
          isFinal : "ke2.isFinal",
          resource : "key2.resource" }
       ]
   }
  
  IllegalArgumentException.
  config - the configurationpropertyName - property nameout - the Writer to write toIOException - raised on errors performing I/O.IllegalArgumentException - when property name is not
   empty and the property is not found in configurationpublic static void dumpConfiguration(Configuration config, Writer out) throws IOException
Writer, the format of the output would be,
  
  { "properties" :
      [ { key : "key1",
          value : "value1",
          isFinal : "key1.isFinal",
          resource : "key1.resource" },
        { key : "key2",
          value : "value2",
          isFinal : "ke2.isFinal",
          resource : "key2.resource" }
       ]
   }
  
  It does not output the properties of the configuration object which
  is loaded from an input stream.
  config - the configurationout - the Writer to write toIOException - raised on errors performing I/O.public ClassLoader getClassLoader()
ClassLoader for this job.public void setClassLoader(ClassLoader classLoader)
classLoader - the new class loader.public void setQuietMode(boolean quietmode)
quietmode - true to set quiet-mode on, false
              to turn it off.public static void main(String[] args) throws Exception
args - the argument to be parsed.Exception - exception.public void readFields(DataInput in) throws IOException
Writablein.  
 
 For efficiency, implementations should attempt to re-use storage in the existing object where possible.
readFields in interface Writablein - DataInput to deseriablize this object from.IOException - any other problem for readFields.public void write(DataOutput out) throws IOException
Writableout.write in interface Writableout - DataOuput to serialize this object into.IOException - any other problem for write.public Map<String,String> getValByRegex(String regex)
regex - the regex to match against.public static void dumpDeprecatedKeys()
public static boolean hasWarnedDeprecation(String name)
name - proprties.public Properties getAllPropertiesByTag(String tag)
tag - tagpublic Properties getAllPropertiesByTags(List<String> tagList)
tagList - list of input tagspublic boolean isPropertyTag(String tagStr)
tagStr - String representation of EnumCopyright © 2023 Apache Software Foundation. All rights reserved.