因为工作的原因,最近打算看一些分布式学习的资料。其中这个http://book.mixu.net/distsys/就是一篇非常适合分布式入门的介绍。

这个短小的材料有下面5个小的章节,图文并茂,也没有太难的概念,非常推荐。

  1. 基础知识。主要是一些基本概念,例如可扩展性(scalability),可用性(availability)(马上就要写成bilibili了),性能(performance),容错(fault tolerance)。
  2. 上下层的抽象。CAP,敲黑板,这个是个很入门和重要的理论。
  3. 时间和顺序。强调了这两者在分布式系统里,对一致的重要性。
  4. Replication 副本(不是游戏里面的):防止divergence。这个divergence是一致性的死对头。divergence是什么,大概是set(k, v)以后,get(k) = v1, v2, ... vn 了吧。
  5. Replication 副本:容忍divergence。如果系统旨在实现weak consistence,那么可以接受一定程度的divergence。
  6. 最后作者专业地列出了所有引用的论文。真是好人。

现在我从第一章做个笔记。(年龄大了,这年头不做笔记不行啊。。。)

我比较喜欢作者的风格,每次开篇或者强调的地方都用鲜艳的颜色和醒目字号标记出来。比如第一章的导言:

Distributed programming is the art of solving the same problem that you can solve on a single computer using multiple computers.

为什么要能用一台电脑完成的事情,我们有时候需要用多台电脑来做呢?

因为一台电脑的资源往往有限。随着问题规模增加,我们升级单台电脑的硬件都可能无法完成任务。那么为什么需要分布式系统呢?

我们的目标:可扩展性

数一数房间里面有多少人很简单,但是要计算全国的人口就非常困难了。作者给可扩展性下了下面的定义。

可扩展性就是某系统,网络或者进程利索能力地处理不断增长的工作量的能力,或者自身扩大以处理这种增长的能力。

性能(performace)/延时(latency) 不解释了大家都懂。不过作者这里给了个比喻蛮有趣:

延时就是存在但未发生。比如你被某空气传染的丧尸病毒感染了。延时就是你被感染的时间和你变成丧尸的时间差。又比如,延时可以是一个写操作发生到被读者看到的时间。

可用性(availability)/容错(fault tolerance)

这是分布式系统的第二个特点。可用性表示,有多少时间某系统是能正常工作的。分布式系统能够通过把很多不可靠的组件合在一起,在之上构建一个可靠的系统。

可用性也可以表示成:

Availability = uptime / (uptime + downtime)

那啥是容错呢?系统在发生错误的情况下正常工作的能力。容错主要的问题就是,定义你能想到的错误,然后进行系统or算法设计来容忍它们。高可用性和容错是分布式系统的对使用者的承诺。

在分布式系统中,是什么导致我们没法达成上面的目标?

  • 单个节点的数量
  • 节点之间的距离

抽象和模型

抽象让我们忽略一些真实世界的繁杂,从而把注意力集中在本质问题上。模型则是抽象的产物,描述分布式系统的关键属性。这个入门教程将要介绍下吗几个分布式模型的类型:

  • 系统模型(异步/同步)
  • 容错模型(crash-fail, paritions, 拜占庭)
  • 一致性模型(强/弱一致性)

其实这些抽象和模型的建立,就是一个目标,让分布式系统表现得像“一个单节点的系统”。内部分布和表现集中,这是一个此消彼长的矛盾,给我们实现一个分布式系统造成了很多困难。如果一个系统并不做强烈地“表现得像单个系统”(高可用性和容错)

这样的承诺,那么性能会变得很好。

设计技巧:划分(Partition)和副本(Replicate)

我们的数据怎么分布在不同节点上,这是个问题。要让计算进行,我们需要定位数据并对他们进行操作。数据的操作有两种方式:

  • Partition
  • Replicate

Partition就是把我们的数据集打撒成不同几份,分开存储。而replicate则是把数据复制多份,分开存储。如下图(再次喜欢这个画风)

这个在存储里面的应用就是RAID0/1了,我们叫Stripe和Mirror。

Replication 允许我们实现可扩展性,性能和容错。不过这也是许多问题的源泉,因为我们面临的是多个独立的数据拷贝,他们需要在多台机器上保持同步。这就是说要实现某种一致性模型。

一致性模型的实现蛮重要。好的一致性模型对程序员(这里应该指的是Client,分布式系统的调用者)来说语义清楚,容易理解,同时也满足业务和设计的目标,例如高可用性或者强一致性。

仅有强一致模型允许你像使用单节点系统一样。其他一致性模型或多或少暴露了一些内部的实现。不过弱一致系统可以提高低延时和更高的可用性,并不一定难以理解,各有秋色罢了。

Summary

这章除了讲解一些概念,反复强调的一个问题就是如果解决在多台机器上实现一台机器的事务的矛盾。如果你暴露更多细节,表现得很”分布“,那么你性能就更好,但是理解起来可能会比较难。

