Help When Needed, But No More: Efficient Read/Write Partial Snapshot

An atomic snapshot object is an object that can be concurrently accessed by asynchronous processes prone to crash. It is made of m components (base atomic registers) and is defined by two operations: an update operation that allows a process to atomically assign a new value to a component and a snapshot operation that atomically reads and returns the values of all the components. To cope with the net effect of concurrency, asynchrony and failures, the algorithm implementing the update operation has to help concurrent snapshot operations so that they always terminate. This paper is on partial snapshot objects. Such an object provides a snapshot operation that can take any subset of the components as input parameter, and atomically reads and returns the values of this subset of components. The paper has two contributions. The first is the introduction of two properties for partial snapshot object algorithms, called help-locality and freshness. Help-locality requires that an update operation helps only the concurrent partial snapshot operations that read the component it writes. When an update of a component r helps a partial snapshot, freshness requires that the update provides the partial snapshot with a value of the component r that is at least as recent as the value it writes into that component. (No snapshot algorithm proposed so far satisfies these properties.) The second contribution consists of an update and a partial snapshot algorithms that are wait-free, linearizable and satisfy the previous efficiency properties. Interestingly, the principle that underlies the proposed algorithms is different from the one used so far, namely, it is based on the "write first, and help later" strategy. An improvement of the previous algorithms is also presented. Based on LL/SC atomic registers (instead of read/write registers) this improvement decreases the number of base registers from O(n2) to O(n). This shows an interesting tradeoff relating the synchronization power of the base operations and the number of base atomic registers when using the "write first, and help later" strategy.

[1]  Yehuda Afek,et al.  Long-lived adaptive collect with applications , 1999, 40th Annual Symposium on Foundations of Computer Science (Cat. No.99CB37039).

[2]  Maurice Herlihy,et al.  The art of multiprocessor programming , 2020, PODC '06.

[3]  Hagit Attiya,et al.  Atomic Snapshots in O(n log n) Operations , 1998, SIAM J. Comput..

[4]  Leslie Lamport,et al.  Distributed snapshots: determining global states of distributed systems , 1985, TOCS.

[5]  Hagit Attiya,et al.  Algorithms adapting to point contention , 2003, JACM.

[6]  Michel Raynal,et al.  A Lock-Based STM Protocol That Satisfies Opacity and Progressiveness , 2008, OPODIS.

[7]  Rachid Guerraoui,et al.  Partial snapshot objects , 2008, SPAA '08.

[8]  Hagit Attiya,et al.  An adaptive collect algorithm with applications , 2002, Distributed Computing.

[9]  Marcin Paprzycki,et al.  Distributed Computing: Fundamentals, Simulations and Advanced Topics , 2001, Scalable Comput. Pract. Exp..

[10]  Marcos K. Aguilera,et al.  A pleasant stroll through the land of infinitely many creatures , 2004, SIGA.

[11]  Wei Chen,et al.  Linear-Time Snapshot Using Multi-writer Multi-reader Registers , 1994, WDAG.

[12]  Amos Israeli,et al.  Disjoint-access-parallel implementations of strong shared memory primitives , 1994, PODC '94.

[13]  Mark Moir Practical implementations of non-blocking synchronization primitives , 1997, PODC '97.

[14]  Faith E. Fich How hard is it to take a snapshot , 2005 .

[15]  Seif Haridi,et al.  Distributed Algorithms , 1992, Lecture Notes in Computer Science.

[16]  Rachid Guerraoui,et al.  From Unreliable Objects to Reliable Objects: The Case of Atomic Registers and Consensus , 2007, PaCT.

[17]  Maurice Herlihy,et al.  Linearizability: a correctness condition for concurrent objects , 1990, TOPL.

[18]  Rachid Guerraoui,et al.  On the correctness of transactional memory , 2008, PPoPP.

[19]  Prasad Jayanti An optimal multi-writer snapshot algorithm , 2005, STOC '05.

[20]  Gadi Taubenfeld Synchronization Algorithms and Concurrent Programming , 2006 .

[21]  Hagit Attiya Needed: foundations for transactional memory , 2008, SIGA.

[22]  James H. Anderson,et al.  Multi-writer composite registers , 1994, Distributed Computing.

[23]  Faith Ellen How Hard Is It to Take a Snapshot? , 2005, SOFSEM.

[24]  Maurice Herlihy,et al.  Wait-free synchronization , 1991, TOPL.

[25]  Hagit Attiya,et al.  Distributed Computing: Fundamentals, Simulations and Advanced Topics , 1998 .

[26]  Hagit Attiya,et al.  Atomic snapshots in O(n log n) operations , 1993, PODC '93.

[27]  Rachid Guerraoui,et al.  Transactions are back---but are they the same? , 2008, SIGA.

[28]  James H. Anderson Composite Registers , 1990, PODC.

[29]  Nir Shavit,et al.  Atomic snapshots of shared memory , 1990, JACM.

[30]  Maurice Herlihy,et al.  Distributed computing and the multicore revolution , 2008, SIGA.

[31]  Nir Shavit,et al.  Software transactional memory , 1995, PODC '95.