[
https://issues.apache.org/jira/browse/IGNITE-22975?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Pavel Pereslegin reassigned IGNITE-22975:
-----------------------------------------
Assignee: Pavel Pereslegin
> Catalog compaction. Improve minimum tx begin time local determination
> ---------------------------------------------------------------------
>
> Key: IGNITE-22975
> URL: https://issues.apache.org/jira/browse/IGNITE-22975
> Project: Ignite
> Issue Type: Improvement
> Reporter: Pavel Pereslegin
> Assignee: Pavel Pereslegin
> Priority: Major
> Labels: ignite-3
>
> Currently minimum begin time among all transactions started locally computes
> under write lock.
> {code:java}
> @Override
> public HybridTimestamp minimumBeginTime(Supplier<HybridTimestamp>
> defaultBeginTime) {
> readWriteLock.writeLock().lock();
> try {
> return txCatalogVersionByBeginTxTs.keySet().stream()
> .min(HybridTimestamp::compareTo)
> .orElse(defaultBeginTime.get());
> } finally {
> readWriteLock.writeLock().unlock();
> }
> }
> {code}
> This code blocks the start of transactions and can be optimized.
> Need to investigate possible ways to optimize it.
> * may be we can somehow use existing ordered map {{txCountByCatalogVersion}}
> to provide minimum require catalog version instead of tx begin time and
> rework/remove {{ActiveLocalTxMinimumBeginTimeProvider}}.
> * may be we can use {{lowWatermark.current()}} instead of current time
> p.s. original discussion link
> https://github.com/apache/ignite-3/pull/4137#discussion_r1705728506
--
This message was sent by Atlassian Jira
(v8.20.10#820010)