a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 專題 > 區(qū)塊鏈 > 正文

簡單易懂,區(qū)塊鏈入門指南

2020-02-25 19:29:31
字體:
來源:轉載
供稿:網友

  區(qū)塊鏈(Blockchain)是比特幣的一個重要概念,區(qū)塊鏈是一串使用密碼學方法相關聯產生的數據塊,每一個數據塊中包含了一次比特幣網絡交易的信息,用于驗證其信息的有效性(防偽)和生成下一個區(qū)塊。眼下新聞媒體大量的爭相報道關于區(qū)塊鏈的信息,但真的能讓人簡單易懂的讓人了解區(qū)塊鏈的文章少之又少,那區(qū)塊鏈到底是什么,有何特別之處呢?

  下面,我就來嘗試,寫一篇最好懂的區(qū)塊鏈教程。畢竟它也不是很難的東西,核心概念非常簡單,幾句話就能說清楚。我希望讀完本文,你不僅可以理解區(qū)塊鏈,還會明白什么是挖礦、為什么挖礦越來越難等問題。

  需要說明的是,我并非這方面的專家。雖然很早就關注,但是仔細地了解區(qū)塊鏈,還是從今年初開始。文中的錯誤和不準確的地方,歡迎大家指正。

  一、區(qū)塊鏈的本質

  區(qū)塊鏈是什么?一句話,它是一種特殊的分布式數據庫。

  首先,區(qū)塊鏈的主要作用是儲存信息。任何需要保存的信息,都可以寫入區(qū)塊鏈,也可以從里面讀取,所以它是數據庫。

  其次,任何人都可以架設服務器,加入區(qū)塊鏈網絡,成為一個節(jié)點。區(qū)塊鏈的世界里面,沒有中心節(jié)點,每個節(jié)點都是平等的,都保存著整個數據庫。你可以向任何一個節(jié)點,寫入/讀取數據,因為所有節(jié)點最后都會同步,保證區(qū)塊鏈一致。

  二、區(qū)塊鏈的最大特點

  分布式數據庫并非新發(fā)明,市場上早有此類產品。但是,區(qū)塊鏈有一個革命性特點。

  區(qū)塊鏈沒有管理員,它是徹底無中心的。其他的數據庫都有管理員,但是區(qū)塊鏈沒有。如果有人想對區(qū)塊鏈添加審核,也實現不了,因為它的設計目標就是防止出現居于中心地位的管理當局。

  正是因為無法管理,區(qū)塊鏈才能做到無法被控制。否則一旦大公司大集團控制了管理權,他們就會控制整個平臺,其他使用者就都必須聽命于他們了。

  但是,沒有了管理員,人人都可以往里面寫入數據,怎么才能保證數據是可信的呢?被壞人改了怎么辦?請接著往下讀,這就是區(qū)塊鏈奇妙的地方。

  三、區(qū)塊

  區(qū)塊鏈由一個個區(qū)塊(block)組成。區(qū)塊很像數據庫的記錄,每次寫入數據,就是創(chuàng)建一個區(qū)塊。

  每個區(qū)塊包含兩個部分。

  區(qū)塊頭(Head):記錄當前區(qū)塊的元信息

  區(qū)塊體(Body):實際數據

  區(qū)塊頭包含了當前區(qū)塊的多項元信息。

  生成時間

  實際數據(即區(qū)塊體)的 Hash

  上一個區(qū)塊的 Hash

  ...

  這里,你需要理解什么叫Hash,這是理解區(qū)塊鏈必需的。

  所謂 Hash 就是計算機可以對任意內容,計算出一個長度相同的特征值。區(qū)塊鏈的 Hash 長度是256位,這就是說,不管原始內容是什么,最后都會計算出一個256位的二進制數字。而且可以保證,只要原始內容不同,對應的 Hash 一定是不同的。

  舉例來說,字符串123的 Hash 是a8fdc205a9f19cc1c7507a60c4f01b13d11d7fd0(十六進制),轉成二進制就是256位,而且只有123能得到這個 Hash。

  因此,就有兩個重要的推論。

  推論1:每個區(qū)塊的 Hash 都是不一樣的,可以通過 Hash 標識區(qū)塊。

  推論2:如果區(qū)塊的內容變了,它的 Hash 一定會改變。

  四、 Hash 的不可修改性

  區(qū)塊與 Hash 是一一對應的,每個區(qū)塊的 Hash 都是針對"區(qū)塊頭"(Head)計算的。

  Hash = SHA256(區(qū)塊頭)

  上面就是區(qū)塊 Hash 的計算公式,Hash 由區(qū)塊頭唯一決定,SHA256是區(qū)塊鏈的 Hash 算法。

  前面說過,區(qū)塊頭包含很多內容,其中有當前區(qū)塊體的 Hash(注意是"區(qū)塊體"的 Hash,而不是整個區(qū)塊),還有上一個區(qū)塊的 Hash。這意味著,如果當前區(qū)塊的內容變了,或者上一個區(qū)塊的 Hash 變了,一定會引起當前區(qū)塊的 Hash 改變。

  這一點對區(qū)塊鏈有重大意義。如果有人修改了一個區(qū)塊,該區(qū)塊的 Hash 就變了。為了讓后面的區(qū)塊還能連到它,該人必須同時修改后面所有的區(qū)塊,否則被改掉的區(qū)塊就脫離區(qū)塊鏈了。由于后面要提到的原因,Hash 的計算很耗時,同時修改多個區(qū)塊幾乎不可能發(fā)生,除非有人掌握了全網51%以上的計算能力。

  正是通過這種聯動機制,區(qū)塊鏈保證了自身的可靠性,數據一旦寫入,就無法被篡改。這就像歷史一樣,發(fā)生了就是發(fā)生了,從此再無法改變。

  每個區(qū)塊都連著上一個區(qū)塊,這也是"區(qū)塊鏈"這個名字的由來。

  五、采礦

  由于必須保證節(jié)點之間的同步,所以新區(qū)塊的添加速度不能太快。試想一下,你剛剛同步了一個區(qū)塊,準備基于它生成下一個區(qū)塊,但這時別的節(jié)點又有新區(qū)塊生成,你不得不放棄做了一半的計算,再次去同步。因為每個區(qū)塊的后面,只能跟著一個區(qū)塊,你永遠只能在最新區(qū)塊的后面,生成下一個區(qū)塊。所以,你別無選擇,一聽到信號,就必須立刻同步。

  所以,區(qū)塊鏈的發(fā)明者中本聰(這是假名,真實身份至今未知)故意讓添加新區(qū)塊,變得很困難。他的設計是,平均每10分鐘,全網才能生成一個新區(qū)塊,一小時也就六個。

  這種產出速度不是通過命令達成的,而是故意設置了海量的計算。也就是說,只有通過極其大量的計算,才能得到當前區(qū)塊的有效 Hash,從而把新區(qū)塊添加到區(qū)塊鏈。由于計算量太大,所以快不起來。

  這個過程就叫做采礦(mining),因為計算有效 Hash 的難度,好比在全世界的沙子里面,找到一粒符合條件的沙子。計算 Hash 的機器就叫做礦機,操作礦機的人就叫做礦工。

  六、難度系數

  讀到這里,你可能會有一個疑問,人們都說采礦很難,可是采礦不就是用計算機算出一個 Hash 嗎,這正是計算機的強項啊,怎么會變得很難,遲遲算不出來呢?

  原來不是任意一個 Hash 都可以,只有滿足條件的 Hash 才會被區(qū)塊鏈接受。這個條件特別苛刻,使得絕大部分 Hash 都不滿足要求,必須重算。

  原來,區(qū)塊頭包含一個難度系數(difficulty),這個值決定了計算 Hash 的難度。舉例來說,第100000個區(qū)塊的難度系數是 14484.16236122。

  區(qū)塊鏈協議規(guī)定,使用一個常量除以難度系數,可以得到目標值(target)。顯然,難度系數越大,目標值就越小。

  Hash 的有效性跟目標值密切相關,只有小于目標值的 Hash 才是有效的,否則 Hash 無效,必須重算。由于目標值非常小,Hash 小于該值的機會極其渺茫,可能計算10億次,才算中一次。這就是采礦如此之慢的根本原因。

  區(qū)塊頭里面還有一個 Nonce 值,記錄了 Hash 重算的次數。第 100000 個區(qū)塊的 Nonce 值是274148111,即計算了 2.74 億次,才得到了一個有效的 Hash,該區(qū)塊才能加入區(qū)塊鏈。

  七、難度系數的動態(tài)調節(jié)

  就算采礦很難,但也沒法保證,正好十分鐘產出一個區(qū)塊,有時一分鐘就算出來了,有時幾個小時可能也沒結果。總體來看,隨著硬件設備的提升,以及礦機的數量增長,計算速度一定會越來越快。

  為了將產出速率恒定在十分鐘,中本聰還設計了難度系數的動態(tài)調節(jié)機制。他規(guī)定,難度系數每兩周(2016個區(qū)塊)調整一次。如果這兩周里面,區(qū)塊的平均生成速度是9分鐘,就意味著比法定速度快了10%,因此難度系數就要調高10%;如果平均生成速度是11分鐘,就意味著比法定速度慢了10%,因此難度系數就要調低10%。

  難度系數越調越高(目標值越來越小),導致了采礦越來越難。

  八、區(qū)塊鏈的分叉

  即使區(qū)塊鏈是可靠的,現在還有一個問題沒有解決:如果兩個人同時向區(qū)塊鏈寫入數據,也就是說,同時有兩個區(qū)塊加入,因為它們都連著前一個區(qū)塊,就形成了分叉。這時應該采納哪一個區(qū)塊呢?

  現在的規(guī)則是,新節(jié)點總是采用最長的那條區(qū)塊鏈。如果區(qū)塊鏈有分叉,將看哪個分支在分叉點后面,先達到6個新區(qū)塊(稱為"六次確認")。按照10分鐘一個區(qū)塊計算,一小時就可以確認。

  由于新區(qū)塊的生成速度由計算能力決定,所以這條規(guī)則就是說,擁有大多數計算能力的那條分支,就是正宗的比特鏈。

  九、總結

  區(qū)塊鏈作為無人管理的分布式數據庫,從2009年開始已經運行了8年,沒有出現大的問題。這證明它是可行的。

  但是,為了保證數據的可靠性,區(qū)塊鏈也有自己的代價。一是效率,數據寫入區(qū)塊鏈,最少要等待十分鐘,所有節(jié)點都同步數據,則需要更多的時間;二是能耗,區(qū)塊的生成需要礦工進行無數無意義的計算,這是非常耗費能源的。

  因此,區(qū)塊鏈的適用場景,其實非常有限。

  不存在所有成員都信任的管理當局

  寫入的數據不要求實時使用

  挖礦的收益能夠彌補本身的成本

  如果無法滿足上述的條件,那么傳統(tǒng)的數據庫是更好的解決方案。

  目前,區(qū)塊鏈最大的應用場景(可能也是唯一的應用場景),就是以比特幣為代表的加密貨幣。

  以上就是簡單易懂,區(qū)塊鏈入門指南的全部內容,更多內容請繼續(xù)關注武林技術頻道網站!

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 色综合久久久久 | 日韩一区二区三区在线视频 | 亚洲一区二区三 | 亚洲精品一区二区在线观看 | 天天摸天天操 | 亚洲精品国产精品乱码不99按摩 | 欧美多人在线 | 国产成人精品不卡 | 精品国产一区二区三区久久久久久 | 香蕉av777xxx色综合一区 | 日韩欧美在线看 | 一区二区中文字幕在线观看 | 日本黄色免费观看 | 中文字幕第一页在线 | 青草青草 | 五月婷在线观看 | 欧美性区| 亚洲综合国产激情另类一区 | 四虎影音 | 97久久久 | 国产成人久久 | 日韩亚洲精品视频 | 久久国际影院 | 欧美一及黄色片 | 色久视频 | 亚洲精品乱码久久久久久不卡 | 免费看国产一级特黄aaaa大片 | 最新超碰 | 精品久久久久久久久久久久久久 | 天天干天天谢 | 在线看一区二区 | 蜜桃av中文字幕 | 国产精品久久久久久久久久久久冷 | 日本在线小视频 | 亚洲视频在线一区二区三区 | 国产午夜手机精彩视频 | 蜜桃一区二区三区 | 欧美人牲 | 久久久久久久av | 欧美二三区 | 91精品国产综合久久婷婷香蕉 |