[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Wei-Chiu Chuang updated HDFS-11851: --- Affects Version/s: 2.6.0 > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 2.6.0 >Reporter: Henry Robinson >Priority: Blocker > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Wei-Chiu Chuang updated HDFS-11851: --- Affects Version/s: (was: 2.6.0) 3.0.0-alpha3 > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha3 >Reporter: Henry Robinson >Priority: Blocker > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Sailesh Mukil updated HDFS-11851: - Attachment: HDFS-11851.000.patch > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha3 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Attachments: HDFS-11851.000.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Sailesh Mukil updated HDFS-11851: - Status: Patch Available (was: In Progress) > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha3 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Attachments: HDFS-11851.000.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Sailesh Mukil updated HDFS-11851: - Attachment: HDFS-11851.001.patch > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha3 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Attachments: HDFS-11851.000.patch, HDFS-11851.001.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Sailesh Mukil updated HDFS-11851: - Status: Patch Available (was: Open) > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha3 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Attachments: HDFS-11851.000.patch, HDFS-11851.001.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Sailesh Mukil updated HDFS-11851: - Status: Open (was: Patch Available) > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha3 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Attachments: HDFS-11851.000.patch, HDFS-11851.001.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Andrew Wang updated HDFS-11851: --- Target Version/s: 3.0.0-alpha3 > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha3 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Attachments: HDFS-11851.000.patch, HDFS-11851.001.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Sailesh Mukil updated HDFS-11851: - Status: Open (was: Patch Available) > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha3 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Attachments: HDFS-11851.000.patch, HDFS-11851.001.patch, > HDFS-11851.002.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Sailesh Mukil updated HDFS-11851: - Status: Patch Available (was: Open) > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha3 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Attachments: HDFS-11851.000.patch, HDFS-11851.001.patch, > HDFS-11851.002.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Sailesh Mukil updated HDFS-11851: - Attachment: HDFS-11851.002.patch > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha3 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Attachments: HDFS-11851.000.patch, HDFS-11851.001.patch, > HDFS-11851.002.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Sailesh Mukil updated HDFS-11851: - Attachment: HDFS-11851.003.patch > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha4 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Attachments: HDFS-11851.000.patch, HDFS-11851.001.patch, > HDFS-11851.002.patch, HDFS-11851.003.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Sailesh Mukil updated HDFS-11851: - Status: Open (was: Patch Available) > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha4 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Attachments: HDFS-11851.000.patch, HDFS-11851.001.patch, > HDFS-11851.002.patch, HDFS-11851.003.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Sailesh Mukil updated HDFS-11851: - Status: Patch Available (was: Open) > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha4 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Attachments: HDFS-11851.000.patch, HDFS-11851.001.patch, > HDFS-11851.002.patch, HDFS-11851.003.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Sailesh Mukil updated HDFS-11851: - Status: Open (was: Patch Available) > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha4 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Attachments: HDFS-11851.000.patch, HDFS-11851.001.patch, > HDFS-11851.002.patch, HDFS-11851.003.patch, HDFS-11851.004.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Sailesh Mukil updated HDFS-11851: - Attachment: HDFS-11851.004.patch > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha4 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Attachments: HDFS-11851.000.patch, HDFS-11851.001.patch, > HDFS-11851.002.patch, HDFS-11851.003.patch, HDFS-11851.004.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Sailesh Mukil updated HDFS-11851: - Attachment: HDFS-11851.005.patch > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha4 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Attachments: HDFS-11851.000.patch, HDFS-11851.001.patch, > HDFS-11851.002.patch, HDFS-11851.003.patch, HDFS-11851.004.patch, > HDFS-11851.005.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Sailesh Mukil updated HDFS-11851: - Status: Patch Available (was: Open) > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha4 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Attachments: HDFS-11851.000.patch, HDFS-11851.001.patch, > HDFS-11851.002.patch, HDFS-11851.003.patch, HDFS-11851.004.patch, > HDFS-11851.005.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org
[jira] [Updated] (HDFS-11851) getGlobalJNIEnv() may deadlock if exception is thrown
[ https://issues.apache.org/jira/browse/HDFS-11851?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] John Zhuge updated HDFS-11851: -- Resolution: Fixed Fix Version/s: 3.0.0-alpha4 Status: Resolved (was: Patch Available) Committed to trunk. Thanks [~sailesh] for the contribution. > getGlobalJNIEnv() may deadlock if exception is thrown > - > > Key: HDFS-11851 > URL: https://issues.apache.org/jira/browse/HDFS-11851 > Project: Hadoop HDFS > Issue Type: Bug > Components: libhdfs >Affects Versions: 3.0.0-alpha4 >Reporter: Henry Robinson >Assignee: Sailesh Mukil >Priority: Blocker > Fix For: 3.0.0-alpha4 > > Attachments: HDFS-11851.000.patch, HDFS-11851.001.patch, > HDFS-11851.002.patch, HDFS-11851.003.patch, HDFS-11851.004.patch, > HDFS-11851.005.patch > > > HDFS-11529 introduced a deadlock into {{getGlobalJNIEnv()}} if an exception > is thrown. {{getGlobalJNIEnv()}} holds {{jvmMutex}}, but > {{printExceptionAndFree()}} will eventually try to acquire that lock in > {{setTLSExceptionStrings()}}. > The exception might get caught from {{loadFileSystems}}: > {code} > jthr = invokeMethod(env, NULL, STATIC, NULL, > "org/apache/hadoop/fs/FileSystem", > "loadFileSystems", "()V"); > if (jthr) { > printExceptionAndFree(env, jthr, PRINT_EXC_ALL, > "loadFileSystems"); > } > } > {code} > and here's the relevant parts of the stack trace from where I call this API > in Impala, which uses {{libhdfs}}: > {code} > #0 __lll_lock_wait () at > ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:135 > #1 0x74a8d657 in _L_lock_909 () from > /lib/x86_64-linux-gnu/libpthread.so.0 > #2 0x74a8d480 in __GI___pthread_mutex_lock (mutex=0x47ce960 > ) at ../nptl/pthread_mutex_lock.c:79 > #3 0x02f06056 in mutexLock (m=) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/os/posix/mutexes.c:28 > #4 0x02efe817 in setTLSExceptionStrings (rootCause=0x0, > stackTrace=0x0) at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:581 > #5 0x02f065d7 in printExceptionAndFreeV (env=0x513c1e8, > exc=0x508a8c0, noPrintFlags=, fmt=0x34349cf "loadFileSystems", > ap=0x7fffb660) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:183 > #6 0x02f0683d in printExceptionAndFree (env=, > exc=, noPrintFlags=, fmt=) > at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/exception.c:213 > #7 0x02eff60f in getGlobalJNIEnv () at > /data/2/jenkins/workspace/impala-hadoop-dependency/hadoop/hadoop-hdfs-project/hadoop-hdfs/src/main/native/libhdfs/jni_helper.c:463 > {code} -- This message was sent by Atlassian JIRA (v6.3.15#6346) - To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org