Nick Lawrence created NIFI-7923:
-----------------------------------
Summary: Nar Auto-Loader cannot recover from Throwable/Error
Key: NIFI-7923
URL: https://issues.apache.org/jira/browse/NIFI-7923
Project: Apache NiFi
Issue Type: Bug
Components: Extensions
Affects Versions: 1.12.0
Reporter: Nick Lawrence
When a nar is built against an up-level JVM, a java Error is thrown while
loading the nar extension. The Throwable is not handled as the code only
handles sub classes of Exception. As a result the thread dies, and when a
corrected nar is later installed, the nar cannot be loaded. Restart of nifi
causes the updated nar to be loaded.
2020-10-14 13:31:55,340 INFO [NAR Auto-Loader] ->
org.apache.nifi.nar.NarClassLoaders -> Loaded NAR file:
/opt/nifi/./work/nar/extensions/nifi-hri-nar-1.0-SNAPSHOT.nar-unpacked as class
loader
org.apache.nifi.nar.NarClassLoader[./work/nar/extensions/nifi-hri-nar-1.0-SNAPSHOT.nar-unpacked]
2020-10-14 13:31:55,342 INFO [NAR Auto-Loader] ->
org.apache.nifi.nar.StandardNarLoader -> Successfully created class loaders for
1 NARs, 0 were skipped
2020-10-14 13:31:55,395 ERROR [NAR Auto-Loader] -> org.apache.nifi.NiFi -> An
Unknown Error Occurred in Thread Thread[NAR Auto-Loader,5,main]:
java.lang.UnsupportedClassVersionError:
com/ibm/watson/health/wffh/nifi/processors/hri/GetHriIngestRecords has been
compiled by a more recent version of the Java Runtime (class file version
55.0), this version of the Java Runtime only recognizes class file versions up
to 52.0
2020-10-14 13:31:55,396 ERROR [NAR Auto-Loader] -> org.apache.nifi.NiFi ->
java.lang.UnsupportedClassVersionError:
com/ibm/watson/health/wffh/nifi/processors/hri/GetHriIngestRecords has been
compiled by a more recent version of the Java Runtime (class file version
55.0), this version of the Java Runtime only recognizes class file versions up
to 52.0
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClass(ClassLoader.java:756)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:468)
at java.net.URLClassLoader.access$100(URLClassLoader.java:74)
at java.net.URLClassLoader$1.run(URLClassLoader.java:369)
at java.net.URLClassLoader$1.run(URLClassLoader.java:363)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:362)
at java.lang.ClassLoader.loadClass(ClassLoader.java:418)
at java.lang.ClassLoader.loadClass(ClassLoader.java:351)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:348)
at java.util.ServiceLoader$LazyIterator.nextService(ServiceLoader.java:370)
at java.util.ServiceLoader$LazyIterator.next(ServiceLoader.java:404)
at java.util.ServiceLoader$1.next(ServiceLoader.java:480)
at
org.apache.nifi.nar.StandardExtensionDiscoveringManager.loadExtensions(StandardExtensionDiscoveringManager.java:156)
at
org.apache.nifi.nar.StandardExtensionDiscoveringManager.discoverExtensions(StandardExtensionDiscoveringManager.java:131)
at org.apache.nifi.nar.StandardNarLoader.load(StandardNarLoader.java:110)
at org.apache.nifi.nar.NarAutoLoaderTask.run(NarAutoLoaderTask.java:128)
at java.lang.Thread.run(Thread.java:748)
I looked at the source enough to believe that the Error is not handled anywhere
between StandardExtensionDiscovingManager.loadExtensions and
NarAutoLoaderTask.run.
I see no messages in the log that suggest that the updated nar is processed
after it is placed in the extensions directory.
--
This message was sent by Atlassian Jira
(v8.3.4#803005)