Transaction scheduling using dynamic conflict avoidance

Nenhuma Miniatura disponível

Data

2013-02-01

Autores

Nicácio, Daniel
Baldassin, Alexandro [UNESP]
Araújo, Guido

Título da Revista

ISSN da Revista

Título de Volume

Editor

Resumo

Software transaction memory (STM) systems have been used as an approach to improve performance, by allowing the concurrent execution of atomic blocks. However, under high-contention workloads, STM-based systems can considerably degrade performance, as transaction conflict rate increases. Contention management policies have been used as a way to select which transaction to abort when a conflict occurs. In general, contention managers are not capable of avoiding conflicts, as they can only select which transaction to abort and the moment it should restart. Since contention managers act only after a conflict is detected, it becomes harder to effectively increase transaction throughput. More proactive approaches have emerged, aiming at predicting when a transaction is likely to abort, postponing its execution. Nevertheless, most of the proposed proactive techniques are limited, as they do not replace the doomed transaction by another or, when they do, they rely on the operating system for that, having little or no control on which transaction to run. This article proposes LUTS, a lightweight user-level transaction scheduler. Unlike other techniques, LUTS provides the means for selecting another transaction to run in parallel, thus improving system throughput. We discuss LUTS design and propose a dynamic conflict-avoidance heuristic built around its scheduling capabilities. Experimental results, conducted with the STAMP and STMBench7 benchmark suites, running on TinySTM and SwissTM, show how our conflict-avoidance heuristic can effectively improve STM performance on high contention applications. © 2012 Springer Science+Business Media, LLC.

Descrição

Palavras-chave

Concurrent programming, Contention management, Multiprocessor systems, Transactional memory, Atomic blocks, Benchmark suites, Concurrent execution, Conflict avoidance, Improving systems, Management policy, Multi processor systems, Pro-active approach, Rate increase, Software Transaction Memory, Transaction scheduling, Transaction throughput, Computer programming, Java programming language, Management, Managers, Scheduling

Como citar

International Journal of Parallel Programming, v. 41, n. 1, p. 89-110, 2013.