2013-10-21 13 views
6

Il divertimento di java 7u45 continua a dare. Questa volta è un deadlock all'interno di webstart. Questo sta accadendo in modo molto consistente (ogni volta) lanciando una grande applicazione (~ 100 vasi).nuovo bug deadlock in 7u45 webstart?

Qualcun altro si è imbattuto in questo o sa di soluzioni alternative? Altro che tornare alla versione 1.7.0_40?

Grazie,

Found one Java-level deadlock: 
============================= 
"Java Web Start Main Thread": 
    waiting to lock monitor 0x066368bc (object 0x29e65428, a java.lang.Class), 
    which is held by "Finalizer" 
"Finalizer": 
    waiting to lock monitor 0x00dbc954 (object 0x2a1b52b0, a com.sun.deploy.cache.CacheEntry), 
    which is held by "Java Web Start Main Thread" 

Java stack information for the threads listed above: 
=================================================== 
"Java Web Start Main Thread": 
    at com.sun.deploy.cache.MemoryCache.getLoadedResource(Unknown Source) 
    - waiting to lock <0x29e65428> (a java.lang.Class for com.sun.deploy.cache.MemoryCache) 
    at com.sun.deploy.cache.CachedJarFile.getCacheEntry(Unknown Source) 
    - locked <0x24810058> (a com.sun.deploy.cache.CachedJarFile) 
    at com.sun.deploy.cache.CachedJarFile.getManifest(Unknown Source) 
    - locked <0x24810058> (a com.sun.deploy.cache.CachedJarFile) 
    at com.sun.deploy.util.JarUtil.isBlobSigned(Unknown Source) 
    at com.sun.deploy.cache.CacheEntry.getJarFile(Unknown Source) 
    - locked <0x2a1b52b0> (a com.sun.deploy.cache.CacheEntry) 
    at com.sun.deploy.security.DeployManifestChecker.verify(Unknown Source) 
    at com.sun.javaws.security.AppPolicy.grantUnrestrictedAccess(Unknown Source) 
    at com.sun.javaws.security.JNLPSignedResourcesHelper.checkSignedResourcesHelper(Unknown Source) 
    at com.sun.javaws.security.JNLPSignedResourcesHelper.checkSignedResources(Unknown Source) 
    at com.sun.javaws.Launcher.prepareResources(Unknown Source) 
    at com.sun.javaws.Launcher.prepareAllResources(Unknown Source) 
    at com.sun.javaws.Launcher.prepareToLaunch(Unknown Source) 
    at com.sun.javaws.Launcher.prepareToLaunch(Unknown Source) 
    at com.sun.javaws.Launcher.launch(Unknown Source) 
    at com.sun.javaws.Main.launchApp(Unknown Source) 
    at com.sun.javaws.Main.continueInSecureThread(Unknown Source) 
    at com.sun.javaws.Main.access$000(Unknown Source) 
    at com.sun.javaws.Main$1.run(Unknown Source) 
    at java.lang.Thread.run(Unknown Source) 
"Finalizer": 
    at com.sun.deploy.cache.CacheEntry.storageFilesExist(Unknown Source) 
    - waiting to lock <0x2a1b52b0> (a com.sun.deploy.cache.CacheEntry) 
    at com.sun.deploy.cache.MemoryCache.validateResource(Unknown Source) 
    at com.sun.deploy.cache.MemoryCache.getLoadedResource(Unknown Source) 
    - locked <0x29e65428> (a java.lang.Class for com.sun.deploy.cache.MemoryCache) 
    at com.sun.deploy.cache.CachedJarFile.isReferencedTo(Unknown Source) 
    at com.sun.deploy.cache.CachedJarFile.close(Unknown Source) 
    at java.util.zip.ZipFile.finalize(Unknown Source) 
    at java.lang.ref.Finalizer.invokeFinalizeMethod(Native Method) 
    at java.lang.ref.Finalizer.runFinalizer(Unknown Source) 
    at java.lang.ref.Finalizer.access$100(Unknown Source) 
    at java.lang.ref.Finalizer$FinalizerThread.run(Unknown Source) 

Found 1 deadlock. 
+2

Se si è trovato un bug JVM/JRE/JDK, si prega di segnalarlo a Oracle. http://www.oracle.com/technetwork/java/javase/bugreports-140511.html –

+0

Ho intenzione di farlo, ma il feedback di oracle sulle segnalazioni di bug è solo "grazie". Nessuna risposta, e non puoi nemmeno vedere il bug una volta che lo "accetti". Stavo per soffermarmi un po 'di più e vedere se potevo trovare ciò che hanno cambiato in deploy.jar tra 7u40 e 7u45. –

+1

