Open topic with navigation
        
        
            
        
        
        
        Configuration
        Db4o can be configured to use a user-defined classloader.
        Java: configuration.common().reflectWith(new JdkReflector(classloader)) 
This line will configure db4o to use the provided classloader. Note that, as with most db4o configuration options, this configuration will have to occur before the respective database has been opened.
The usual ways of getting a classloader reference are:
- Using the classloader the class containing the currently executed code was loaded from. (this.getClass().getClassLoader())
- Using the classloader db4o was loaded from. (Db4o.class.getClassLoader())
- Using the classloader your domain classes were loaded from. (SomeDomainClass.class.getClassLoader())
- Using the context classloader that may have been arbitrarily set by the execution environment. (Thread.currentThread().getContextClassLoader()).
To choose the right classloader to use, you have to be aware of the classloader hierarchy of your specific execution environment. As a rule of thumb, one should configure db4o to use a classloader as deep/specialized in the tree as possible. In the above example this would be the classloader of the plugin db4o is supposed to work with.