主頁 > 區塊鏈 > 從分布式一致性演算法到區塊鏈共識演算法(一)

從分布式一致性演算法到區塊鏈共識演算法(一)

2021-04-20 11:53:00 區塊鏈

從分布式一致性演算法到區塊鏈共識演算法(一)

本文主要參考書籍:區塊鏈原理、設計與應用第二版

一致性問題

一致性問題是分布式領域最為基礎也是最重要的問題, 如果分布式系統能實作“一致”, 對外就可以呈現為一個完美的、可擴展的“虛擬節點”,相對物理節點具備更優越性能和穩 定性 , 這也是分布式系統希望能實作的最終目標,

一致性要求

  1. 可終止性( termination ):一致的結果在有限時間內能完成;
  2. 約同性( agreement):不同節點最終完成決策的結果是相同的;
  3. 合法性( validity):決策的結果必須是某個節點提出的提案 ,

帶約束的一致性

要實作絕對理想的嚴格一致性( strict consistency)代價很大 , 除非系統不發生任何故障,而且所有節點之間的通信無需任何時間,這個時候整個系統其實就等價于一臺機器了 ,
實際上,越強的一致性要求往往會造成越弱的處理性能,以及越差的可擴展性 ,

一般來講,強一致性( strong consistency)主要包括下面兩類:

  1. 順序一致性( sequential consistency) : Leslie Lamport 在 1979 年的經典論文 《 How toMake a Multiprocessor Computer That Correctly Executes
    Multiprocess Programs 》 中提出,是一種比較強的約束,保證所有行程看到的全域執行順序( total order )
    一致,并且每個行程看自身的執行順序( local order)跟實際發生順序一致, 例如,某行程第 4 重分布式系統核心問題 令 37先執行
    A ,后執行 B ,則實際得到的全域結果中就應該為 A 在 B 前面,而不能反過來 , 同時所有其他行程在全域上也應該看到這個順序 ,
    順序一致性實際上限制了各行程內指令的偏序關系,但不在行程間按照物理時間進行全域排序;
  2. 線性一致性( linearizability consistency) : Maurice P. Herlihy 與 Jeannette M. Wing 在1990 年的經典論文 《 Linearizability: A Correctness
    Condition for Concurrent Objects
    中共同提出,在順序一致性前提下加強了行程間的操作排序,形成唯一的全域順序(系統等價于是順序執行,所有行程看到的所有操作的序列順序都一致,并且跟實際發生順序一致),是很強的原子性保證,
    但是比較難實作,目前基本上要么依賴于全 局的時鐘或鎖,要么通過一些復雜演算法實作,性能往往不高 ,

由于強一致性的系統往往比較難實作,而且很多時候,實際需求并沒有那么嚴格需要 強一致性 , 因此,可以適當地放寬對一致性的要求,從而降低系統實作的難度 , 例如在一定約束下實作所謂最終一致性( eventual
consistency),即總會存在一個時刻(而不是立刻),讓系統達到一致的狀態 , 大部分 Web 系統實作的都是最終一致性 ,
相對強一致性,這一類在某些方面榷訓的一致性都籠統稱為弱一致性(weak consistency ) ,

FLP不可能定理

定義

FLP 不可能原理: 在網路可靠,但允許節點失效(即便只有一個)的最小化異步模型 系統中,不存在一個可以解決一致性問題的確定性共識演算法( No completely asynchronous consensus
protocol can tolerate even a single unannounced process death ) ,

FLP 不可能原理實際上告訴人們,不要浪費時間,去為異步分布式系統設計在任意場 景下都能實作共識的演算法,

正確理解