Il bug proviene da un nuovo blocco di codice aggiunto in getJarFile() nella classe CacheEntry in deploy.jar tra 7u40 e 7u45. Ho inviato il bug ora. Con un po 'di fortuna, forse renderanno pubblico il bug. (Stai ascoltando Larry?) –

risposta

1

La segnalazione ho detto nel mio commento è stato ora accettato.

Sembra che il suo ID sia cambiato come parte di quel processo, però. Si è spostato dallo spazio nomi JI- allo spazio nomi JDK-: https://bugs.openjdk.java.net/browse/JI-9007571 ora reindirizza a https://bugs.openjdk.java.net/browse/JDK-8027029. Il problema può essere visto anche a http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=8027029.

La correzione sembra essere in discussione per l'inclusione in 7u51, prevista per gennaio.

Le nostre tracce di stack sono simili - il deadlock stesso sembra essere identico. Nel nostro caso abbiamo due applet nella pagina che si stanno caricando allo stesso tempo.

"thread applet-cl.applet.TutorApplet-2" prio=4 tid=0x04f21000 nid=0x528 waiting for monitor entry [0x0652f000] 
    java.lang.Thread.State: BLOCKED (on object monitor) 
    at com.sun.deploy.cache.MemoryCache.getLoadedResource(Unknown Source) 
    - waiting to lock <0x29d288b8> (a java.lang.Class for com.sun.deploy.cache.MemoryCache) 
    at com.sun.deploy.cache.CachedJarFile.getCacheEntry(Unknown Source) 
    - locked <0x247a4f90> (a com.sun.deploy.cache.CachedJarFile) 
    at com.sun.deploy.cache.CachedJarFile.getManifest(Unknown Source) 
    - locked <0x247a4f90> (a com.sun.deploy.cache.CachedJarFile) 
    at com.sun.deploy.util.JarUtil.isBlobSigned(Unknown Source) 
    at com.sun.deploy.cache.CacheEntry.getJarFile(Unknown Source) 
    - locked <0x29eccc00> (a com.sun.deploy.cache.CacheEntry) 
    at com.sun.javaws.security.SigningInfo.check(Unknown Source) 
    at com.sun.javaws.security.JNLPSignedResourcesHelper.checkSignedResourcesHelper(Unknown Source) 
    at com.sun.javaws.security.JNLPSignedResourcesHelper.checkSignedResources(Unknown Source) 
    at sun.plugin2.applet.JNLP2Manager.prepareLaunchFile(Unknown Source) 
    at sun.plugin2.applet.JNLP2Manager.loadJarFiles(Unknown Source) 
    at sun.plugin2.applet.Plugin2Manager$AppletExecutionRunnable.run(Unknown Source) 
    at java.lang.Thread.run(Unknown Source) 

"thread applet-cl.applet.TTSApplet-1" prio=4 tid=0x04f1f800 nid=0xa40 waiting for monitor entry [0x0600f000] 
    java.lang.Thread.State: BLOCKED (on object monitor) 
    at com.sun.deploy.cache.CacheEntry.storageFilesExist(Unknown Source) 
    - waiting to lock <0x29eccc00> (a com.sun.deploy.cache.CacheEntry) 
    at com.sun.deploy.cache.MemoryCache.validateResource(Unknown Source) 
    at com.sun.deploy.cache.MemoryCache.getLoadedResource(Unknown Source) 
    - locked <0x29d288b8> (a java.lang.Class for com.sun.deploy.cache.MemoryCache) 
    at com.sun.deploy.cache.MemoryCache.getLoadedResource(Unknown Source) 
    - locked <0x29d288b8> (a java.lang.Class for com.sun.deploy.cache.MemoryCache) 
    at com.sun.deploy.cache.Cache.getCacheEntry(Unknown Source) 
    at com.sun.deploy.cache.Cache.getCacheEntry(Unknown Source) 
    at com.sun.deploy.cache.Cache.getCachedResourceFilePath(Unknown Source) 
    at com.sun.deploy.cache.ResourceProviderImpl.getCachedResourceFilePath(Unknown Source) 
    at com.sun.javaws.security.JNLPSignedResourcesHelper.getSignedJNLPBits(Unknown Source) 
    at com.sun.javaws.security.JNLPSignedResourcesHelper.getSignedJNLPFile(Unknown Source) 
    at com.sun.javaws.security.JNLPSignedResourcesHelper.checkSignedLaunchDescHelper(Unknown Source) 
    at com.sun.javaws.security.JNLPSignedResourcesHelper.checkSignedLaunchDesc(Unknown Source) 
    at sun.plugin2.applet.JNLP2Manager.prepareLaunchFile(Unknown Source) 
    at sun.plugin2.applet.JNLP2Manager.loadJarFiles(Unknown Source) 
    at sun.plugin2.applet.Plugin2Manager$AppletExecutionRunnable.run(Unknown Source) 
    at java.lang.Thread.run(Unknown Source)