Do not log CNFE when tcnative is not in classpath

Motivation:

When a user deliberatively omitted netty-tcnative from classpath, he or
she will see an ugly stack trace of ClassNotFoundException.

Modifications:

Log more briefly when netty-tcnative is not in classpath.

Result:

Better-looking log at DEBUG level
This commit is contained in:
Trustin Lee 2015-01-08 12:23:14 +09:00
parent 851ca79ea6
commit f0a4802d1f

View File

@ -41,16 +41,31 @@ public final class OpenSsl {
static { static {
Throwable cause = null; Throwable cause = null;
// Test if netty-tcnative is in the classpath first.
try { try {
NativeLibraryLoader.load("netty-tcnative", SSL.class.getClassLoader()); Class.forName("org.apache.tomcat.jni.SSL", false, OpenSsl.class.getClassLoader());
Library.initialize("provided"); } catch (ClassNotFoundException t) {
SSL.initialize(null);
} catch (Throwable t) {
cause = t; cause = t;
logger.debug( logger.debug(
"Failed to load netty-tcnative; " + "netty-tcnative not in the classpath; " +
OpenSslEngine.class.getSimpleName() + " will be unavailable.", t); OpenSslEngine.class.getSimpleName() + " will be unavailable.");
} }
// If in the classpath, try to load the native library and initialize netty-tcnative.
if (cause == null) {
try {
NativeLibraryLoader.load("netty-tcnative", SSL.class.getClassLoader());
Library.initialize("provided");
SSL.initialize(null);
} catch (Throwable t) {
cause = t;
logger.debug(
"Failed to load netty-tcnative; " +
OpenSslEngine.class.getSimpleName() + " will be unavailable.", t);
}
}
UNAVAILABILITY_CAUSE = cause; UNAVAILABILITY_CAUSE = cause;
if (cause == null) { if (cause == null) {