skip to main content
article
Free access

Self-stabilization

Published: 01 March 1993 Publication History

Abstract

In 1973 Dijkstra introduced to computer science the notion of self-stabilization in the context of distributed systems. He defined a system as self-stabilizing when “regardless of its initial state, it is guaranteed to arrive at a legitimate state in a finite number of steps.” A system which is not self-stabilizing may stay in an illegitimate state forever. Dijkstra's notion of self-stabilization, which originally had a very narrow scope of application, is proving to encompass a formal and unified approach to fault tolerance under a model of transient failures for distributed systems. In this paper we define self-stabilization, examine its significance in the context of fault tolerance, define the important research themes that have arisen from it, and discuss the relevant results. In addition to the issues arising from Dijkstra's original presentation as well as several related issues, we discuss methodologies for designing self-stabilizing systems, the role of compilers with respect to self-stabilization, and some of the factors that prevent self-stabilization.

References

[1]
ABADIR, M. S., AND GOUDA, M.G. 1992. The stabilizing computer. In Proceedings of the 1992 International Conference on Parallel and Distributed Systems. (Dec.).
[2]
AFEK, Y., AND BROWN, G. 1989. Self-stabilization of the alternating-bit protocol. In Proceedings of the 8th Symposium olz Reliable Dlstrtbuted Systems, 80-83.
[3]
AFEK, Y., KUTTEN, S., AND YUNG, M. 1990. Memory-efficient self-~tabilization on general networks. In Proceedtngs of the 4th Internattonal Workshop on Distributed Algomthms (Bari, Italy, Sept.). In Lecture Notes in Computer Science, vol. 486. Springer-Verlag, New York, 15-28.
[4]
ARORA, A. 1992. A foundation for fault-tolerant computing. Ph.D. dissertation, Dept of Computer Sciences, Univ. of Texas at Austin.
[5]
AmORA, A., AND GOUDA, M.G. 1992. Closure and convergence: A foundation for fault-tolerant computing. In Proceedzngs of the 22rid Internatzonal Conference on Fault-Tolerant Computing Systems.
[6]
ARORA, A., AND GOUDA, M. G. 1990. Distributed reset. In Proceedings of the lOth Conference on Foundatmns of Software Technology and Theorettcal Computer Science (Dec.). Also in Lecture Notes on Computer Science, vol. 472. Springer- Verlag, New York.
[7]
ARORA, A., DOLEV, S., AND GOUDA, M. G. 1991. Maintaining digital clocks in step In Proceedrags of the 5th Internattonal Workshop on Distrzbuted Algorzthms (Oct.). Also in Parall. Process. Lett. 1, 1 (Sept.), 11 18.
[8]
AWERBUCH, B., AND VARGHESE, G 1991 Distributed program checking: A paradigTn for building self-stabilizing distributed protocols. In Proceedings of the 32nd IEEE Sympostun't on Foundations of Computer Science (Oct.). IEEE, New York
[9]
AWERBUCH, B., PATT, B. AND VARGHHESE, G. 1991. Self-stabilization by local checking and correction. In Proceedings of the 32nd IEEE Symposzum on Foundations of Computer Science, (Oct.). IEEE, New York.
[10]
BASTIM, F., YEN, I., AND CHEN, I. 1988. A class of inherently fault tolerant distributed programs. IEEE Trans. So/ha Eng. 14, 1432-1442.
[11]
BASTANI, F., YEN, I., AND ZI.IAO, Y. 1989. On self, stabilization, non-determinism, and inherent fault tolerance. In Proceedings of the MCC Workshop on Self-Stabilizing Systems. MCC Tech. Rep. STP-379-89.
[12]
BROWNE, J. C., EMERSON, A, GOUDA, M., MIRANKER, D., MOK, A., AND ROSmR, L. 1990 Boundedtime fault-tolerant rule-based systems. Telemotzcs Informat. 7, 3/4, 441-454.
[13]
BROWN, G. M., GOUDA. M. G., AND WU, C.-L. 1989. Token systems that self-stabihze. {EEE Trans. Comput. 38, 6 (June 1989l, 845-852.
[14]
BURNS, J.E. 1987. Self-stabilizing rings without demons. Tech. Rep. GIT-ICS-87/36, Georgia Inst of Technology.
[15]
BURNS, J. E., AND PACHL, J. 1989. Uniform selfstabilizing rings. ACM Trans Programm Lang. Syst. 11,330 344
[16]
BURNS, J. E, GOUDA, M. G., AND MmuEa, R. E 1990 Stabilization and pseudo-stabilization. Tech. Rep. TR-90-13, Dept. of Computer Sciences, Univ. of Texas at Austin
[17]
BURNS, J. E, GOUDA, M. G., AND MmLER, R. E 1989. On relaxing interleaving assumptions. In Proceedings of the MCC Workshop on Self- Stabzhzzng Systems MCC Tech. Rep. STP-379- 89.
[18]
CHANDY, K. M., AND LAMPORT, L 1985. Distributed snapshots: Determining global states of distributed systems. ACM Trans. Comput. Syst. 3, 1, 63-75.
[19]
CnANDY, K. M., AND MISRA, J. 1988. Parallel Program Design: A Foundation. Addison-Wesley, New York.
[20]
CHANG, E. J. H, GONNET, G. H. AND ROTEM,'D. 1987. On the costs of self-stabilization. Ipf Process Lett. 24, (1987), 311-316.
[21]
CHEN, N. S., Yu, F. P., AND HUANG, S.T. 1991. A self-stabilizing algorithm for constructing spanning' trees. Inf. Process. Lett., 39, (1991), 147 151.
[22]
CHENG, A. M.K. 1990. Analysis and synthesis of real-time rule-based decision systems. Ph.D. dissertation, Dept of Computer Sciences, Univ. of Texas at Austin.
[23]
COUVREUR, J.-M., FRANCEZ, N., AND GOUDA, M. G. 1992. Asynchronous unison. In Proceedings of the 12th Internatmnal Conference on Distrzbuted Computzng Systems (Yokohama, Japan, June).
[24]
CRISTIAN, F. 1991. Understanding fault-tolerant distributed systems. Commun. ACM 34, 2 (Feb.), 56-78.
[25]
CRIST~AN, F. 1985. A rigorous approach to faulttolerant programming. IEEE Trans. Softw. Eng 11, 1, (1985).
[26]
DIJKSTRA, E.W. 1986. A belated proof of self-stabilization. Dzstrzb. Comput., 1, 5-6.
[27]
DIJKSTRA, E.W. 1974. Self-stabfiizing systems in spite of distributed control Com mun. ACM 17, 643-644.
[28]
DIJKSTRA, E.W. 1973. Self-stabilization in spite of distributed control. In Selected Wrztmgs on Computing: A Personal Perspectwe. Springer- Verlag, Berlin, 1982, 41-46. Originally pubhshed in 1973.
[29]
DOLEV, S., ISRAELI, A., AND MORAN, S. 1990. Self-stabilization of dynamic systems. In Proceedmg's of the 9th Annual ACM Sympostum on Principles of Dzstributed Computing (Quebec City, Canada, Aug.). ACM, New York
[30]
EVANGELIST, M. 1989. Proceedings of the MCC Workshop on Self-Stabd~zmg Systems. MCC Tech. Rep. STP-379-89.
[31]
FLATEBO, M., AND DATTA, A. 1992. Two-state self-stabilizing algorithms. In Proceedings of the 6th Internatmnal Parallel Processing Symposium (Beverly Hills, Calif. Mar.), 198 203.
[32]
FLATEBO, M., DATTA, A., AND GttosI-I, S. 1991 Self-stabilization in distributed systems. IEEE Comput.
[33]
GAREY, M., AND JOHNSON, D. Computers and Intractabihty: A Guide to the Theory of NP-Completeness. W. H. Freeman, New York.
[34]
GttOSH, S. 1990a. Self-stabilizing distributed systems with binary machines. In Proceedings of the 28th Annual Allerton Conference, 988 997.
[35]
GHOSH, S. 1990b Understanding self-stabilization in distributed systems. Tech. Rep. TR-90- 02, Dept. of Computer Science, Univ. of Iowa.
[36]
GOUDA, M.G. 1989. The inevitable properties of programs. Dept. of Computer Sciences, Univ. of Texas at Austin.
[37]
GOUDA, M.G. 1991. The stabilizing philosopher: Asymmetry by memory and by action. Tech. Rep. TR-87~12, Dept. of Computer Sciences, Univ. of Texas at Austin.
[38]
GOUDA, M. G., AND EVANGELIST, M. 1990. Convergence/response tradeoffs in concurrent systems. In Proceedings of the 2nd IEEE Symposium on Parallel and Distributed Processing (Dec.). IEEE, New York.
[39]
GOUDA, M. G., AND HERMAN, T. 1991. Adaptive programming. IEEE Trans. Softw. Eng. 17, 9 (Sept.).
[40]
GOUDA, M. G., AND HERMAN, T. 1990. Stabilizing unison. Inf. Process. Lett. 35 (1990), 171 175.
[41]
GOUDA, M. G., AND MULTARI, N. 1991. Stabilizing communication protocols. IEEE Trans. Cornput. 40, 4 (Apr.), 448-458.
[42]
GOUDA, M. G., HOWELL, R. R., AND ROSmR, L. E. The instability of self-stabilization. Acta Inf. 27, (1990), 697-724.
[43]
HADDIX, F.F. 1991. Stabilization of bounded token rings. Tech. Rep. ARL-TR-91-31, Applied Research Lab., Univ. of Texas at Austin.
[44]
HERMAN, T. 1990. Probabilistic self-stabilization. Inf. Process. Lett. 15, 63-67.
[45]
HOARE, C. A. R. 1978. Communicating sequential processes. Commun. ACM 21,666-677.
[46]
ISRAELL A., AND JALFON, M. 1990. Token management schemes and random walks yield self stabilizing mutual exclusion. In Proceedings of the 9th Annual ACM Sympostum on Principles of Distributed Computing (Quebec City, Canada, Aug.). ACM, New York.
[47]
ISRAELI, A., AND JALFON, M. 1989. Self-stabilizing ring orientation. Tech. Rep., Dept. of Electrical Engineering, Technion-Israel.
[48]
JOHNSON, D. 1990. A catalog of complexity classes. In Handbook of Theoretical Computer Science. vol. A. North-Holland, Amsterdam.
[49]
JOHNSON, B. 1988. The Design and Analysis of Fault-Tolerant Dlgttal Systems, Addison-Wesley, New York.
[50]
KA?Z~ S., AND PERRY, K.J. 1990. Self-stabilizing extensions for message-passing systems. In Proceedings of the 9th Annual ACM Sympostum on Principles o{ Distributed Computing (Quebec City, Canada, Aug.). ACM, New York.
[51]
KRUIJER, H. S. M. 1979. Self-stabilization (in spite of distributed control) in tree-structured systems. Inf. Process. Lett., 8, 2, 2 79.
[52]
LAMPORT, L. 1986. The mutual exclusion problem: Part II--Statement and solutions. J. ACM 33, 327-348.
[53]
LAMPORT, L. 1984. Solved problems, unsolved problems and non-problems in concurrency. In Proceedings of the 3rd ACM Symposium on Principles of Distributed Computing. ACM, New York, 1-11.
[54]
LAPRIE, J.-C. 1985. Dependable computing and fault tolerance: Concepts and terminology. In Proceedtngs of FTCS-15, 2-11.
[55]
LEHMAN, D., AND RABIN, M. 1981. On the advantages of free choice: A symmetric and fully distributed solution of the dining philosophers problem. In Proceedings of the 8th Annual ACM Symposium on Principles of Programmtng Languages. ACM, New York, 133-138.
[56]
LFN, X., AND GHOSH, S. 1991. Self-stabilizing maxima finding. In Proceedings of the 28th Ann ual Allerton Conference.
[57]
MULTAR1, N. 1989. Towards a theory for selfstabilizing protocols. Ph.D. dissertation, Dept. of Computer Sciences, Univ. of Texas at Austin.
[58]
ZVEREN, C., WiLLSKY, A., AND ANTSAKLIS, P. 1989. Stability and stabilizability of discrete event dynamic systems. MIT LIDS Pub., LIDS-P- 1853, MIT, Cambridge, Mass.
[59]
SCHNEIDER, M. 1992. Compiling self-stabihzation into sequential programs. Dept. of Computer Sciences, Umv. of Texas, Austin, Tex.
[60]
SCHNEIDER, M. 1991. SelLstabilization--A unified approach to fault tolerance in the face of transient errors. In Tech. Rep. TR-91-18, Dept. of Computer Sciences, Univ. of Texas at Austin.
[61]
TCHUENTE, M. 1981. Sur 1 auto-stabilisation dans un ~eseau ttordinateurs. RAIRO Inf. Theor. 15, 47 66. In French.
[62]
WHITBY-STREVENS, C. 1979. On the performance of Dijkstra's self-stabilising algorithms in spite of distributed control. In Proceedings of the 1st Internattonal Conference on Distributed Computing Systems. IEEE, New York.

Cited By

View all

Recommendations

Reviews

David James Taylor

Self-stabilization is the property that guarantees that a system placed in an arbitrary state will return to a legitimate state within a finite number of state transitions. This paper provides an extensive survey of research into self-stabilization and such related notions as probabilistic self-stabilization and pseudo-stabilization. Although it provides a good general background and historical summary, the paper is likely to prove frustrating for a reader unfamiliar with the field. The authors frequently introduce a topic too briefly for it to be really appreciated and then refer the reader to the original work for details. In addition, the paper does not provide any proofs for self-stabilization. With no examples, the reader may be left without a grasp of the type of argument required. For the original Dijkstra unidirectional ring, it would not have been difficult to sketch a proof rather than leave the reader with the statement, “Furthermore it can be shown quite easily that if started in an arbitrary state, the system will stabilize.” The paper claims, as does much of the cited literature, that self-stabilization is a useful technique for fault tolerance. A critical reading of the paper suggests that the field has instead provided a number of impossibility results. In some instances, self-stabilization can only be achieved if a system has an infinite number of states; elsewhere it is indicated that termination and self-stabilization are frequently mutually exclusive. (The attempt to equate distributed systems with nonterminating systems and, thus, claim that termination is not a significant issue is unrealistic.) The quote from L. Lamport near the beginning of the paper, “I regard it [E. W. Dijkstra's original work on self-stabilization] to be a milestone in work on fault tolerance,” needs to be balanced by a reasonable assessment of the limited practical application that self-stabilization has had and is likely to have.

Access critical reviews of Computing literature here

Become a reviewer for Computing Reviews.

Comments

Information & Contributors

Information

Published In

cover image ACM Computing Surveys
ACM Computing Surveys  Volume 25, Issue 1
March 1993
62 pages
ISSN:0360-0300
EISSN:1557-7341
DOI:10.1145/151254
Issue’s Table of Contents

Publisher

Association for Computing Machinery

New York, NY, United States

Publication History

Published: 01 March 1993
Published in CSUR Volume 25, Issue 1

Permissions

Request permissions for this article.

Check for updates

Author Tags

  1. convergence
  2. fault tolerance
  3. self-stabilization
  4. self-stabilizing systems
  5. stabilization
  6. transient errors
  7. transient failures

Qualifiers

  • Article

Contributors

Other Metrics

Bibliometrics & Citations

Bibliometrics

Article Metrics

  • Downloads (Last 12 months)194
  • Downloads (Last 6 weeks)31
Reflects downloads up to 15 Jan 2025

Other Metrics

Citations

Cited By

View all

View Options

View options

PDF

View or Download as a PDF file.

PDF

eReader

View online with eReader.

eReader

Login options

Full Access

Media

Figures

Other

Tables

Share

Share

Share this Publication link

Share on social media