分布式系统中的 safety 和 liveness

栏目: 后端 · 发布时间: 7年前

内容简介:在分布式系统的算法和设计中,通俗来讲,这2个属性的含义就是:我们可以举一些例子来说明:

在分布式系统的算法和设计中, safetyliveness 是2个非常重要的属性,这个概念最早由 L. Lamport 提出。这2个属性是非常基础的属性,系统中的其他属性都可以被分解为 safetyliveness

通俗来讲,这2个属性的含义就是:

  • safety something “bad” will never happen
  • liveness something “good” will must happen (but we don’t know when)

我们可以举一些例子来说明:

  1. 同一时刻,只有一个进程能够进入互斥临界区

1是一个关于 safety 的表述,它表述了,什么样的时间不应该被发生,那就是”同一时刻,不少于一个进程进入了互斥临界区“。

  1. 进程 P2 不会永远停留在互斥临界区,以至于 P1 最终能够进入互斥临界区。

2是一个关于 liveness 的表述,它表述了什么样的事件最终应该被发送,那就是“ P1 最终会进入互斥临界区”。

  1. gossip协议具有 最终一致性

3是关于 liveness 的表述,

更加形式化的解释我们可以参考 Safety & Liveness Properties

虽然 safetyliveness 是正交地两个属性,但是在设计一个分布式系统时,我们需要同时考虑这两个属性,只具备其中之一的系统是没有意义的。

避免 死锁 是保证 liveness 的一个充分条件,虽然这个约束比较弱。但是是比较好验证的,如果算法、逻辑中存在死锁,那么一定不能保证系统的 liveness 。避免 饥饿 也是保证 liveness 的一个充分条件,这个约束比避免 死锁 更强一些,因为避免 饥饿 的算法一定是避免 死锁 的。更强的约束是,保证算法、逻辑能在 有限步骤内完成 ,这样系统一定是 liveness 的,但是这个约束条件很难被验证和证明。

关于 safetyliveness 的历史可以参考 afety and liveness properties: a survey

参考


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

编译原理

编译原理

Alfred V. Aho、Monica S.Lam、Ravi Sethi、Jeffrey D. Ullman / 赵建华、郑滔、戴新宇 / 机械工业出版社 / 2008年12月 / 89.00元

本书全面、深入地探讨了编译器设计方面的重要主题,包括词法分析、语法分析、语法制导定义和语法制导翻译、运行时刻环境、目标代码生成、代码优化技术、并行性检测以及过程间分析技术,并在相关章节中给出大量的实例。与上一版相比,本书进行了全面的修订,涵盖了编译器开发方面的最新进展。每章中都提供了大量的系统及参考文献。 本书是编译原理课程方面的经典教材,内容丰富,适合作为高等院校计算机及相关专业本科生及研......一起来看看 《编译原理》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

在线进制转换器
在线进制转换器

各进制数互转换器