FLP不可能定理的最大適用前提是異步網路模型,何為同步、異步模型呢?

  1. 所謂異步模型,是說從一個節點到另一個節點的訊息延遲是有限的,但可能是無界的(finite but can be unbounded),這就意味著如果一個節點沒有收到訊息,它無法判斷訊息到底是丟失了,還是只是延遲了,也就是說,我們無法通過超時時間來判斷某個節點是否故障,
  2. 所謂同步模型,是說訊息傳遞的延遲是有限的,且是有界的,這就意味著我們可以通過經驗或采樣精確估算訊息的最大可能延遲,從而可以通過超時時間來確定訊息是否丟失、節點是否故障,
    綜上所述,在分布式系統中,同步和異步這兩個術語存在特殊的含義 , 同步是指系統中的各個節點的時鐘誤差存在上限;并且訊息傳遞必須在一定時間
    內完成, 否則認為失敗 ;同時各個節點完成處理訊息的時間是一定的 , 對于同步系統,可以很容易地判斷訊息是否丟失 ,
    異步是指系統中各個節點可能存在較大的時鐘差異,同時訊息傳輸時間是任意長的,各節點對訊息進行處理的時間也可能是任意長的,這就造成無法判斷某個訊息遲遲沒有被回應是哪里出了問題(節點故障還是傳輸故障?)

如何規避“FLP不可能定理”

研究者們通過調整問題模型來規避“FLP 不可能定理”從而尋找工程上可行的共識演算法, 比如位元幣系統中通過假定網路為弱同步性, 即網路節點間可以快速同步,以及礦工在一個區塊上投入有限的時間等來規避“FLP
不可能定理”,通過調整問題模型規避“FLP 不可能定理”, 使得共識演算法存在“工程解”,

CAP定理

定義

分布式系統無法同時滿足一致性 (Consistency)、可用性(Availability)和磁區容忍性(Partition Tolerance), 最多只能同時滿足其中兩個特性, 如下圖所示,
在這里插入圖片描述

  1. 一致性是指分布式系統中所有節點在同一時刻持有同樣的資料資訊,而且任何操作應該都是原子的,發生在后面的事件能看到前面事件發生導致的結果,注意這里指的是強一致性;
  2. 可用性是指系統處于服務狀態, 當客戶端發出請求, 服務端能在有效的時間內回傳結果;
  3. 磁區容忍性是指允許網路中部分節點不與其他節點通信,即允許網路發生磁區(不同區域之間的節點不能建立通信),

應用場景

  1. 榷訓一致性
    對結果一致性不敏感的應用,可以允許在新版本上線后過一段時間才最終更新成功, 期間不保證一致性 , 例如網站靜態頁面內容 、 實時性較弱的查詢類資料庫等,簡單分布式同步協議如 Gossip ,以及 CouchDB 、 Cassandra 資料庫等,都是為此設計的 ,
  2. 榷訓可用性
    對結果 一 致性很敏感的應用,例如銀行取款機,當系統故障時候會拒絕服務 , MongoDB 、 Redis 、MapReduce 等是為此設計的 , Paxos 、 Raft 等共識演算法,主要處理這種情況 ,在 Paxos
    類演算法中,可能存在著無法提供可用結果的情形,同時允許少數節點離線 ,
  3. 榷訓磁區容忍性
    現實中,網路磁區出現概率較小,但較難完全避免, 兩階段的提交演算法,某些關系型 資料庫及 ZooKeeper 主要考慮了這種設計, 實踐中,網路可以通過雙通道等機制增強可靠性,達到高穩定的網路通信,

轉載請註明出處,本文鏈接:https://www.uj5u.com/qukuanlian/278134.html

標籤:區塊鏈

上一篇:對稱加密和非對稱加密

