From b29a67b20278296f86fbab310f5d604d4a1447e7 Mon Sep 17 00:00:00 2001 From: Kim YoungJin Date: Tue, 25 Apr 2023 18:14:10 +0900 Subject: [PATCH] [#8890] Implemented findClass in Java9ClassLoader Removed manually registering providers which occurs duplication --- .../java9/classloader/Java9ClassLoader.java | 12 ++++++ .../bootstrap/java9/module/ModuleSupport.java | 40 +++---------------- .../java9/module/ModuleSupportFactory.java | 14 +------ 3 files changed, 18 insertions(+), 48 deletions(-) diff --git a/bootstraps/bootstrap-java9/src/main/java/com/navercorp/pinpoint/bootstrap/java9/classloader/Java9ClassLoader.java b/bootstraps/bootstrap-java9/src/main/java/com/navercorp/pinpoint/bootstrap/java9/classloader/Java9ClassLoader.java index d18aa7e2d1ac..61e60e8c20de 100644 --- a/bootstraps/bootstrap-java9/src/main/java/com/navercorp/pinpoint/bootstrap/java9/classloader/Java9ClassLoader.java +++ b/bootstraps/bootstrap-java9/src/main/java/com/navercorp/pinpoint/bootstrap/java9/classloader/Java9ClassLoader.java @@ -55,6 +55,18 @@ protected URL findResource(String moduleName, String name) throws IOException { return null; } + @Override + protected Class findClass(String moduleName, String name) { + if (getName().equals(moduleName)) { + try { + return this.findClass(name); + } catch (ClassNotFoundException e) { + return null; + } + } + return null; + } + @Override public InputStream getResourceAsStream(String name) { return super.getResourceAsStream(name); diff --git a/bootstraps/bootstrap-java9/src/main/java/com/navercorp/pinpoint/bootstrap/java9/module/ModuleSupport.java b/bootstraps/bootstrap-java9/src/main/java/com/navercorp/pinpoint/bootstrap/java9/module/ModuleSupport.java index 6eefd77b3809..a955d16f3f90 100644 --- a/bootstraps/bootstrap-java9/src/main/java/com/navercorp/pinpoint/bootstrap/java9/module/ModuleSupport.java +++ b/bootstraps/bootstrap-java9/src/main/java/com/navercorp/pinpoint/bootstrap/java9/module/ModuleSupport.java @@ -18,14 +18,11 @@ import com.navercorp.pinpoint.bootstrap.module.JavaModule; -import com.navercorp.pinpoint.bootstrap.module.Providers; import com.navercorp.pinpoint.common.util.JvmUtils; import com.navercorp.pinpoint.common.util.JvmVersion; import java.lang.instrument.Instrumentation; import java.net.URL; -import java.util.ArrayList; -import java.util.List; import java.util.Objects; /** @@ -40,15 +37,14 @@ public class ModuleSupport { private final JavaModule javaBaseModule; private final JavaModule bootstrapModule; - private final List allowedProviders; - ModuleSupport(Instrumentation instrumentation, List allowedProviders) { + ModuleSupport(Instrumentation instrumentation) { this.instrumentation = Objects.requireNonNull(instrumentation, "instrumentation"); - this.allowedProviders = Objects.requireNonNull(allowedProviders, "allowedProviders"); this.javaBaseModule = wrapJavaModule(Object.class); this.bootstrapModule = wrapJavaModule(this.getClass()); } + @SuppressWarnings("unused") // Used implicitly public void setup() { // pinpoint module name : unnamed JavaModule bootstrapModule = getBootstrapModule(); @@ -65,8 +61,8 @@ public void setup() { } + @SuppressWarnings("unused") // Used implicitly public void defineAgentModule(ClassLoader classLoader, URL[] jarFileList) { - final JavaModule agentModule = newAgentModule(classLoader, jarFileList); prepareAgentModule(classLoader, agentModule); @@ -92,7 +88,7 @@ private void addPermissionToValueAnnotation(JavaModule agentModule) { private JavaModule newAgentModule(ClassLoader classLoader, URL[] jarFileList) { ModuleBuilder moduleBuilder = new ModuleBuilder(); - final Module agentModule = moduleBuilder.defineModule("pinpoint.agent", classLoader, jarFileList); + final Module agentModule = moduleBuilder.defineModule(classLoader.getName(), classLoader, jarFileList); return wrapJavaModule(agentModule); } @@ -229,32 +225,6 @@ private void prepareAgentModule(final ClassLoader classLoader, JavaModule agentM final String watchEventServiceName = "org.apache.logging.log4j.core.util.WatchEventService"; Class watchEventServiceClazz = forName(watchEventServiceName, classLoader); agentModule.addUses(watchEventServiceClazz); - - List providersList = agentModule.getProviders(); - for (Providers providers : providersList) { - final String service = providers.getService(); - if (isAllowedProvider(service)) { - logger.info("load provider:" + providers); - Class serviceClass = forName(providers.getService(), classLoader); - List> providerClassList = loadProviderClassList(providers.getProviders(), classLoader); - agentModule.addProvides(serviceClass, providerClassList); - } else { - logger.info("discard provider:" + providers); - } - } - } - - public boolean isAllowedProvider(String serviceName) { - return allowedProviders.contains(serviceName); - } - - private List> loadProviderClassList(List classNameList, ClassLoader classLoader) { - List> providerClassList = new ArrayList<>(); - for (String providerClassName : classNameList) { - Class providerClass = forName(providerClassName, classLoader); - providerClassList.add(providerClass); - } - return providerClassList; } private Class forName(String className, ClassLoader classLoader) { @@ -281,7 +251,7 @@ private JavaModule loadModule(String moduleName) { // throw new ModuleException(moduleName + " not found"); } - private JavaModule wrapJavaModule(Class clazz) { + private JavaModule wrapJavaModule(Class clazz) { return new Java9Module(instrumentation, clazz.getModule()); } diff --git a/bootstraps/bootstrap-java9/src/main/java/com/navercorp/pinpoint/bootstrap/java9/module/ModuleSupportFactory.java b/bootstraps/bootstrap-java9/src/main/java/com/navercorp/pinpoint/bootstrap/java9/module/ModuleSupportFactory.java index cd31f5b64581..50a99d4b5a2d 100644 --- a/bootstraps/bootstrap-java9/src/main/java/com/navercorp/pinpoint/bootstrap/java9/module/ModuleSupportFactory.java +++ b/bootstraps/bootstrap-java9/src/main/java/com/navercorp/pinpoint/bootstrap/java9/module/ModuleSupportFactory.java @@ -17,8 +17,6 @@ package com.navercorp.pinpoint.bootstrap.java9.module; import java.lang.instrument.Instrumentation; -import java.util.Arrays; -import java.util.List; /** * @author Woonduk Kang(emeroad) @@ -28,16 +26,6 @@ public ModuleSupportFactory() { } public ModuleSupport newModuleSupport(Instrumentation instrumentation) { - // Dynamic changes are required? - // move to pinpoint.config? - List allowedProviders = Arrays.asList( - "io.grpc.NameResolverProvider", - "com.navercorp.pinpoint.agent.plugin.proxy.common.ProxyRequestMetadataProvider", - "com.navercorp.pinpoint.profiler.context.recorder.proxy.ProxyRequestParserProvider", - "io.grpc.ManagedChannelProvider", - "io.grpc.LoadBalancerProvider" - ); - - return new ModuleSupport(instrumentation, allowedProviders); + return new ModuleSupport(instrumentation); } }