HDFS-14818. Check native pmdk lib by 'hadoop checknative' command. Contributed by Feilong He.

This commit is contained in:
Rakesh Radhakrishnan 2019-09-22 22:02:54 +05:30
parent a94aa1ff46
commit 659c88801d
7 changed files with 72 additions and 30 deletions

View File

@ -170,7 +170,7 @@ if(REQUIRE_PMDK)
set(CMAKE_FIND_LIBRARY_SUFFIXES ${STORED_CMAKE_FIND_LIBRARY_SUFFIXES}) set(CMAKE_FIND_LIBRARY_SUFFIXES ${STORED_CMAKE_FIND_LIBRARY_SUFFIXES})
if(PMDK_LIBRARY) if(PMDK_LIBRARY)
GET_FILENAME_COMPONENT(HADOOP_PMDK_LIBRARY ${PMDK_LIBRARY} NAME) GET_FILENAME_COMPONENT(HADOOP_PMDK_LIBRARY ${PMDK_LIBRARY} REALPATH)
set(PMDK_SOURCE_FILES ${SRC}/io/nativeio/pmdk_load.c) set(PMDK_SOURCE_FILES ${SRC}/io/nativeio/pmdk_load.c)
else(PMDK_LIBRARY) else(PMDK_LIBRARY)
MESSAGE(FATAL_ERROR "The required PMDK library is NOT found. PMDK_LIBRARY=${PMDK_LIBRARY}") MESSAGE(FATAL_ERROR "The required PMDK library is NOT found. PMDK_LIBRARY=${PMDK_LIBRARY}")

View File

