[
https://issues.apache.org/jira/browse/FLINK-22639?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Chesnay Schepler closed FLINK-22639.
------------------------------------
Fix Version/s: 1.14.0
Resolution: Fixed
master: d67064d6829335bcbdbb12961ea821dd1565dd1e
> ClassLoaderUtil cannot print classpath of FlinkUserCodeClassLoader
> ------------------------------------------------------------------
>
> Key: FLINK-22639
> URL: https://issues.apache.org/jira/browse/FLINK-22639
> Project: Flink
> Issue Type: Improvement
> Components: Runtime / Configuration
> Affects Versions: 1.13.0
> Reporter: Adrian Zhong
> Priority: Major
> Labels: Classloader, pull-request-available, runtime
> Fix For: 1.14.0
>
>
> Hello, community.
> I found FlinkUserCodeClassLoader is wrapping by
> SafetyNetWrapperClassLoader, but it cut getURL invoking chain.
>
> ClassLoaderUtil.getUserCodeClassLoaderInfo:
> {code:java}
> public static String getUserCodeClassLoaderInfo(ClassLoader loader) {
> if (loader instanceof URLClassLoader) {
> URLClassLoader cl = (URLClassLoader) loader;
> try {
> StringBuilder bld = new StringBuilder();
> if (cl == ClassLoader.getSystemClassLoader()) {
> bld.append("System ClassLoader: ");
> } else {
> bld.append("URL ClassLoader:");
> }
> for (URL url : cl.getURLs()) {
> }
> }{code}
> {code:java}
> SafetyNetWrapperClassLoader(FlinkUserCodeClassLoader inner, ClassLoader
> parent) {
> super(new URL[0], parent);
> this.inner = inner;
> }
> {code}
> The constructor passed an empty array to super class,
> SafetyNetWrapperClassLoader.getURL {color:#505f79}*should dispatch this
> invocation*{color}.
> {code:java}
> @Override
> public URL[] getURLs() {
> return inner.getURLs();
> }
> {code}
> Otherwise,
> {code:java}
> ClassLoaderUtil.getUserCodeClassLoaderInfo(theJarClassLoader);
> {code}
> will print empty, like below:
> {code:java}
> URL ClassLoader:
> {code}
>
>
--
This message was sent by Atlassian Jira
(v8.3.4#803005)