Uploaded image for project: 'Infinispan'
  1. Infinispan
  2. ISPN-9561

GlobalConfiguration should keep strong reference to classloader

This issue belongs to an archived project. You can view it, but you can't modify it. Learn more

XMLWordPrintable

    • Icon: Bug Bug
    • Resolution: Done
    • Icon: Major Major
    • 9.4.0.Final
    • 9.4.0.Final
    • Core
    • None

      GlobalConfiguration uses a WeakReference to store its classloader, in order to allow JCachingProvider to use a WeakHashMap<ClassLoader, DefaultCacheManager>.

      The weak reference works fine when the classloader is the application classloader, but if the application (or the server, in our case) creates a ClassLoader instance just for the Infinispan configuration, that classloader can be garbage collected while the cache manager is starting. That is exactly what happens during server startup sometimes, making GlobalComponentRegistry use the TCCL for module initialization and ignoring all the non-core modules.

      We can still use a WeakClassLoader adapter that wraps a WeakReference<ClassLoader> for JCachingProvider.

              dberinde@redhat.com Dan Berindei (Inactive)
              dberinde@redhat.com Dan Berindei (Inactive)
              Archiver:
              rhn-support-adongare Amol Dongare

                Created:
                Updated:
                Resolved:
                Archived: