2015-01-27 2 views
0

org.apache.camel.Service를 구현하는 맞춤 클래스를 추가하여 일부 기능을 노출했습니다. void를 반환하는 모든 메서드는 제대로 작동합니다. 이제 String (여러 줄)을 반환하는 메서드를 추가했습니다. jconsole의 또는 MissionControl 수율이 호출 :jmx 메소드를 공개하는 Camel 맞춤 서비스 - 예외 : 보안 관리자 없음 : RMI 클래스 로더 사용 안 함

java.rmi.UnmarshalException: Error unmarshaling return; nested exception is: 
    java.lang.ClassNotFoundException: javax.ws.rs.ProcessingException (no security manager: RMI class loader disabled) 
    at sun.rmi.transport.StreamRemoteCall.executeCall(StreamRemoteCall.java:246) 
    at sun.rmi.server.UnicastRef.invoke(UnicastRef.java:161) 
    at com.sun.jmx.remote.internal.PRef.invoke(Unknown Source) 
    at javax.management.remote.rmi.RMIConnectionImpl_Stub.invoke(Unknown Source) 
    at javax.management.remote.rmi.RMIConnector$RemoteMBeanServerConnection.invoke(RMIConnector.java:1029) 
    at com.jrockit.mc.rjmx.internal.MCMBeanServerConnection.invoke(MCMBeanServerConnection.java:234) 
    at com.jrockit.mc.rjmx.services.internal.MBeanOperationsWrapper$MBeanOperation$1.call(MBeanOperationsWrapper.java:133) 
    at com.jrockit.mc.rjmx.ui.operations.ExecuteOperationForm.createInvocationResult(ExecuteOperationForm.java:143) 
    at com.jrockit.mc.rjmx.ui.operations.ExecuteOperationForm.access$9(ExecuteOperationForm.java:138) 
    at com.jrockit.mc.rjmx.ui.operations.ExecuteOperationForm$3.widgetSelected(ExecuteOperationForm.java:125) 
    at org.eclipse.swt.widgets.TypedListener.handleEvent(TypedListener.java:248) 
    at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:84) 
    at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1053) 
    at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:4169) 
    at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3758) 
    at org.eclipse.ui.internal.Workbench.runEventLoop(Workbench.java:2701) 
    at org.eclipse.ui.internal.Workbench.runUI(Workbench.java:2665) 
    at org.eclipse.ui.internal.Workbench.access$4(Workbench.java:2499) 
    at org.eclipse.ui.internal.Workbench$7.run(Workbench.java:679) 
    at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332) 
    at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:668) 
    at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:149) 
    at com.jrockit.mc.rcp.application.Application.start(Application.java:26) 
    at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:196) 
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:110) 
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:79) 
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:353) 
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:180) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:606) 
    at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:629) 
    at org.eclipse.equinox.launcher.Main.basicRun(Main.java:584) 
    at org.eclipse.equinox.launcher.Main.run(Main.java:1438) 
    at org.eclipse.equinox.launcher.Main.main(Main.java:1414) 
Caused by: java.lang.ClassNotFoundException: javax.ws.rs.ProcessingException (no security manager: RMI class loader disabled) 
    at sun.rmi.server.LoaderHandler.loadClass(LoaderHandler.java:393) 
    at sun.rmi.server.LoaderHandler.loadClass(LoaderHandler.java:185) 
    at java.rmi.server.RMIClassLoader$2.loadClass(RMIClassLoader.java:637) 
    at java.rmi.server.RMIClassLoader.loadClass(RMIClassLoader.java:264) 
    at sun.rmi.server.MarshalInputStream.resolveClass(MarshalInputStream.java:214) 
    at java.io.ObjectInputStream.readNonProxyDesc(ObjectInputStream.java:1612) 
    at java.io.ObjectInputStream.readClassDesc(ObjectInputStream.java:1517) 
    at java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1771) 
    at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1350) 
    at java.io.ObjectInputStream.defaultReadFields(ObjectInputStream.java:1990) 
    at java.io.ObjectInputStream.readSerialData(ObjectInputStream.java:1915) 
    at java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1798) 
    at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1350) 
    at java.io.ObjectInputStream.readObject(ObjectInputStream.java:370) 
    at sun.rmi.transport.StreamRemoteCall.executeCall(StreamRemoteCall.java:244) 
    ... 35 more 

을 나는이 문제를 해결하는 몇 가지 낙타 방법이 있는지 물어 JMX의 아파치 낙타 층을 사용하고 있기 때문에?

+0

메소드가 호출 될 때 예외가 발생합니까? 아마 예외가 throw되지 않고 String 값이 반환되는지 확인하십시오. 어쩌면 단지 하드 코드를 시도하고 "Hello"등을 반환하려고 시도합니다. –

+0

감사합니다. Claus이 문제 였고, 테스트를 위해 로깅이 해제되었습니다 .-P. 이제 작동합니다. 답변으로 의견을 작성하면 받아 들일 것입니다 - 다른 사람들에게 도움이 될 수 있습니다 (예외는 다소 미스테 다). – dermoritz

답변

1

당신의 새로운 메소드가 예외 대상 (예 : jconsole 등)이 클래스 경로에없는 javax.ws.rs.ProcessingException과 같은 예외를 throw한다고 생각합니다.

예외가 throw되고 String 값이 반환되는지 확인하려고 할 수 있습니다. 어쩌면 그냥 하드 코드를 시도하고 "Hello"등을 반환하려고합니다. 예외가 발생하면 JDK 자체의 예외를 사용하여 예외를 throw하므로이 클래스 경로 문제가 발생하지 않습니다.

관련 문제