Move system property access operations to SystemPropertyUtil
This commit is contained in:
parent
85f47d639f
commit
00f737c3a4
@ -40,7 +40,7 @@ public final class DetectionUtil {
|
|||||||
private static final boolean IS_ROOT;
|
private static final boolean IS_ROOT;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
String os = System.getProperty("os.name").toLowerCase();
|
String os = SystemPropertyUtil.get("os.name").toLowerCase();
|
||||||
// windows
|
// windows
|
||||||
IS_WINDOWS = os.contains("win");
|
IS_WINDOWS = os.contains("win");
|
||||||
|
|
||||||
@ -104,17 +104,20 @@ public final class DetectionUtil {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static boolean hasUnsafe(ClassLoader loader) {
|
private static boolean hasUnsafe(ClassLoader loader) {
|
||||||
String value = SystemPropertyUtil.get("io.netty.noUnsafe");
|
boolean noUnsafe = SystemPropertyUtil.getBoolean("io.netty.noUnsafe", false);
|
||||||
if (value != null) {
|
if (noUnsafe) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Legacy properties
|
// Legacy properties
|
||||||
value = SystemPropertyUtil.get("io.netty.tryUnsafe");
|
boolean tryUnsafe = false;
|
||||||
if (value == null) {
|
if (SystemPropertyUtil.contains("io.netty.tryUnsafe")) {
|
||||||
value = SystemPropertyUtil.get("org.jboss.netty.tryUnsafe", "true");
|
tryUnsafe = SystemPropertyUtil.getBoolean("io.netty.tryUnsafe", true);
|
||||||
|
} else {
|
||||||
|
tryUnsafe = SystemPropertyUtil.getBoolean("org.jboss.netty.tryUnsafe", true);
|
||||||
}
|
}
|
||||||
if (!"true".equalsIgnoreCase(value)) {
|
|
||||||
|
if (!tryUnsafe) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -124,6 +127,7 @@ public final class DetectionUtil {
|
|||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
// Ignore
|
// Ignore
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -15,27 +15,56 @@
|
|||||||
*/
|
*/
|
||||||
package io.netty.util.internal;
|
package io.netty.util.internal;
|
||||||
|
|
||||||
import java.util.regex.Pattern;
|
import io.netty.logging.InternalLogger;
|
||||||
|
import io.netty.logging.InternalLoggerFactory;
|
||||||
|
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Accesses the system property swallowing a {@link SecurityException}.
|
* A collection of utility methods to retrieve and parse the values of the Java system properties.
|
||||||
*/
|
*/
|
||||||
final class SystemPropertyUtil {
|
public final class SystemPropertyUtil {
|
||||||
|
|
||||||
|
private static final InternalLogger logger =
|
||||||
|
InternalLoggerFactory.getInstance(SystemPropertyUtil.class);
|
||||||
|
|
||||||
|
private static final Properties props;
|
||||||
|
|
||||||
|
// Retrieve all system properties at once so that there's no need to deal with
|
||||||
|
// security exceptions from next time. Otherwise, we might end up with logging every
|
||||||
|
// security exceptions on every system property access or introducing more complexity
|
||||||
|
// just because of less verbose logging.
|
||||||
|
static {
|
||||||
|
Properties newProps = null;
|
||||||
|
try {
|
||||||
|
newProps = System.getProperties();
|
||||||
|
} catch (SecurityException e) {
|
||||||
|
logger.warn("Unable to access the system properties; default values will be used.", e);
|
||||||
|
newProps = new Properties();
|
||||||
|
}
|
||||||
|
|
||||||
|
props = newProps;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns {@code true} if and only if the system property with the specified {@code key}
|
||||||
|
* exists.
|
||||||
|
*/
|
||||||
|
public static boolean contains(String key) {
|
||||||
|
if (key == null) {
|
||||||
|
throw new NullPointerException("key");
|
||||||
|
}
|
||||||
|
return props.containsKey(key);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the value of the Java system property with the specified
|
* Returns the value of the Java system property with the specified
|
||||||
* {@code key}.
|
* {@code key}, while falling back to {@code null} if the property access fails.
|
||||||
*
|
*
|
||||||
* @return the property value.
|
* @return the property value or {@code null}
|
||||||
* {@code null} if there's no such property or if an access to the
|
|
||||||
* specified property is not allowed.
|
|
||||||
*/
|
*/
|
||||||
public static String get(String key) {
|
public static String get(String key) {
|
||||||
try {
|
return get(key, null);
|
||||||
return System.getProperty(key);
|
|
||||||
} catch (Exception e) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -48,10 +77,15 @@ final class SystemPropertyUtil {
|
|||||||
* specified property is not allowed.
|
* specified property is not allowed.
|
||||||
*/
|
*/
|
||||||
public static String get(String key, String def) {
|
public static String get(String key, String def) {
|
||||||
String value = get(key);
|
if (key == null) {
|
||||||
if (value == null) {
|
throw new NullPointerException("key");
|
||||||
value = def;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
String value = props.getProperty(key);
|
||||||
|
if (value == null) {
|
||||||
|
return def;
|
||||||
|
}
|
||||||
|
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -64,17 +98,104 @@ final class SystemPropertyUtil {
|
|||||||
* {@code def} if there's no such property or if an access to the
|
* {@code def} if there's no such property or if an access to the
|
||||||
* specified property is not allowed.
|
* specified property is not allowed.
|
||||||
*/
|
*/
|
||||||
public static int get(String key, int def) {
|
public static boolean getBoolean(String key, boolean def) {
|
||||||
String value = get(key);
|
if (key == null) {
|
||||||
|
throw new NullPointerException("key");
|
||||||
|
}
|
||||||
|
|
||||||
|
String value = props.getProperty(key);
|
||||||
if (value == null) {
|
if (value == null) {
|
||||||
return def;
|
return def;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Pattern.matches("-?[0-9]+", value)) {
|
value = value.trim().toLowerCase();
|
||||||
return Integer.parseInt(value);
|
if (value.length() == 0) {
|
||||||
} else {
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (value.equals("true") || value.equals("yes") || value.equals("1")) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (value.equals("false") || value.equals("no") || value.equals("0")) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
logger.warn(
|
||||||
|
"Unable to parse the boolean system property '" + key + "':" + value + " - " +
|
||||||
|
"using the default value: " + def);
|
||||||
|
|
||||||
return def;
|
return def;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the value of the Java system property with the specified
|
||||||
|
* {@code key}, while falling back to the specified default value if
|
||||||
|
* the property access fails.
|
||||||
|
*
|
||||||
|
* @return the property value.
|
||||||
|
* {@code def} if there's no such property or if an access to the
|
||||||
|
* specified property is not allowed.
|
||||||
|
*/
|
||||||
|
public static int getInt(String key, int def) {
|
||||||
|
if (key == null) {
|
||||||
|
throw new NullPointerException("key");
|
||||||
|
}
|
||||||
|
|
||||||
|
String value = props.getProperty(key);
|
||||||
|
if (value == null) {
|
||||||
|
return def;
|
||||||
|
}
|
||||||
|
|
||||||
|
value = value.trim().toLowerCase();
|
||||||
|
if (value.matches("-?[0-9]+")) {
|
||||||
|
try {
|
||||||
|
return Integer.parseInt(value);
|
||||||
|
} catch (Exception e) {
|
||||||
|
// Ignore
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
logger.warn(
|
||||||
|
"Unable to parse the integer system property '" + key + "':" + value + " - " +
|
||||||
|
"using the default value: " + def);
|
||||||
|
|
||||||
|
return def;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the value of the Java system property with the specified
|
||||||
|
* {@code key}, while falling back to the specified default value if
|
||||||
|
* the property access fails.
|
||||||
|
*
|
||||||
|
* @return the property value.
|
||||||
|
* {@code def} if there's no such property or if an access to the
|
||||||
|
* specified property is not allowed.
|
||||||
|
*/
|
||||||
|
public static long getLong(String key, long def) {
|
||||||
|
if (key == null) {
|
||||||
|
throw new NullPointerException("key");
|
||||||
|
}
|
||||||
|
|
||||||
|
String value = props.getProperty(key);
|
||||||
|
if (value == null) {
|
||||||
|
return def;
|
||||||
|
}
|
||||||
|
|
||||||
|
value = value.trim().toLowerCase();
|
||||||
|
if (value.matches("-?[0-9]+")) {
|
||||||
|
try {
|
||||||
|
return Long.parseLong(value);
|
||||||
|
} catch (Exception e) {
|
||||||
|
// Ignore
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
logger.warn(
|
||||||
|
"Unable to parse the long integer system property '" + key + "':" + value + " - " +
|
||||||
|
"using the default value: " + def);
|
||||||
|
|
||||||
|
return def;
|
||||||
}
|
}
|
||||||
|
|
||||||
private SystemPropertyUtil() {
|
private SystemPropertyUtil() {
|
||||||
|
@ -17,6 +17,7 @@ package io.netty.channel.socket.nio;
|
|||||||
|
|
||||||
import io.netty.logging.InternalLogger;
|
import io.netty.logging.InternalLogger;
|
||||||
import io.netty.logging.InternalLoggerFactory;
|
import io.netty.logging.InternalLoggerFactory;
|
||||||
|
import io.netty.util.internal.SystemPropertyUtil;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.channels.CancelledKeyException;
|
import java.nio.channels.CancelledKeyException;
|
||||||
@ -27,8 +28,9 @@ final class SelectorUtil {
|
|||||||
private static final InternalLogger logger =
|
private static final InternalLogger logger =
|
||||||
InternalLoggerFactory.getInstance(SelectorUtil.class);
|
InternalLoggerFactory.getInstance(SelectorUtil.class);
|
||||||
static final long DEFAULT_SELECT_TIMEOUT = 10;
|
static final long DEFAULT_SELECT_TIMEOUT = 10;
|
||||||
static final long SELECT_TIMEOUT;
|
static final long SELECT_TIMEOUT =
|
||||||
static final long SELECT_TIMEOUT_NANOS;
|
SystemPropertyUtil.getLong("io.netty.selectTimeout", DEFAULT_SELECT_TIMEOUT);
|
||||||
|
static final long SELECT_TIMEOUT_NANOS = TimeUnit.MILLISECONDS.toNanos(SELECT_TIMEOUT);
|
||||||
|
|
||||||
// Workaround for JDK NIO bug.
|
// Workaround for JDK NIO bug.
|
||||||
//
|
//
|
||||||
@ -47,15 +49,7 @@ final class SelectorUtil {
|
|||||||
logger.debug("Unable to get/set System Property '" + key + "'", e);
|
logger.debug("Unable to get/set System Property '" + key + "'", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
long selectTimeout;
|
|
||||||
try {
|
|
||||||
selectTimeout = Long.parseLong(System.getProperty("io.netty.selectTimeout",
|
|
||||||
String.valueOf(DEFAULT_SELECT_TIMEOUT)));
|
|
||||||
} catch (NumberFormatException e) {
|
|
||||||
selectTimeout = DEFAULT_SELECT_TIMEOUT;
|
|
||||||
}
|
|
||||||
SELECT_TIMEOUT = selectTimeout;
|
|
||||||
SELECT_TIMEOUT_NANOS = TimeUnit.MILLISECONDS.toNanos(SELECT_TIMEOUT);
|
|
||||||
logger.debug("Using select timeout of " + SELECT_TIMEOUT);
|
logger.debug("Using select timeout of " + SELECT_TIMEOUT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user