[JBoss JIRA] (ISPN-11387) Preloading store is blocking with tx cache
by Will Burns (Jira)
Will Burns created ISPN-11387:
---------------------------------
Summary: Preloading store is blocking with tx cache
Key: ISPN-11387
URL: https://issues.redhat.com/browse/ISPN-11387
Project: Infinispan
Issue Type: Bug
Affects Versions: 10.0.0.Final
Reporter: Will Burns
The preload from a store currently blocks when the cache is transactional when it commits. We should be invoking `putAsync` where possible and aggregating the values appropriately. This would most likely require using a limit intermediate method. We also need to figure out how to handle the transaction commit as this is inherently blocking.
Also to note the `PreloadManager` currently blocks on join for the Stage returned from the PersistenceManager. But this requires non blocking cache startup/initialization.
--
This message was sent by Atlassian Jira
(v7.13.8#713008)
5 years
[JBoss JIRA] (ISPN-11386) Use blocking thread pool in Persistent preload
by Pedro Ruivo (Jira)
[ https://issues.redhat.com/browse/ISPN-11386?page=com.atlassian.jira.plugi... ]
Pedro Ruivo updated ISPN-11386:
-------------------------------
Status: Pull Request Sent (was: Coding In Progress)
Git Pull Request: https://github.com/infinispan/infinispan/pull/7960
> Use blocking thread pool in Persistent preload
> ----------------------------------------------
>
> Key: ISPN-11386
> URL: https://issues.redhat.com/browse/ISPN-11386
> Project: Infinispan
> Issue Type: Bug
> Components: Core
> Affects Versions: 10.1.3.Final
> Reporter: Pedro Ruivo
> Assignee: Pedro Ruivo
> Priority: Major
> Fix For: 10.1.4.Final
>
>
> When preload on a transactional cache, the preload blocks until the transactions is committed.
> {noformat}
> org.infinispan.commons.CacheException: java.lang.AssertionError: Blocking call! jdk.internal.misc.Unsafe#park on thread Thread[non-blocking-thread-IracMetadataStoreTest-NodeB-p50782-t1,5,main]
> at org.infinispan.interceptors.impl.AsyncInterceptorChainImpl.invoke(AsyncInterceptorChainImpl.java:259) ~[classes/:?]
> at org.infinispan.transaction.impl.TransactionCoordinator.commitInternal(TransactionCoordinator.java:218) ~[classes/:?]
> at org.infinispan.transaction.impl.TransactionCoordinator.commit(TransactionCoordinator.java:162) ~[classes/:?]
> at org.infinispan.transaction.xa.XaTransactionTable.commit(XaTransactionTable.java:119) ~[classes/:?]
> at org.infinispan.transaction.xa.TransactionXaAdapter.commit(TransactionXaAdapter.java:68) ~[classes/:?]
> at com.arjuna.ats.internal.jta.resources.arjunacore.XAResourceRecord.topLevelOnePhaseCommit(XAResourceRecord.java:702) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.arjuna.coordinator.BasicAction.onePhaseCommit(BasicAction.java:2386) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.arjuna.coordinator.BasicAction.End(BasicAction.java:1497) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.arjuna.coordinator.TwoPhaseCoordinator.end(TwoPhaseCoordinator.java:96) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.arjuna.AtomicAction.commit(AtomicAction.java:162) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.internal.jta.transaction.arjunacore.TransactionImple.commitAndDisassociate(TransactionImple.java:1287) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.internal.jta.transaction.arjunacore.BaseTransaction.commit(BaseTransaction.java:126) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at org.infinispan.persistence.manager.PersistenceManagerImpl.commitIfNeeded(PersistenceManagerImpl.java:1452) ~[classes/:?]
> at org.infinispan.persistence.manager.PersistenceManagerImpl.preloadKey(PersistenceManagerImpl.java:1408) ~[classes/:?]
> {noformat}
--
This message was sent by Atlassian Jira
(v7.13.8#713008)
5 years
[JBoss JIRA] (ISPN-11386) Use blocking thread pool in Persistent preload
by Pedro Ruivo (Jira)
[ https://issues.redhat.com/browse/ISPN-11386?page=com.atlassian.jira.plugi... ]
Work on ISPN-11386 started by Pedro Ruivo.
------------------------------------------
> Use blocking thread pool in Persistent preload
> ----------------------------------------------
>
> Key: ISPN-11386
> URL: https://issues.redhat.com/browse/ISPN-11386
> Project: Infinispan
> Issue Type: Bug
> Components: Core
> Affects Versions: 10.1.3.Final
> Reporter: Pedro Ruivo
> Assignee: Pedro Ruivo
> Priority: Major
> Fix For: 10.1.4.Final
>
>
> When preload on a transactional cache, the preload blocks until the transactions is committed.
> {noformat}
> org.infinispan.commons.CacheException: java.lang.AssertionError: Blocking call! jdk.internal.misc.Unsafe#park on thread Thread[non-blocking-thread-IracMetadataStoreTest-NodeB-p50782-t1,5,main]
> at org.infinispan.interceptors.impl.AsyncInterceptorChainImpl.invoke(AsyncInterceptorChainImpl.java:259) ~[classes/:?]
> at org.infinispan.transaction.impl.TransactionCoordinator.commitInternal(TransactionCoordinator.java:218) ~[classes/:?]
> at org.infinispan.transaction.impl.TransactionCoordinator.commit(TransactionCoordinator.java:162) ~[classes/:?]
> at org.infinispan.transaction.xa.XaTransactionTable.commit(XaTransactionTable.java:119) ~[classes/:?]
> at org.infinispan.transaction.xa.TransactionXaAdapter.commit(TransactionXaAdapter.java:68) ~[classes/:?]
> at com.arjuna.ats.internal.jta.resources.arjunacore.XAResourceRecord.topLevelOnePhaseCommit(XAResourceRecord.java:702) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.arjuna.coordinator.BasicAction.onePhaseCommit(BasicAction.java:2386) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.arjuna.coordinator.BasicAction.End(BasicAction.java:1497) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.arjuna.coordinator.TwoPhaseCoordinator.end(TwoPhaseCoordinator.java:96) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.arjuna.AtomicAction.commit(AtomicAction.java:162) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.internal.jta.transaction.arjunacore.TransactionImple.commitAndDisassociate(TransactionImple.java:1287) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.internal.jta.transaction.arjunacore.BaseTransaction.commit(BaseTransaction.java:126) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at org.infinispan.persistence.manager.PersistenceManagerImpl.commitIfNeeded(PersistenceManagerImpl.java:1452) ~[classes/:?]
> at org.infinispan.persistence.manager.PersistenceManagerImpl.preloadKey(PersistenceManagerImpl.java:1408) ~[classes/:?]
> {noformat}
--
This message was sent by Atlassian Jira
(v7.13.8#713008)
5 years
[JBoss JIRA] (ISPN-11386) Use blocking thread pool in Persistent preload
by Pedro Ruivo (Jira)
Pedro Ruivo created ISPN-11386:
----------------------------------
Summary: Use blocking thread pool in Persistent preload
Key: ISPN-11386
URL: https://issues.redhat.com/browse/ISPN-11386
Project: Infinispan
Issue Type: Bug
Components: Core
Affects Versions: 10.1.3.Final
Reporter: Pedro Ruivo
Assignee: Pedro Ruivo
Fix For: 10.1.4.Final
When preload on a transactional cache, the preload blocks until the transactions is committed.
{noformat}
org.infinispan.commons.CacheException: java.lang.AssertionError: Blocking call! jdk.internal.misc.Unsafe#park on thread Thread[non-blocking-thread-IracMetadataStoreTest-NodeB-p50782-t1,5,main]
at org.infinispan.interceptors.impl.AsyncInterceptorChainImpl.invoke(AsyncInterceptorChainImpl.java:259) ~[classes/:?]
at org.infinispan.transaction.impl.TransactionCoordinator.commitInternal(TransactionCoordinator.java:218) ~[classes/:?]
at org.infinispan.transaction.impl.TransactionCoordinator.commit(TransactionCoordinator.java:162) ~[classes/:?]
at org.infinispan.transaction.xa.XaTransactionTable.commit(XaTransactionTable.java:119) ~[classes/:?]
at org.infinispan.transaction.xa.TransactionXaAdapter.commit(TransactionXaAdapter.java:68) ~[classes/:?]
at com.arjuna.ats.internal.jta.resources.arjunacore.XAResourceRecord.topLevelOnePhaseCommit(XAResourceRecord.java:702) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
at com.arjuna.ats.arjuna.coordinator.BasicAction.onePhaseCommit(BasicAction.java:2386) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
at com.arjuna.ats.arjuna.coordinator.BasicAction.End(BasicAction.java:1497) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
at com.arjuna.ats.arjuna.coordinator.TwoPhaseCoordinator.end(TwoPhaseCoordinator.java:96) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
at com.arjuna.ats.arjuna.AtomicAction.commit(AtomicAction.java:162) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
at com.arjuna.ats.internal.jta.transaction.arjunacore.TransactionImple.commitAndDisassociate(TransactionImple.java:1287) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
at com.arjuna.ats.internal.jta.transaction.arjunacore.BaseTransaction.commit(BaseTransaction.java:126) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
at org.infinispan.persistence.manager.PersistenceManagerImpl.commitIfNeeded(PersistenceManagerImpl.java:1452) ~[classes/:?]
at org.infinispan.persistence.manager.PersistenceManagerImpl.preloadKey(PersistenceManagerImpl.java:1408) ~[classes/:?]
{noformat}
--
This message was sent by Atlassian Jira
(v7.13.8#713008)
5 years
[JBoss JIRA] (ISPN-11386) Use blocking thread pool in Persistent preload
by Pedro Ruivo (Jira)
[ https://issues.redhat.com/browse/ISPN-11386?page=com.atlassian.jira.plugi... ]
Pedro Ruivo updated ISPN-11386:
-------------------------------
Status: Open (was: New)
> Use blocking thread pool in Persistent preload
> ----------------------------------------------
>
> Key: ISPN-11386
> URL: https://issues.redhat.com/browse/ISPN-11386
> Project: Infinispan
> Issue Type: Bug
> Components: Core
> Affects Versions: 10.1.3.Final
> Reporter: Pedro Ruivo
> Assignee: Pedro Ruivo
> Priority: Major
> Fix For: 10.1.4.Final
>
>
> When preload on a transactional cache, the preload blocks until the transactions is committed.
> {noformat}
> org.infinispan.commons.CacheException: java.lang.AssertionError: Blocking call! jdk.internal.misc.Unsafe#park on thread Thread[non-blocking-thread-IracMetadataStoreTest-NodeB-p50782-t1,5,main]
> at org.infinispan.interceptors.impl.AsyncInterceptorChainImpl.invoke(AsyncInterceptorChainImpl.java:259) ~[classes/:?]
> at org.infinispan.transaction.impl.TransactionCoordinator.commitInternal(TransactionCoordinator.java:218) ~[classes/:?]
> at org.infinispan.transaction.impl.TransactionCoordinator.commit(TransactionCoordinator.java:162) ~[classes/:?]
> at org.infinispan.transaction.xa.XaTransactionTable.commit(XaTransactionTable.java:119) ~[classes/:?]
> at org.infinispan.transaction.xa.TransactionXaAdapter.commit(TransactionXaAdapter.java:68) ~[classes/:?]
> at com.arjuna.ats.internal.jta.resources.arjunacore.XAResourceRecord.topLevelOnePhaseCommit(XAResourceRecord.java:702) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.arjuna.coordinator.BasicAction.onePhaseCommit(BasicAction.java:2386) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.arjuna.coordinator.BasicAction.End(BasicAction.java:1497) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.arjuna.coordinator.TwoPhaseCoordinator.end(TwoPhaseCoordinator.java:96) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.arjuna.AtomicAction.commit(AtomicAction.java:162) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.internal.jta.transaction.arjunacore.TransactionImple.commitAndDisassociate(TransactionImple.java:1287) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at com.arjuna.ats.internal.jta.transaction.arjunacore.BaseTransaction.commit(BaseTransaction.java:126) ~[narayana-jta-5.9.8.Final.jar:5.9.8.Final (revision: 92f28)]
> at org.infinispan.persistence.manager.PersistenceManagerImpl.commitIfNeeded(PersistenceManagerImpl.java:1452) ~[classes/:?]
> at org.infinispan.persistence.manager.PersistenceManagerImpl.preloadKey(PersistenceManagerImpl.java:1408) ~[classes/:?]
> {noformat}
--
This message was sent by Atlassian Jira
(v7.13.8#713008)
5 years
[JBoss JIRA] (ISPN-11384) Cannot create OFF_HEAP caches dynamically
by Gustavo Fernandes (Jira)
Gustavo Fernandes created ISPN-11384:
----------------------------------------
Summary: Cannot create OFF_HEAP caches dynamically
Key: ISPN-11384
URL: https://issues.redhat.com/browse/ISPN-11384
Project: Infinispan
Issue Type: Enhancement
Components: Hot Rod, REST
Affects Versions: 10.1.3.Final, 11.0.0.Alpha1
Reporter: Gustavo Fernandes
{code:xml}
<infinispan>
<cache-container>
<local-cache name ="offheap-cache">
<memory>
<off-heap/>
</memory>
</local-cache>
</cache-container>
</infinispan>
{code}
The config above when posted via REST will ignore the <off-heap/> and create a regular cache
--
This message was sent by Atlassian Jira
(v7.13.8#713008)
5 years