• 分布式容错性:分布式网络极其鲁棒,能够容忍部分节点的异常状态;
  • 不可篡改性:一致提交后的数据会一直存在,不可被销毁或修改;
  • 隐私保护性:密码学保证了数据隐私,即便数据泄露,也无法解析。

随之带来的业务特性将可能包括:

  • 可信任性:区块链技术可以提供天然可信的分布式账本平台,不需要额外第三方中介机构参与;
  • 降低成本:跟传统技术相比,区块链技术可能带来更短的时间、更少的人力,降低维护成本;
  • 增强安全:区块链技术将有利于安全、可靠的审计管理和账目清算,减少犯罪风险。

比特币区块链已经支持了简单的脚本计算,但仅限于数字货币相关的处理。除了支持数字货币外,还可以将区块链上执行的处理过程进一步泛化,即提供智能合约(Smart
Contract)。智能合约可以提供除了货币交易功能外更灵活的合约功能,执行更为复杂的操作。

这样扩展之后的区块链,已经超越了单纯数据记录的功能了,实际上带有点“智能计算”的意味了;更进一步地,还可以为区块链加入权限管理,高级编程语言支持等,实现更强大的、支持更多商用场景的分布式账本。

据参与者的不同,可以分为公有(Public)链、联盟(Consortium)链和私有(Private)链。

公有链,顾名思义,任何人都可以参与使用和维护,典型的如比特币区块链,信息是完全公开的。

如果进一步引入许可机制,可以实现私有链和联盟链两种类型。

私有链,由集中管理者进行管理限制,只有内部少数人可以使用,信息不公开。

联盟链则介于两者之间,由若干组织一起合作维护一条区块链,该区块链的使用必须是带有权限的限制访问,相关信息会得到保护,典型如供应链机构或银行联盟。

目前来看,公有链更容易吸引市场和媒体的眼球,但更多的商业价值会在联盟链和私有链上落地。

根据使用目的和场景的不同,又可以分为以数字货币为目的的货币链,以记录产权为目的的产权链,以众筹为目的的众筹链等……,也有不局限特定应用场景的通用链。

现有大部分区块链实现都至少包括了网络层、共识层、智能合约和应用层等结构,联盟链实现往往还会引入一定的权限管理机制。

问题是什么?

This
problem appears both in data consistency maintenance and in
synchronization of a cluster state (propagation of the cluster
membership information and so on). Although the problem above can
be solved by means of a global coordinator that monitors a
database and builds a global synchronization plan or schedule,
decentralized databases take advantage of more
fault-tolerant approach
. The main idea is to use
well-studied epidemic protocols
[7] that are relatively simple, provide a pretty good convergence
time, and can tolerate almost any failures or network partitions.
Although there are different classes of epidemic algorithms, we
focus on anti-entropy protocols because
of their intensive usage in NoSQL databases.

Anti-entropy
protocols assume that synchronization is performed by a fixed
schedule – every node regularly chooses another node at random or
by some rule and exchanges database contents, resolving
differences. There are three flavors of anti-entropy protocols: push,
pull, and push-pull
. The idea of the push protocol is
to simply select a random peer and push a current state of data to
it. In practice, it is quite silly to push the entire database, so
nodes typically work in accordance with the protocol which is
depicted in the figure below.

这个问题当然可以通过global
coordinator来解决, 但是decentralized设计可以提供more fault-tolerant
approach的设计.

其实算法很简单,
就是epidemic protocols,
这儿选了在Nosql中广泛应用的anti-entropy protocols.

Push,
问B你有什么和我不同, B告诉我, 我把不同部分push给B

Pull,
告诉B我有什么, B把我没有的发给我

Push-pull,
把上面两个同时结合做了, 图的下面两条线箭头画反了

Anti-entropy
protocols provide reasonable good convergence time and
scalability. The following figure shows simulation results for
propagation of an update in the cluster of 100 nodes. On each
iteration, each node contacts one randomly selected peer.

One
can see that the pull style provides better convergence than the
push, and this can be proven theoretically [7]. Also, push has a
problem with a “convergence tail” when a small percent of nodes
remains unaffected during many iterations, although almost all
nodes are already touched. The Push-Pull approach greatly improves
efficiency in comparison with the original push or pulls
techniques, so it is typically used in practice. Anti-entropy is
scalable because the average conversion time grows as a
logarithmic function of the cluster size.

Although
these techniques look pretty simple, there are many studies [5]
regarding performance of anti-entropy protocols under different
constraints. One can leverage knowledge of the network topology to
replace a random peer selection by a more efficient schema [10];
adjust transmit rates or use advanced rules to select data to be
synchronized if the network bandwidth is limited [9]. Computation
of digest can also be challenging, so a database can maintain a
journal of the recent updates to facilitate digests computing.

怎么衡量Anti-entropy
protocols, 当然是通过convergence
 time, 
肯定是Push-pull效率最高

