Camel 2.9 - JMX and reducing Spring dependencyPage edited by Claus IbsenChanges (1)
Full ContentCamel 2.9 - JMX and reducing Spring dependencyThis note covers the goal for Camel 2.9 to reduce Spring dependency in camel-core and other Components where Spring is not really needed. BackgroundIn camel-core we support Spring JMX annotations when we enlist MBeans in JMX. In fact Spring JMX must be on the classpath to be able to use JMX with Camel at all. Some Camel Components such as Velocity, FreeMarker, XSLT uses Spring Resource API to load resources over the classpath etc. This does not work in OSGi blueprint, etc. Instead we should rely on the Pluggable Class Resolvers provided by Camel that works with OSGi, JBoss and other containers. DesignThe Spring JMX annotation support code in camel-core should be moved to camel-spring. This allows people to keep using Spring JMX annotations. We should provide a basic set of Camel JMX annotations in camel-core that the various Camel Components should use. This ensures we its stil easy to have Components enlist in JMX with custom attributes and operations. For example Apache ActiveMQ has a set of JMX annotations as well. This also allows Camel end users to use these new Camel JMX annotations in their custom Camel components. Then they do not need to use Spring JMX annotations, and thus bring in maybe unneeded dependency on Spring JARs in their code. The ResourceEndpoint from camel-spring should be moved to camel-core and rely on ClassResolver API from Camel to load resources from the classpath. Reducing runtime JARsSince Spring JARs will no longer be mandatory on the classpath for JMX support, we can reduce the runtime JAR dependency for Camel end users. Most end users of Camel will need to support JMX, so essentially we force them to add Spring JARs. That means they only need slf4j logging and commons-management JARs. Porting commons-management to camel-coreCurrently camel-core rely on commons-management for basic JMX support. We should consider porting this code into the camel-core codebase. Other components using SpringThe Mail and JMS component currently depend on Spring JARs. There is a work in progress patch for the Mail component to be able to run without Spring. The JMS component is however heavily dependent on Spring, as it uses spring-jms. We may in the future consider writing a new light weight JMS component that has less features, but can work without Spring. However this is not the goal for Camel 2.9.
Change Notification Preferences
View Online
|
View Changes
|
Add Comment
|
- [CONF] Apache Camel > Camel 2.9 - JMX and reducing Spring de... confluence
- [CONF] Apache Camel > Camel 2.9 - JMX and reducing Spri... confluence
- [CONF] Apache Camel > Camel 2.9 - JMX and reducing Spri... confluence