bc https://en.wikipedia.org/wiki/Gossip_protocol
- 分布式容错性:分布式网络极其鲁棒,能够容忍部分节点的异常状态;
- 不可篡改性:一致提交后的数据会一直存在,不可被销毁或修改;
- 隐私保护性:密码学保证了数据隐私,即便数据泄露,也无法解析。
随之带来的业务特性将可能包括:
- 可信任性:区块链技术可以提供天然可信的分布式账本平台,不需要额外第三方中介机构参与;
- 降低成本:跟传统技术相比,区块链技术可能带来更短的时间、更少的人力,降低维护成本;
- 增强安全:区块链技术将有利于安全、可靠的审计管理和账目清算,减少犯罪风险。
比特币区块链已经支持了简单的脚本计算,但仅限于数字货币相关的处理。除了支持数字货币外,还可以将区块链上执行的处理过程进一步泛化,即提供智能合约(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的更多相关文章
- https://en.wikipedia.org/wiki/Green_threads
https://en.wikipedia.org/wiki/Green_threads
- 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 ...
- kerberos (https://en.wikipedia.org/wiki/Kerberos_(protocol))
Protocol[edit] Description[edit] The client authenticates itself to the Authentication Server (AS) w ...
- 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)是一个用于标识某一互联网资源名称的字符串. 该种标识允许用户对网络中( ...
- https://zh.cppreference.com 和 https://en.cppreference.com 和 https://cppcon.org/
https://zh.cppreference.comhttps://en.cppreference.com/w/ https://cppcon.org/
- git 基本操作 https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/0013744142037508cf42e51debf49668810645e02887691000
1.创建版本库 (即仓库 repository)简单理解为一个目录,这个目录里的所有文件都可以被git管理起来,每个文件的修改删除,git都能跟踪,一边任何时刻都可以追踪历史,或者在将来某个时刻可以 ...
- Promise https://www.liaoxuefeng.com/wiki/1022910821149312/1023024413276544
在JavaScript的世界中,所有代码都是单线程执行的. 由于这个“缺陷”,导致JavaScript的所有网络操作,浏览器事件,都必须是异步执行.异步执行可以用回调函数实现: function ca ...
- 近千节点的Redis Cluster高可用集群案例:优酷蓝鲸优化实战(摘自高可用架构)
(原创)2016-07-26 吴建超 高可用架构导读:Redis Cluster 作者建议的最大集群规模 1,000 节点,目前优酷在蓝鲸项目中管理了超过 700 台节点,积累了 Redis Clus ...
- 从新冠疫情出发,漫谈 Gossip 协议
众所周知周知,疫情仍然在全球各地肆虐.据最新数据统计,截至北京时间 2020-05-28,全球累计确诊 5698703 例,累计死亡 352282 例,累计治愈 2415237 例. 从上面的统计数据 ...
随机推荐
- Socket网络编程--epoll小结
以前使用的用于I/O多路复用为了方便就使用select函数,但select这个函数是有缺陷的.因为它所支持的并发连接数是有限的(一般小于1024),因为用户处理的数组是使用硬编码的.这个最大值为FD_ ...
- idea android 开发
plugins 勾上 插件即可
- 【6集iCore3_ADP触摸屏驱动讲解视频】6-6 底层驱动之触摸操作
源视频包下载地址: 链接:http://pan.baidu.com/s/1skQlWAT 密码:ymn7 银杏科技优酷视频发布区: http://i.youku.com/gingko8
- 关于指针*前后const代表的意思——记住一个口诀“左内右本”
记住一个口诀“左内右本”:const出现在*的左边,则说明指针所指向的内容是常量const出现在*的右边,则说明指针本身是常量如果*左右两边都出现const,那么说明指针本事是常量,它所指向的内容也是 ...
- Spring AOP 详解[转]
此前对于AOP的使用仅限于声明式事务,除此之外在实际开发中也没有遇到过与之相关的问题.最近项目中遇到了以下几点需求,仔细思考之后,觉得采用AOP 来解决.一方面是为了以更加灵活的方式来解决问题,另一方 ...
- python中的生成器函数是如何工作的?
以下内容基于python3.4 1. python中的普通函数是怎么运行的? 当一个python函数在执行时,它会在相应的python栈帧上运行,栈帧表示程序运行时函数调用栈中的某一帧.想要获得某个函 ...
- [UI] 06 - jQuery
前言 From : http://www.runoob.com/jquery/jquery-intro.html Ref: jQuery 实例 一.什么是 jQuery ? jQuery是一个Java ...
- Navicat -- Oracle -- 错误锦集
ORA:connection to server failed,probable Oracle Net admin error 解决的方案是: oci.dll的版本不对 从 http://www.o ...
- Tomcat -- 启动错误 -- 解决锦集
java.lang.NoSuchMethodException: org.apache.catalina.deploy.WebXml addFilter :在Tomacat7的context.xml文 ...
- sklearn参数优化方法
学习器模型中一般有两个参数:一类参数可以从数据中学习估计得到,还有一类参数无法从数据中估计,只能靠人的经验进行指定,后一类参数就叫超参数 比如,支持向量机里的C,Kernel,gama,朴素贝叶斯里的 ...