Issue No. 06 - November/December (1999 vol. 11)

ISSN: 1041-4347

pp: 880-895

DOI Bookmark: http://doi.ieeecomputersociety.org/10.1109/69.824601

ABSTRACT

<p><b>Abstract</b>—Replicated databases that use quorum-consensus algorithms to perform majority voting are prone to deadlocks. Due to the P-out-of-Q nature of quorum requests, deadlocks that arise are generalized deadlocks and are hard to detect. We present an efficient distributed algorithm to detect generalized deadlocks in replicated databases. The algorithm performs reduction of a distributed wait-for-graph (WFG) to determine the existence of a deadlock. If sufficient information to decide the reducibility of a node is not available at that node, the algorithm attempts reduction later in a lazy manner. We prove the correctness of the algorithm. The algorithm has a message complexity of <tmath>$2e$</tmath> messages and a worst-case time complexity of <tmath>$2d+2$</tmath> hops, where <tmath>$e$</tmath> is the number of edges and <tmath>$d$</tmath> is the diameter of the WFG. The algorithm is shown to perform significantly better in both time and message complexity than the best known existing algorithms. We conjecture that this is an optimal algorithm, in time and message complexity, to detect generalized deadlocks if no transaction has complete knowledge of the topology of the WFG or the system and the deadlock detection is to be carried out in a distributed manner.</p>

INDEX TERMS

Distributed database, replicated database, quorum consensus, generalized deadlock, graph reduction.

CITATION

Ajay D. Kshemkalyani, Mukesh Singhal, "A One-Phase Algorithm to Detect Distributed Deadlocks in Replicated Databases",

*IEEE Transactions on Knowledge & Data Engineering*, vol. 11, no. , pp. 880-895, November/December 1999, doi:10.1109/69.824601