alluxio.conf.AlluxioProperties Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of alluxio-core-common Show documentation
Show all versions of alluxio-core-common Show documentation
Common utilities shared in Alluxio core modules
/*
* The Alluxio Open Foundation licenses this work under the Apache License, version 2.0
* (the "License"). You may not use this work except in compliance with the License, which is
* available at www.apache.org/licenses/LICENSE-2.0
*
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
* either express or implied, as more fully set forth in the License.
*
* See the NOTICE file distributed with this work for information regarding copyright ownership.
*/
package alluxio.conf;
import static java.util.stream.Collectors.toSet;
import com.google.common.annotations.VisibleForTesting;
import com.google.common.collect.Maps;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashSet;
import java.util.Map;
import java.util.Optional;
import java.util.Properties;
import java.util.Set;
import java.util.concurrent.ConcurrentHashMap;
import java.util.function.BiConsumer;
import javax.annotation.Nullable;
import javax.annotation.concurrent.NotThreadSafe;
/**
* Provides the source of truth of property values and a unified abstraction to put and get
* properties, hiding the difference of accessing user-specified properties, the default properties
* (known at construction time) and the extension properties (known at runtime). This class is
* supposed to handle the ordering and priority of properties from different sources, whereas the
* Configuration
class is supposed to handle the type conversion on top of the source
* of truth of the properties.
*
* For a given property key, the order of preference of its value is (from highest to lowest)
*
* (1) runtime config
* (2) system properties,
* (3) properties in the specified file (site-properties),
* (4) default property values.
*/
@NotThreadSafe
public class AlluxioProperties {
private static final Logger LOG = LoggerFactory.getLogger(AlluxioProperties.class);
/**
* Map of user-specified properties. When key is mapped to Optional.empty(), it indicates no
* value is set for this key. Note that, ConcurrentHashMap requires not null for key and value.
*/
private final ConcurrentHashMap> mUserProps =
new ConcurrentHashMap<>();
/** Map of property sources. */
private final ConcurrentHashMap mSources = new ConcurrentHashMap<>();
private final Hash mHash = new Hash(() -> keySet().stream()
.filter(key -> get(key) != null)
.sorted(Comparator.comparing(PropertyKey::getName))
.map(key -> String.format("%s:%s:%s", key.getName(), get(key), getSource(key)).getBytes()));
/**
* Constructs a new instance of Alluxio properties.
*/
public AlluxioProperties() {}
/**
* @param alluxioProperties properties to copy
*/
public AlluxioProperties(AlluxioProperties alluxioProperties) {
mUserProps.putAll(alluxioProperties.mUserProps);
mSources.putAll(alluxioProperties.mSources);
}
/**
* @param key the key to query
* @return the value, or null if the key has no value set
*/
@Nullable
public Object get(PropertyKey key) {
if (mUserProps.containsKey(key)) {
return mUserProps.get(key).orElse(null);
}
// In case key is not the reference to the original key
return PropertyKey.fromString(key.toString()).getDefaultValue();
}
/**
* Clears all existing user-specified properties.
*/
public void clear() {
mUserProps.clear();
mSources.clear();
}
/**
* Puts the key value pair specified by users.
*
* @param key key to put
* @param value value to put
* @param source the source of this value for the key
*/
public void put(PropertyKey key, Object value, Source source) {
if (!mUserProps.containsKey(key) || source.compareTo(getSource(key)) >= 0) {
mUserProps.put(key, Optional.ofNullable(value));
mSources.put(key, source);
mHash.markOutdated();
}
}
/**
* Puts the key value pair specified by users.
*
* @param key key to put
* @param value value to put
*/
public void set(PropertyKey key, Object value) {
put(key, value, Source.RUNTIME);
}
/**
* Merges the current configuration properties with new properties. If a property exists
* both in the new and current configuration, the one from the new configuration wins if
* its priority is higher or equal than the existing one.
*
* @param properties the source {@link Properties} to be merged
* @param source the source of the the properties (e.g., system property, default and etc)
*/
public void merge(Map, ?> properties, Source source) {
if (properties == null || properties.isEmpty()) {
return;
}
// merge the properties
for (Map.Entry, ?> entry : properties.entrySet()) {
String key = entry.getKey().toString().trim();
String value = entry.getValue() == null ? null : entry.getValue().toString().trim();
PropertyKey propertyKey;
if (PropertyKey.isValid(key)) {
propertyKey = PropertyKey.fromString(key);
} else {
// Add unrecognized properties
LOG.debug("Property {} from source {} is unrecognized", key, source);
// Workaround for issue https://alluxio.atlassian.net/browse/ALLUXIO-3108
// This will register the key as a valid PropertyKey
// TODO(adit): Do not add properties unrecognized by Ufs extensions when Configuration
// is made dynamic
propertyKey = PropertyKey.getOrBuildCustom(key);
}
put(propertyKey, propertyKey.parseValue(value), source);
}
mHash.markOutdated();
}
/**
* Merges properties from another instance. If a property exists
* both in the new and current configuration, the one from the new configuration wins if
* its priority is higher or equal than the existing one.
*
* @param properties the properties to merge from
*/
public void merge(AlluxioProperties properties) {
if (properties == null || properties.userKeySet().isEmpty()) {
return;
}
for (Map.Entry> entry : properties.mUserProps.entrySet()) {
PropertyKey key = entry.getKey();
Optional
© 2015 - 2025 Weber Informatics LLC | Privacy Policy