下一篇:從零基礎部署自己的數字貨幣機器人(初稿)

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • JAVA使用 web3j 進行token轉賬

    最近新學習了下區塊鏈這方面的知識,所學不多,給大家分享下。 # 1. 關于web3j web3j是一個高度模塊化,反應性,型別安全的Java和Android庫,用于與智能合約配合并與以太坊網路上的客戶端(節點)集成。 # 2. 準備作業 jdk版本1.8 引入maven <dependency> < ......

    uj5u.com 2020-09-10 03:03:06 more
  • 以太坊智能合約開發框架Truffle

    前言 部署智能合約有多種方式,命令列的瀏覽器的渠道都有,但往往跟我們程式員的風格不太相符,因為我們習慣了在IDE里寫了代碼然后打包運行看效果。 雖然現在IDE中已經存在了Solidity插件,可以撰寫智能合約,但是部署智能合約卻要另走他路,沒辦法進行一個快捷的部署與測驗。 如果團隊管理的區塊節點多、 ......

    uj5u.com 2020-09-10 03:03:12 more
  • 谷歌二次驗證碼成為區塊鏈專用安全碼,你怎么看?

    前言 谷歌身份驗證器,前些年大家都比較陌生,但隨著國內互聯網安全的加強,它越來越多地出現在大家的視野中。 比較廣泛接觸的人群是國際3A游戲愛好者,游戲盜號現象嚴重+國外賬號安全應用廣泛,這類游戲一般都會要求用戶系結名為“兩步驗證”、“雙重驗證”等,平臺一般都推薦用谷歌身份驗證器。 后來區塊鏈業務風靡 ......

    uj5u.com 2020-09-10 03:03:17 more
  • 密碼學DAY1

    目錄 ##1.1 密碼學基本概念 密碼在我們的生活中有著重要的作用,那么密碼究竟來自何方,為何會產生呢? 密碼學是網路安全、資訊安全、區塊鏈等產品的基礎,常見的非對稱加密、對稱加密、散列函式等,都屬于密碼學范疇。 密碼學有數千年的歷史,從最開始的替換法到如今的非對稱加密演算法,經歷了古典密碼學,近代密 ......

    uj5u.com 2020-09-10 03:03:50 more
  • 密碼學DAY1_02

    目錄 ##1.1 ASCII編碼 ASCII(American Standard Code for Information Interchange,美國資訊交換標準代碼)是基于拉丁字母的一套電腦編碼系統,主要用于顯示現代英語和其他西歐語言。它是現今最通用的單位元組編碼系統,并等同于國際標準ISO/IE ......

    uj5u.com 2020-09-10 03:04:50 more
  • 密碼學DAY2

    ##1.1 加密模式 加密模式:https://docs.oracle.com/javase/8/docs/api/javax/crypto/Cipher.html ECB ECB : Electronic codebook, 電子密碼本. 需要加密的訊息按照塊密碼的塊大小被分為數個塊,并對每個塊進 ......

    uj5u.com 2020-09-10 03:05:42 more
  • NTP時鐘服務器的特點(京準電子)

    NTP時鐘服務器的特點(京準電子) NTP時鐘服務器的特點(京準電子) 京準電子官V——ahjzsz 首先對時間同步進行了背景介紹,然后討論了不同的時間同步網路技術,最后指出了建立全球或區域時間同步網存在的問題。 一、概 述 在通信領域,“同步”概念是指頻率的同步,即網路各個節點的時鐘頻率和相位同步 ......

    uj5u.com 2020-09-10 03:05:47 more
  • 標準化考場時鐘同步系統推進智能化校園建設

    標準化考場時鐘同步系統推進智能化校園建設 標準化考場時鐘同步系統推進智能化校園建設 安徽京準電子科技官微——ahjzsz 一、背景概述隨著教育事業的快速發展,學校建設如雨后春筍,隨之而來的學校教育、管理、安全方面的問題成了學校管理人員面臨的最大的挑戰,這些問題同時也是學生家長所擔心的。為了讓學生有更 ......

    uj5u.com 2020-09-10 03:05:51 more
  • 位元幣入門

    引言 位元幣基本結構 位元幣基礎知識 1)哈希演算法 2)非對稱加密技術 3)數字簽名 4)MerkleTree 5)哪有位元幣,有的是UTXO 6)位元幣挖礦與共識 7)區塊驗證(共識) 總結 引言 上一篇我們已經知道了什么是區塊鏈,此篇說一下區塊鏈的第一個應用——位元幣。其實先有位元幣,后有的區塊 ......

    uj5u.com 2020-09-10 03:06:15 more
  • 北斗對時服務器(北斗對時設備)電力系統應用

    北斗對時服務器(北斗對時設備)電力系統應用 北斗對時服務器(北斗對時設備)電力系統應用 京準電子科技官微(ahjzsz) 中國北斗衛星導航系統(英文名稱:BeiDou Navigation Satellite System,簡稱BDS),因為是目前世界范圍內唯一可以大面積提供免費定位服務的系統,所以 ......

    uj5u.com 2020-09-10 03:06:20 more
