Commit 044a3c549df302f3f641f2e165a48614b89d1be1
1 parent
07af24ef
Exists in
master
Resolvido bug que impedia chamadas remotas JMX devido a classloader
ativado ser diferente do que carregou os recursos da aplicação.
Showing
1 changed file
with
33 additions
and
3 deletions
Show diff stats
impl/extension/jmx/src/main/java/br/gov/frameworkdemoiselle/internal/proxy/DynamicMBeanProxy.java
| @@ -96,9 +96,15 @@ public class DynamicMBeanProxy implements DynamicMBean { | @@ -96,9 +96,15 @@ public class DynamicMBeanProxy implements DynamicMBean { | ||
| 96 | initializeMBeanInfo(); | 96 | initializeMBeanInfo(); |
| 97 | } | 97 | } |
| 98 | 98 | ||
| 99 | - Management manager = Beans.getReference(Management.class); | 99 | + |
| 100 | + //Define temporariamente o classloader para o classloader que carregou a classe Management. | ||
| 101 | + //Isso evita problemas onde recursos necessários para executar o ManagementController não estão disponíveis | ||
| 102 | + //para o classloader da chamada JMX. | ||
| 103 | + final ClassLoader originalClassloader = Thread.currentThread().getContextClassLoader(); | ||
| 100 | 104 | ||
| 101 | try{ | 105 | try{ |
| 106 | + Thread.currentThread().setContextClassLoader( Management.class.getClassLoader() ); | ||
| 107 | + Management manager = Beans.getReference(Management.class); | ||
| 102 | return manager.getProperty(managedType, attribute); | 108 | return manager.getProperty(managedType, attribute); |
| 103 | } | 109 | } |
| 104 | catch(DemoiselleException de){ | 110 | catch(DemoiselleException de){ |
| @@ -112,6 +118,10 @@ public class DynamicMBeanProxy implements DynamicMBean { | @@ -112,6 +118,10 @@ public class DynamicMBeanProxy implements DynamicMBean { | ||
| 112 | throw de; | 118 | throw de; |
| 113 | } | 119 | } |
| 114 | } | 120 | } |
| 121 | + finally{ | ||
| 122 | + //Devolve o classloader original. | ||
| 123 | + Thread.currentThread().setContextClassLoader( originalClassloader ); | ||
| 124 | + } | ||
| 115 | } | 125 | } |
| 116 | 126 | ||
| 117 | @Override | 127 | @Override |
| @@ -123,9 +133,15 @@ public class DynamicMBeanProxy implements DynamicMBean { | @@ -123,9 +133,15 @@ public class DynamicMBeanProxy implements DynamicMBean { | ||
| 123 | initializeMBeanInfo(); | 133 | initializeMBeanInfo(); |
| 124 | } | 134 | } |
| 125 | 135 | ||
| 126 | - Management manager = Beans.getReference(Management.class); | 136 | + |
| 137 | + //Define temporariamente o classloader para o classloader que carregou a classe Management. | ||
| 138 | + //Isso evita problemas onde recursos necessários para executar o ManagementController não estão disponíveis | ||
| 139 | + //para o classloader da chamada JMX. | ||
| 140 | + final ClassLoader originalClassloader = Thread.currentThread().getContextClassLoader(); | ||
| 127 | 141 | ||
| 128 | try{ | 142 | try{ |
| 143 | + Thread.currentThread().setContextClassLoader( Management.class.getClassLoader() ); | ||
| 144 | + Management manager = Beans.getReference(Management.class); | ||
| 129 | manager.setProperty(managedType, attribute.getName(), attribute.getValue()); | 145 | manager.setProperty(managedType, attribute.getName(), attribute.getValue()); |
| 130 | } | 146 | } |
| 131 | catch(DemoiselleException de){ | 147 | catch(DemoiselleException de){ |
| @@ -139,6 +155,10 @@ public class DynamicMBeanProxy implements DynamicMBean { | @@ -139,6 +155,10 @@ public class DynamicMBeanProxy implements DynamicMBean { | ||
| 139 | throw de; | 155 | throw de; |
| 140 | } | 156 | } |
| 141 | } | 157 | } |
| 158 | + finally{ | ||
| 159 | + //Devolve o classloader original. | ||
| 160 | + Thread.currentThread().setContextClassLoader( originalClassloader ); | ||
| 161 | + } | ||
| 142 | } | 162 | } |
| 143 | 163 | ||
| 144 | @Override | 164 | @Override |
| @@ -190,14 +210,24 @@ public class DynamicMBeanProxy implements DynamicMBean { | @@ -190,14 +210,24 @@ public class DynamicMBeanProxy implements DynamicMBean { | ||
| 190 | initializeMBeanInfo(); | 210 | initializeMBeanInfo(); |
| 191 | } | 211 | } |
| 192 | 212 | ||
| 193 | - Management manager = Beans.getReference(Management.class); | 213 | + |
| 214 | + //Define temporariamente o classloader para o classloader que carregou a classe Management. | ||
| 215 | + //Isso evita problemas onde recursos necessários para executar o ManagementController não estão disponíveis | ||
| 216 | + //para o classloader da chamada JMX. | ||
| 217 | + final ClassLoader originalClassloader = Thread.currentThread().getContextClassLoader(); | ||
| 194 | 218 | ||
| 195 | try{ | 219 | try{ |
| 220 | + Thread.currentThread().setContextClassLoader( Management.class.getClassLoader() ); | ||
| 221 | + Management manager = Beans.getReference(Management.class); | ||
| 196 | return manager.invoke(managedType, actionName, params); | 222 | return manager.invoke(managedType, actionName, params); |
| 197 | } | 223 | } |
| 198 | catch(DemoiselleException de){ | 224 | catch(DemoiselleException de){ |
| 199 | throw new MBeanException(new Exception(de.getMessage())); | 225 | throw new MBeanException(new Exception(de.getMessage())); |
| 200 | } | 226 | } |
| 227 | + finally{ | ||
| 228 | + //Devolve o classloader original. | ||
| 229 | + Thread.currentThread().setContextClassLoader( originalClassloader ); | ||
| 230 | + } | ||
| 201 | } | 231 | } |
| 202 | 232 | ||
| 203 | /** | 233 | /** |