@ -120,16 +120,19 @@ public class NativeIO {
public String getMessage() { public String getMessage() {
String msg; String msg;
switch (stateCode) { switch (stateCode) {
// -1 represents UNSUPPORTED.
case -1: case -1:
msg = "The native code is built without PMDK support."; msg = "The native code was built without PMDK support.";
break; break;
// 1 represents PMDK_LIB_NOT_FOUND.
case 1: case 1:
msg = "The native code is built with PMDK support, but PMDK libs " + msg = "The native code was built with PMDK support, but PMDK libs " +
"are NOT found in execution environment or failed to be loaded."; "were NOT found in execution environment or failed to be loaded.";
break; break;
// 0 represents SUPPORTED.
case 0: case 0:
msg = "The native code is built with PMDK support, and PMDK libs " + msg = "The native code was built with PMDK support, and PMDK libs " +
"are loaded successfully."; "were loaded successfully.";
break; break;
default: default:
msg = "The state code: " + stateCode + " is unrecognized!"; msg = "The state code: " + stateCode + " is unrecognized!";
@ -140,7 +143,7 @@ public class NativeIO {
// Denotes the state of supporting PMDK. The value is set by JNI. // Denotes the state of supporting PMDK. The value is set by JNI.
private static SupportState pmdkSupportState = private static SupportState pmdkSupportState =
SupportState.PMDK_LIB_NOT_FOUND; SupportState.UNSUPPORTED;
private static final Logger LOG = LoggerFactory.getLogger(NativeIO.class); private static final Logger LOG = LoggerFactory.getLogger(NativeIO.class);
@ -177,6 +180,14 @@ public class NativeIO {
LOG.error("The state code: " + stateCode + " is unrecognized!"); LOG.error("The state code: " + stateCode + " is unrecognized!");
} }
public static String getPmdkSupportStateMessage() {
if (getPmdkLibPath() != null) {
return pmdkSupportState.getMessage() +
" The pmdk lib path: " + getPmdkLibPath();
}
return pmdkSupportState.getMessage();
}
public static boolean isPmdkAvailable() { public static boolean isPmdkAvailable() {
LOG.info(pmdkSupportState.getMessage()); LOG.info(pmdkSupportState.getMessage());
return pmdkSupportState == SupportState.SUPPORTED; return pmdkSupportState == SupportState.SUPPORTED;
@ -242,8 +253,13 @@ public class NativeIO {
NativeIO.POSIX.pmemSync(region.getAddress(), region.getLength()); NativeIO.POSIX.pmemSync(region.getAddress(), region.getLength());
} }
} }
public static String getPmdkLibPath() {
return POSIX.getPmdkLibPath();
}
} }
private static native String getPmdkLibPath();
private static native boolean isPmemCheck(long address, long length); private static native boolean isPmemCheck(long address, long length);
private static native PmemMappedRegion pmemCreateMapFile(String path, private static native PmemMappedRegion pmemCreateMapFile(String path,
long length); long length);

View File

@ -28,6 +28,7 @@ import org.apache.hadoop.io.compress.bzip2.Bzip2Factory;
import org.apache.hadoop.io.compress.zlib.ZlibFactory; import org.apache.hadoop.io.compress.zlib.ZlibFactory;
import org.apache.hadoop.classification.InterfaceAudience; import org.apache.hadoop.classification.InterfaceAudience;
import org.apache.hadoop.classification.InterfaceStability; import org.apache.hadoop.classification.InterfaceStability;
import org.apache.hadoop.io.nativeio.NativeIO;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -69,6 +70,7 @@ public class NativeLibraryChecker {
boolean snappyLoaded = false; boolean snappyLoaded = false;
boolean isalLoaded = false; boolean isalLoaded = false;
boolean zStdLoaded = false; boolean zStdLoaded = false;
boolean pmdkLoaded = false;
// lz4 is linked within libhadoop // lz4 is linked within libhadoop
boolean lz4Loaded = nativeHadoopLoaded; boolean lz4Loaded = nativeHadoopLoaded;
boolean bzip2Loaded = Bzip2Factory.isNativeBzip2Loaded(conf); boolean bzip2Loaded = Bzip2Factory.isNativeBzip2Loaded(conf);
@ -80,6 +82,7 @@ public class NativeLibraryChecker {
String zlibLibraryName = ""; String zlibLibraryName = "";
String snappyLibraryName = ""; String snappyLibraryName = "";
String isalDetail = ""; String isalDetail = "";
String pmdkDetail = "";
String zstdLibraryName = ""; String zstdLibraryName = "";
String lz4LibraryName = ""; String lz4LibraryName = "";
String bzip2LibraryName = ""; String bzip2LibraryName = "";
@ -110,6 +113,12 @@ public class NativeLibraryChecker {
isalLoaded = true; isalLoaded = true;
} }
pmdkDetail = NativeIO.POSIX.getPmdkSupportStateMessage();
pmdkLoaded = NativeIO.POSIX.isPmdkAvailable();
if (pmdkLoaded) {
pmdkDetail = NativeIO.POSIX.Pmem.getPmdkLibPath();
}
openSslDetail = OpensslCipher.getLoadingFailureReason(); openSslDetail = OpensslCipher.getLoadingFailureReason();
if (openSslDetail != null) { if (openSslDetail != null) {
openSslLoaded = false; openSslLoaded = false;
@ -148,6 +157,7 @@ public class NativeLibraryChecker {
System.out.printf("bzip2: %b %s%n", bzip2Loaded, bzip2LibraryName); System.out.printf("bzip2: %b %s%n", bzip2Loaded, bzip2LibraryName);
System.out.printf("openssl: %b %s%n", openSslLoaded, openSslDetail); System.out.printf("openssl: %b %s%n", openSslLoaded, openSslDetail);
System.out.printf("ISA-L: %b %s%n", isalLoaded, isalDetail); System.out.printf("ISA-L: %b %s%n", isalLoaded, isalDetail);
System.out.printf("PMDK: %b %s%n", pmdkLoaded, pmdkDetail);
if (Shell.WINDOWS) { if (Shell.WINDOWS) {
System.out.printf("winutils: %b %s%n", winutilsExists, winutilsPath); System.out.printf("winutils: %b %s%n", winutilsExists, winutilsPath);

View File

@ -292,10 +292,13 @@ static int loadPmdkLib(JNIEnv *env) {
if (mid == 0) { if (mid == 0) {
return 0; return 0;
} }
if (strlen(errMsg) > 0) { if (strlen(errMsg) > 0) {
// Set PMDK support state to 1 which represents PMDK_LIB_NOT_FOUND.
(*env)->CallStaticVoidMethod(env, clazz, mid, 1); (*env)->CallStaticVoidMethod(env, clazz, mid, 1);
return 0; return 0;
} }
// Set PMDK support state to 0 which represents SUPPORTED.
(*env)->CallStaticVoidMethod(env, clazz, mid, 0); (*env)->CallStaticVoidMethod(env, clazz, mid, 0);
return 1; return 1;
} }
@ -1620,7 +1623,7 @@ JNIEXPORT void JNICALL Java_org_apache_hadoop_io_nativeio_NativeIO_00024POSIX_pm
char msg[1000]; char msg[1000];
succeed = pmdkLoader->pmem_msync(address, length); succeed = pmdkLoader->pmem_msync(address, length);
// succeed = -1 failure // succeed = -1 failure
if (succeed = -1) { if (succeed == -1) {
snprintf(msg, sizeof(msg), "Failed to msync region. address: %x, length: %x, error msg: %s", address, length, pmem_errormsg()); snprintf(msg, sizeof(msg), "Failed to msync region. address: %x, length: %x, error msg: %s", address, length, pmem_errormsg());
THROW(env, "java/io/IOException", msg); THROW(env, "java/io/IOException", msg);
return; return;
@ -1631,6 +1634,15 @@ JNIEXPORT void JNICALL Java_org_apache_hadoop_io_nativeio_NativeIO_00024POSIX_pm
#endif #endif
} }
JNIEXPORT jstring JNICALL Java_org_apache_hadoop_io_nativeio_NativeIO_00024POSIX_getPmdkLibPath
(JNIEnv * env, jclass thisClass) {
jstring libpath = NULL;
#ifdef HADOOP_PMDK_LIBRARY
libpath = (*env)->NewStringUTF(env, HADOOP_PMDK_LIBRARY);
#endif
return libpath;
}
#ifdef __cplusplus #ifdef __cplusplus
} }

View File

@ -79,11 +79,6 @@ void *myDlsym(void *handle, const char *symbol) {
#endif #endif
/**
* Return 0 if not support, 1 otherwise.
*/
int build_support_pmdk();
/** /**
* Initialize and load PMDK library, returning error message if any. * Initialize and load PMDK library, returning error message if any.
* *

View File

@ -267,8 +267,8 @@ public class FsDatasetCache {
Value prevValue = mappableBlockMap.get(key); Value prevValue = mappableBlockMap.get(key);
boolean deferred = false; boolean deferred = false;
if (!dataset.datanode.getShortCircuitRegistry(). if (cacheLoader.isTransientCache() && !dataset.datanode.
processBlockMunlockRequest(key)) { getShortCircuitRegistry().processBlockMunlockRequest(key)) {
deferred = true; deferred = true;
} }
if (prevValue == null) { if (prevValue == null) {
@ -438,7 +438,11 @@ public class FsDatasetCache {
} }
LOG.debug("Successfully cached {}. We are now caching {} bytes in" LOG.debug("Successfully cached {}. We are now caching {} bytes in"
+ " total.", key, newUsedBytes); + " total.", key, newUsedBytes);
dataset.datanode.getShortCircuitRegistry().processBlockMlockEvent(key); // Only applicable to DRAM cache.
if (cacheLoader.isTransientCache()) {
dataset.datanode.
getShortCircuitRegistry().processBlockMlockEvent(key);
}
numBlocksCached.addAndGet(1); numBlocksCached.addAndGet(1);
dataset.datanode.getMetrics().incrBlocksCached(1); dataset.datanode.getMetrics().incrBlocksCached(1);
success = true; success = true;
@ -476,6 +480,11 @@ public class FsDatasetCache {
} }
private boolean shouldDefer() { private boolean shouldDefer() {
// Currently, defer condition is just checked for DRAM cache case.
if (!cacheLoader.isTransientCache()) {
return false;
}
/* If revocationTimeMs == 0, this is an immediate uncache request. /* If revocationTimeMs == 0, this is an immediate uncache request.
* No clients were anchored at the time we made the request. */ * No clients were anchored at the time we made the request. */
if (revocationTimeMs == 0) { if (revocationTimeMs == 0) {