最新发布
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:46:47 more
  • Hyperledger Fabric 使用 CouchDB 和復雜智能合約開發

    在上個實驗中,我們已經實作了簡單智能合約實作及客戶端開發,但該實驗中智能合約只有基礎的增刪改查功能,且其中的資料管理功能與傳統 MySQL 比相差甚遠。本文將在前面實驗的基礎上,將 Hyperledger Fabric 的默認資料庫支持 LevelDB 改為 CouchDB 模式,以實作更復雜的資料... ......

    uj5u.com 2023-04-16 07:28:31 more
  • .NET Core 波場鏈離線簽名、廣播交易(發送 TRX和USDT)筆記

    Get Started NuGet You can run the following command to install the Tron.Wallet.Net in your project. PM> Install-Package Tron.Wallet.Net 配置 public reco ......

    uj5u.com 2023-04-14 08:08:00 more
  • DKP 黑客分析——不正確的代幣對比率計算

    概述: 2023 年 2 月 8 日,針對 DKP 協議的閃電貸攻擊導致該協議的用戶損失了 8 萬美元,因為 execute() 函式取決于 USDT-DKP 對中兩種代幣的余額比率。 智能合約黑客概述: 攻擊者的交易:0x0c850f,0x2d31 攻擊者地址:0xF38 利用合同:0xf34ad ......

    uj5u.com 2023-04-07 07:46:09 more
  • Defi開發簡介

    Defi開發簡介 介紹 Defi是去中心化金融的縮寫, 是一項旨在利用區塊鏈技術和智能合約創建更加開放,可訪問和透明的金融體系的運動. 這與傳統金融形成鮮明對比,傳統金融通常由少數大型銀行和金融機構控制 在Defi的世界里,用戶可以直接從他們的電腦或移動設備上訪問廣泛的金融服務,而不需要像銀行或者信 ......

    uj5u.com 2023-04-05 08:01:34 more
  • solidity簡單的ERC20代幣實作

    // SPDX-License-Identifier: GPL-3.0 pragma solidity >=0.7.0 <0.9.0; import "hardhat/console.sol"; //ERC20 同質化代幣,每個代幣的本質或性質都是相同 //ETH 是原生代幣,它不是ERC20代幣, ......

    uj5u.com 2023-03-21 07:56:29 more
  • solidity 參考型別修飾符memory、calldata與storage 常量修飾符C

    在solidity語言中 參考型別修飾符(參考型別為存盤空間不固定的數值型別) memory、calldata與storage,它們只能修飾參考型別變數,比如字串、陣列、位元組等... memory 適用于方法傳參、返參或在方法體內使用,使用完就會清除掉,釋放記憶體 calldata 僅適用于方法傳參 ......

    uj5u.com 2023-03-08 07:57:54 more
  • solidity注解標簽

    在solidity語言中 注釋符為// 注解符為/* 內容*/ 或者 是 ///內容 注解中含有這幾個標簽給予我們使用 @title 一個應該描述合約/介面的標題 contract, library, interface @author 作者的名字 contract, library, interf ......

    uj5u.com 2023-03-08 07:57:49 more
  • 評價指標:相似度、GAS消耗

    【代碼注釋自動生成方法綜述】 這些評測指標主要來自機器翻譯和文本總結等研究領域,可以評估候選文本(即基于代碼注釋自動方法而生成)和參考文本(即基于手工方式而生成)的相似度. BLEU指標^[^?88^^?^]^:其全稱是bilingual evaluation understudy.該指標是最早用于 ......

    uj5u.com 2023-02-23 07:27:39 more
  • 基于NOSTR協議的“公有制”版本的Twitter,去中心化社交軟體Damus

    最近,一個幽靈,Web3的幽靈,在網路游蕩,它叫Damus,這玩意詮釋了什么叫做病毒式營銷,滑稽的是,一個Web3產品卻在Web2的產品鏈上瘋狂傳銷,各方大佬紛紛為其背書,到底發生了什么?Damus的葫蘆里,賣的是什么藥? 注冊和簡單實用 很少有什么產品在用戶注冊環節會有什么噱頭,但Damus確實出 ......

    uj5u.com 2023-02-05 06:48:39 more