[分布式系统学习]阅读笔记 Distributed systems for fun and profit 之一 基本概念的更多相关文章

  1. [分布式系统学习]阅读笔记 Distributed systems for fun and profit 之四 Replication 拷贝

    阅读http://book.mixu.net/distsys/replication.html的笔记,是本系列的第四章 拷贝其实是一组通信问题,为一些子问题,例如选举,失灵检测,一致性和原子广播提供了 ...

  2. [分布式系统学习]阅读笔记 Distributed systems for fun and profit 之三 时间和顺序

    这是阅读 http://book.mixu.net/distsys/time.html 的笔记,是该系列的第三章. 为什么时间和顺序很重要呢?为什么我们关系事件A发生在事件B之前? 因为分布式系统要解 ...

  3. [分布式系统学习]阅读笔记 Distributed systems for fun and profit 抽象 之二

    本文是阅读 http://book.mixu.net/distsys/abstractions.html 的笔记. 第二章的题目是"Up and down the level of abst ...

  4. Mongodb Manual阅读笔记:CH4 管理

    4 管理 Mongodb Manual阅读笔记:CH2 Mongodb CRUD 操作Mongodb Manual阅读笔记:CH3 数据模型(Data Models)Mongodb Manual阅读笔 ...

  5. Distributed systems theory for the distributed systems engineer

    Gwen Shapira, SA superstar and now full-time engineer at Cloudera, asked a question on Twitter that ...

  6. [置顶] 人工智能(深度学习)加速芯片论文阅读笔记 (已添加ISSCC17,FPGA17...ISCA17...)

    这是一个导读,可以快速找到我记录的关于人工智能(深度学习)加速芯片论文阅读笔记. ISSCC 2017 Session14 Deep Learning Processors: ISSCC 2017关于 ...

  7. 可扩展的Web系统和分布式系统(Scalable Web Architecture and Distributed Systems)

    Open source software has become a fundamental building block for some of the biggest websites. And a ...

  8. 论文阅读笔记 Improved Word Representation Learning with Sememes

    论文阅读笔记 Improved Word Representation Learning with Sememes 一句话概括本文工作 使用词汇资源--知网--来提升词嵌入的表征能力,并提出了三种基于 ...

  9. (转)深度学习word2vec笔记之基础篇

    深度学习word2vec笔记之基础篇 声明: 1)该博文是多位博主以及多位文档资料的主人所无私奉献的论文资料整理的.具体引用的资料请看参考文献.具体的版本声明也参考原文献 2)本文仅供学术交流,非商用 ...

随机推荐

  1. MathType如何编辑大三角形符号

    MathType中包含的符号超过1000多个,可以满足我们很多学科的使用,尤其是数学中,涉及到很多的符号,常见的就是代数.几何这两大类,当然还有集合之类的符号使用也比较多.我们在用MathType编辑 ...

  2. 【QT学习】QT GUI应用程序的框架,文件分析

    有几个名字,项目名,类名,界面对象名. 1.项目文件 项目名.pro(MyHelloQt.pro) 主要包括项目用到的模块,项目包含哪些源码文件,头文件,窗体文件,生成应用程序的名称. 由QT自动生成 ...

  3. Java加密和C#解密=>DES方法

    Java加密代码: import javax.crypto.*; import javax.crypto.*; import java.io.UnsupportedEncodingException; ...

  4. 源码分析五(HashSet的内部实现)

    一:首先来看看Hashset的继承体系 public class HashSet<E> extends AbstractSet<E> implements Set<E&g ...

  5. mysql中参数low_case_table_name的使用?不同参数值的设置有什么影响?

    需求描述: 今天一个同事问,在mysql中,默认的表名是大小写区分的吗,默认是什么设置, 如果要设置成大小写不区分的改怎么设置,是否需要进行重启.然后就进行了查询, 对于lower_case_tabl ...

  6. iOS 播放gif动态图的方式探讨

    原文链接:http://my.oschina.net/u/2340880/blog/608560 摘要iOS中没有现成的接口来展示gif动态图,但可以通过其他的方式来处理gif图的展示.iOS中播放g ...

  7. PDF XSS

    漏洞测试: 下面,我们介绍如何把 JavaScript 嵌入到 PDF 文档之中.我使用的是迅捷 PDF 编辑器未注册版本 1.启动迅捷 PDF 编辑器打开一个 PDF 文件,或者使用“创建 PDF ...

  8. HttpClient(五)-- 模拟表单上传文件

    1.maven依赖 <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId ...

  9. Ubuntu图形界面和字符界面转换、指定默认启动界面

    1.按ALT+CTRL+F1.F2.F3.F4.F5.F6.F7可来回切换7个界面(Linux实体机)      其中ALT+CTRL+F7可切换到图形界面(Linux实体机)        如果是V ...

  10. [Windows] 解决 VLC Media Player 的 Crash Reporting 消息弹窗

    运行环境:Windows 8.1 (64bits), VLC Media Player 2.1.3 异常描述:首次启动VLC播放影音文件时,一切正常.此后每次启动VLC都弹出"VLC Cra ...