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 | 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 | 105 | try{ |
106 | + Thread.currentThread().setContextClassLoader( Management.class.getClassLoader() ); | |
107 | + Management manager = Beans.getReference(Management.class); | |
102 | 108 | return manager.getProperty(managedType, attribute); |
103 | 109 | } |
104 | 110 | catch(DemoiselleException de){ |
... | ... | @@ -112,6 +118,10 @@ public class DynamicMBeanProxy implements DynamicMBean { |
112 | 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 | 127 | @Override |
... | ... | @@ -123,9 +133,15 @@ public class DynamicMBeanProxy implements DynamicMBean { |
123 | 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 | 142 | try{ |
143 | + Thread.currentThread().setContextClassLoader( Management.class.getClassLoader() ); | |
144 | + Management manager = Beans.getReference(Management.class); | |
129 | 145 | manager.setProperty(managedType, attribute.getName(), attribute.getValue()); |
130 | 146 | } |
131 | 147 | catch(DemoiselleException de){ |
... | ... | @@ -139,6 +155,10 @@ public class DynamicMBeanProxy implements DynamicMBean { |
139 | 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 | 164 | @Override |
... | ... | @@ -190,14 +210,24 @@ public class DynamicMBeanProxy implements DynamicMBean { |
190 | 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 | 219 | try{ |
220 | + Thread.currentThread().setContextClassLoader( Management.class.getClassLoader() ); | |
221 | + Management manager = Beans.getReference(Management.class); | |
196 | 222 | return manager.invoke(managedType, actionName, params); |
197 | 223 | } |
198 | 224 | catch(DemoiselleException de){ |
199 | 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 | /** | ... | ... |