The Community for Technology Leaders
2016 International Conference on Parallel Architecture and Compilation Techniques (PACT) (2016)
Haifa, Israel
Sept. 11, 2016 to Sept. 15, 2016
ISBN: 978-1-5090-5308-7
pp: 401-412
Heiner Litz , Stanford University, 353 Serra Mall, CA, 94305, United States of America
Benjamin Braun , Stanford University, 353 Serra Mall, CA, 94305, United States of America
David Cheriton , Stanford University, 353 Serra Mall, CA, 94305, United States of America
ABSTRACT
Multi-core programming remains a major software development and maintenance challenge because of data races, deadlock, non-deterministic failures and complex performance issues. In this paper, we describe EXCITE-VM, a system that provides snapshot isolation transactions on shared memory to facilitate programming and to improve the performance of parallel applications. With snapshots, an application thread is not exposed to the committed changes of other threads until it receives the updates by explicitly creating a new snapshot. Snapshot isolation enables low overhead lockless read operations and improves fault tolerance by isolating each thread from the transient, uncommitted writes of other threads. This paper describes how EXCITE-VM implements snapshot isolation transactions efficiently by manipulating virtual memory mappings and using a novel copy-on-read mechanism with a customized page cache. Compared to conventional software transactional memory systems, EXCITE-VM provides up to 2.2× performance improvement for the STAMP benchmark suite and up to 1000× speedup for a modified benchmark having long running read-only transactions. Furthermore, EXCITE-VM achieves a 2× performance improvement on a Memcached benchmark and the Yahoo Cloud Server Benchmarks. Finally, EXCITE-VM improves fault tolerance and offers features such as low-overhead concurrent audit and analysis.
INDEX TERMS
Instruction sets, Cows, Benchmark testing, Synchronization, Programming, Servers
CITATION
Heiner Litz, Benjamin Braun, David Cheriton, "EXCITE-VM: Extending the virtual memory system to support snapshot isolation transactions", 2016 International Conference on Parallel Architecture and Compilation Techniques (PACT), vol. 00, no. , pp. 401-412, 2016, doi:10.1145/2967938.2967955
93 ms
(Ver 3.3 (11022016))