[ 
https://issues.apache.org/jira/browse/IGNITE-18736?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17685759#comment-17685759
 ] 

Roman Puchkovskiy commented on IGNITE-18736:
--------------------------------------------

The patch looks good to me, thanks!

> Prepare class AbstractPageMemoryMvPartitionStorage cursors for working with 
> locks
> ---------------------------------------------------------------------------------
>
>                 Key: IGNITE-18736
>                 URL: https://issues.apache.org/jira/browse/IGNITE-18736
>             Project: Ignite
>          Issue Type: Improvement
>            Reporter: Kirill Tkalenko
>            Assignee: Kirill Tkalenko
>            Priority: Major
>              Labels: ignite-3
>             Fix For: 3.0.0-beta2
>
>          Time Spent: 1h
>  Remaining Estimate: 0h
>
> We need to prepare cursors for working with locks, which should solve the 
> problems of parallel modifications and reading version chains.
> *org.apache.ignite.internal.storage.pagememory.mv.AbstractPageMemoryMvPartitionStorage#scanVersions*
>  - we need to read the entire chain at once. Since after reading one of the 
> elements of the chain, any modification of the links to the next element can 
> occur, we can degrade to quadratic complexity.
> *org.apache.ignite.internal.storage.pagememory.mv.AbstractPageMemoryMvPartitionStorage#scan*
>  - we will need to try to immediately find the version by *timestamp* when 
> reading the chain, since the *BplusTree* cursor caches rows that are on the 
> same page.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to