bc https://en.wikipedia.org/wiki/Gossip_protocol的更多相关文章

  1. https://en.wikipedia.org/wiki/Green_threads

    https://en.wikipedia.org/wiki/Green_threads

  2. abi-api, arm target triplet https://en.wikipedia.org/wiki/ARM_architecture

    GNU软件用target triplet来描述工作平台,target triplet是一种规范化的名称,形如cpu-vendor-os(where os can be ‘system’ or ‘ker ...

  3. kerberos (https://en.wikipedia.org/wiki/Kerberos_(protocol))

    Protocol[edit] Description[edit] The client authenticates itself to the Authentication Server (AS) w ...

  4. URI--http://zh.wikipedia.org/wiki/%E7%BB%9F%E4%B8%80%E8%B5%84%E6%BA%90%E6%A0%87%E5%BF%97%E7%AC%A6

    维基百科,自由的百科全书     在电脑术语中,统一资源标识符(Uniform Resource Identifier,或URI)是一个用于标识某一互联网资源名称的字符串. 该种标识允许用户对网络中( ...

  5. https://zh.cppreference.com 和 https://en.cppreference.com 和 https://cppcon.org/

    https://zh.cppreference.comhttps://en.cppreference.com/w/ https://cppcon.org/

  6. git 基本操作 https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/0013744142037508cf42e51debf49668810645e02887691000

    1.创建版本库 (即仓库  repository)简单理解为一个目录,这个目录里的所有文件都可以被git管理起来,每个文件的修改删除,git都能跟踪,一边任何时刻都可以追踪历史,或者在将来某个时刻可以 ...

  7. Promise https://www.liaoxuefeng.com/wiki/1022910821149312/1023024413276544

    在JavaScript的世界中,所有代码都是单线程执行的. 由于这个“缺陷”,导致JavaScript的所有网络操作,浏览器事件,都必须是异步执行.异步执行可以用回调函数实现: function ca ...

  8. 近千节点的Redis Cluster高可用集群案例:优酷蓝鲸优化实战(摘自高可用架构)

    (原创)2016-07-26 吴建超 高可用架构导读:Redis Cluster 作者建议的最大集群规模 1,000 节点,目前优酷在蓝鲸项目中管理了超过 700 台节点,积累了 Redis Clus ...

  9. 从新冠疫情出发,漫谈 Gossip 协议

    众所周知周知,疫情仍然在全球各地肆虐.据最新数据统计,截至北京时间 2020-05-28,全球累计确诊 5698703 例,累计死亡 352282 例,累计治愈 2415237 例. 从上面的统计数据 ...

随机推荐

  1. Atitit 翻页功能的解决方案与版本历史 v4 r49

    Atitit 翻页功能的解决方案与版本历史 v4 r49 1. 版本历史与分支版本,项目版本记录1 1.1. 主干版本历史1 1.2. 分支版本  项目版本记录.1 2. Easyui 的翻页组件2 ...

  2. Android studio的主题颜色修改

    1.选择喜欢的主题 http://color-themes.com/?view=index 好几十款,总有一款你喜欢 2.下载你喜欢的主题,注意是jar文件 .File -> Import Se ...

  3. Python list 常用方法总结

    一,创建列表  只要把逗号分隔的不同的数据项使用方括号([ ])括起来即可 下标(角标,索引)从0开始,最后一个元素的下标可以写-1 list  =  ['1',‘2,‘3’] list = [] 空 ...

  4. 【Java】Java Queue的简介

    阻塞队列 阻塞队列有几个实现: ArrayBlockingQueue LinkedBlockingQueue PriorityBlockingQueue DelayQueue SynchronousQ ...

  5. DIOCP-V5发布

    DIOCP-v5开源项目 https://github.com/ymofen/diocp-v5   DIOCP-v5 0.0.1   2015-02-22 08:40:40 1.规范单元文件的命名,和 ...

  6. Android Studio 运行出现 Multiple dex files define Landroid/support/annotation/AnimRes 解决方法

    引入的工程的android-support-v4.jar版本跟自己工程的android-support-v4.jar的版本不一样

  7. 【iCore4 双核心板_ARM】例程七:WWDG看门狗实验——复位ARM

    实验原理: STM32内部包含窗口看门狗,通过看门狗可以监控程序运行,程序运行错误时,未在 规定时间喂狗(提前或超时),自动复位ARM,本实验通过按键按下,停止喂狗,从而产 生复位. 核心代码: in ...

  8. 【iCore1S 双核心板_FPGA】例程三:计数器实验——计数器的使用

    实验现象: 程序下载成功后,程序中的计数器开始计数,每次计满后,计数器清零,三色LED中红色LED的状态反转.可以看到,红色LED以一定的时间间隔闪烁. 核心源代码: //-------------- ...

  9. 【Linux】防火墙与CentOS中的iptables

    [iptables] 参考好文:http://www.zsythink.net/archives/1199.这个博客的作者写了深入浅出的iptables介绍,基本上我就是做个他的读书笔记. ■ 基本介 ...

  10. IDEA VS 常用高效 黄金 快捷键

    [参考] VS 常用高效 快捷键 身为一个编程人员,掌握IDE的快键是提高开发效率最简单直接的方法,也是必备技能.和网上的大篇罗列不同,下面只讲精髓,根据实践不断调整.本人C#转Java,曾经试过Ec ...