You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@camel.apache.org by "Claus Ibsen (JIRA)" <ji...@apache.org> on 2011/08/19 09:49:27 UTC

[jira] [Updated] (CAMEL-4347) Set thread context class loader when starting camel-blueprint routes

     [ https://issues.apache.org/jira/browse/CAMEL-4347?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Claus Ibsen updated CAMEL-4347:
-------------------------------

    Fix Version/s: 2.8.1

Backported to 2.8.1

> Set thread context class loader when starting camel-blueprint routes
> --------------------------------------------------------------------
>
>                 Key: CAMEL-4347
>                 URL: https://issues.apache.org/jira/browse/CAMEL-4347
>             Project: Camel
>          Issue Type: Improvement
>          Components: camel-blueprint
>    Affects Versions: 2.8.0
>            Reporter: Gert Vanthienen
>            Assignee: Gert Vanthienen
>             Fix For: 2.8.1, 2.9.0
>
>
> When routes are getting started by the camel-blueprint component, the thread context classloader at that moment is the container's boot classloader.  This is causing problems for e.g. ActiveMQ object messages that need to get deserialized, because the boot classloader is not aware of classes that might be available inside the container.  The class used for reading the ActiveMQ object messages is http://svn.apache.org/repos/asf/activemq/trunk/activemq-core/src/main/java/org/apache/activemq/util/ClassLoadingAwareObjectInputStream.java.
> We can fix this by setting a more appropriate classloader as the thread context classloader while starting the CamelContext from a Blueprint definition.  I see we also have a similar class in camel-jdbc and there are no doubt other libraries that depend on this classloader being set as well, so this change should help with all of those cases.

--
This message is automatically generated by JIRA.
For more information on JIRA, see: http://www.atlassian.com/software/jira