学习笔记:区块链概念入门
本文是100天區(qū)塊鏈學(xué)習(xí)計(jì)劃的第二篇學(xué)習(xí)筆記,其實(shí)就是按照阮一峰的網(wǎng)絡(luò)日志-區(qū)塊鏈入門教程的講解進(jìn)行的簡單梳理。也是時(shí)間有點(diǎn)緊張的原因,相比于上一篇SHA256算法原理詳解,個(gè)人感覺質(zhì)量和原創(chuàng)程度明顯下降。待對區(qū)塊鏈有了更深的理解后,我會回來完善,并加入更多自己的理解的。
區(qū)塊鏈的本質(zhì)
區(qū)塊鏈?zhǔn)鞘裁?#xff1f;一句話,它是一種特殊的分布式數(shù)據(jù)庫。
首先,區(qū)塊鏈的主要作用是存儲信息。任何需要保存的信息,都可以寫入?yún)^(qū)塊鏈,也可以從里面讀取,所以它是數(shù)據(jù)庫。
其次,任何人都可以架設(shè)服務(wù)器,加入?yún)^(qū)塊鏈網(wǎng)絡(luò),成為一個(gè)節(jié)點(diǎn)。區(qū)塊鏈的世界里面,沒有中心節(jié)點(diǎn),每個(gè)結(jié)點(diǎn)都是平等的,都保存著整個(gè)數(shù)據(jù)庫。你可以向任何一個(gè)節(jié)點(diǎn),寫入/讀取數(shù)據(jù),因?yàn)樗泄?jié)點(diǎn)最后都會同步,保證區(qū)塊鏈一致。
區(qū)塊鏈的誕生是為了滿足什么需求?還是解決什么問題?
溯源區(qū)塊鏈,我們發(fā)現(xiàn)區(qū)塊鏈誕生于比特幣,是從比特幣的技術(shù)中衍生出的。
在2008年全球金融危機(jī)中,美國政府因?yàn)橛杏涃~權(quán),所以可以無限增發(fā)貨幣,一位自稱中本聰?shù)娜擞X得這樣很不靠譜,于是他想創(chuàng)建一種新型支付體系,大家都有權(quán)記賬,貨幣不能超發(fā),整個(gè)賬本完全公開透明十分公平。
2008年11月1日中本聰在網(wǎng)絡(luò)上發(fā)表了一篇《比特幣——一種點(diǎn)對點(diǎn)的電子現(xiàn)金系統(tǒng)》的論文,文中描述了一個(gè)全新的電子現(xiàn)金系統(tǒng) 比特幣。比特幣是一種去中心化的電子現(xiàn)金系統(tǒng),它解決了在沒有中心機(jī)構(gòu)的情況下,總量恒定的數(shù)字資產(chǎn)的發(fā)行和流通問題,通過比特幣系統(tǒng)轉(zhuǎn)賬,信息公開透明,可以放心的把比特幣轉(zhuǎn)給另一個(gè)人,每一筆轉(zhuǎn)賬信息都會被全網(wǎng)記錄。白皮書的問世,標(biāo)志著比特幣的底層技術(shù)區(qū)塊鏈的誕生。(這里要著重區(qū)分一下Bitcoin和bitcoin,大寫的B是代表點(diǎn)對點(diǎn)的電子現(xiàn)金系統(tǒng),小寫的b是指比特幣。)
注意:區(qū)塊鏈?zhǔn)潜忍貛诺靡詫?shí)現(xiàn)的技術(shù),比特幣是區(qū)塊鏈技術(shù)的第一個(gè)應(yīng)用。
比特幣的存在是為了避免中心機(jī)構(gòu)作惡超發(fā)貨幣,解決去中心化網(wǎng)絡(luò)和價(jià)值傳遞兩個(gè)問題。而區(qū)塊鏈就是解決這兩個(gè)問題的核心技術(shù),使得電子現(xiàn)金可以點(diǎn)對點(diǎn)的直接從一方支付給另一方,中間不經(jīng)過任何金融機(jī)構(gòu)。
區(qū)塊鏈的最大特點(diǎn)
分布式數(shù)據(jù)庫并非新發(fā)明,市場上早有此類產(chǎn)品。但是,區(qū)塊鏈有一個(gè)革命性特點(diǎn)。
區(qū)塊鏈沒有管理員,它是徹底無中心的。其他的數(shù)據(jù)庫都有管理員,但是區(qū)塊鏈沒有。如果有人想對區(qū)塊鏈添加審核,也實(shí)現(xiàn)不了,因?yàn)樗脑O(shè)計(jì)目標(biāo)就是防止出現(xiàn)居于中心地位的管理當(dāng)局。
正是因?yàn)闊o法管理,區(qū)塊鏈才能做到無法被控制。否則一旦大公司大集團(tuán)控制了管理權(quán),他們就會控制整個(gè)平臺,其他使用者就都必須聽命于他們了。
但是,沒有了管理員,人人都可以往里面寫入數(shù)據(jù),怎么才能保證數(shù)據(jù)是可信的呢?被壞人改了怎么辦?
區(qū)塊
區(qū)塊鏈由一個(gè)個(gè)區(qū)塊(Block)組成。
每個(gè)區(qū)塊包含兩個(gè)部分。
- 區(qū)塊頭(Head):記錄當(dāng)前區(qū)塊的特征值
- 區(qū)塊體(Body):實(shí)際數(shù)據(jù)
區(qū)塊頭包含了當(dāng)前區(qū)塊的多項(xiàng)特征值。
- Height 525216 (Main chain)
- Hash 00000000000000000016897fbee5d409cf831236d12f760f8453b0cb9e5150b9
- Previous Block 000000000000000000280a08df7f13f48bb30c1470216b81c98c2396c3c9aaca
- Next Blocks 0000000000000000003a29065af4314d8ea2299c091c61bf3045f9f7da24d85e
- Time 2018-05-31 02:49:19
- Difficulty 4,306,949,573,981.51
- Bits 390158921
- Version 0x20000000
- Merkle Root d76de1a9c0f4b583c51815b08377d788286e2213ba71ab24114d635dbf7207ac
- Nonce 2427928693
- Block Reward 12.5 BTC
- …
所謂“哈希”就是計(jì)算機(jī)可以對任意內(nèi)容,計(jì)算出一個(gè)長度相同的特征值。區(qū)塊鏈的哈希長度是256位,這就是說,不管原始內(nèi)容是什么,最后都會計(jì)算出一個(gè)256位的二進(jìn)制數(shù)字。而且可以保證,只要原始內(nèi)容不同,對應(yīng)的哈希一定是不同的。
因此,就有兩個(gè)重要的推論。
- 推論1:每個(gè)區(qū)塊的哈希都是不一樣的,可以通過哈希標(biāo)識區(qū)塊。
- 推論2:如果區(qū)塊的內(nèi)容變了,它的哈希一定會改變。
Hash的不可修改性
區(qū)塊與哈希是一一對應(yīng)的,每個(gè)區(qū)塊的哈希都是針對“區(qū)塊頭”計(jì)算的。也就是說,把區(qū)塊頭的各項(xiàng)特征值,按照順序連接在一起,組成一個(gè)很長的字符串,再對這個(gè)字符串計(jì)算哈希。
Hash = SHA256 ( 區(qū)塊頭 )
上面就是區(qū)塊哈希的計(jì)算公式,AHA256 是區(qū)塊鏈的哈希算法。注意,這個(gè)公式里面只包含區(qū)塊頭,不包含區(qū)塊體,也就是說,哈希由區(qū)塊頭唯一決定。
前面說過,區(qū)塊頭包含很多內(nèi)容,其中有當(dāng)前區(qū)塊體的哈希,還有上一個(gè)區(qū)塊的哈希。這意味著,如果當(dāng)前區(qū)塊體的內(nèi)容變了,或者上一個(gè)區(qū)塊的哈希變了,一定會引起當(dāng)前區(qū)塊的哈希改變。
這一點(diǎn)對區(qū)塊鏈有重大意義。如果有人修改了一個(gè)區(qū)塊,該區(qū)塊的哈希就變了。為了讓后面的區(qū)塊能連接到它(因?yàn)橄乱粋€(gè)區(qū)塊包含上一個(gè)區(qū)塊的哈希),該人必須依次修改后面所有的區(qū)塊,否則被改掉的區(qū)塊就脫離區(qū)塊鏈了。由于后面要提到的原因,哈希的計(jì)算很耗時(shí),短時(shí)間內(nèi)修改多個(gè)區(qū)塊幾乎不可能發(fā)生,除非有人掌握了全網(wǎng)51%以上的計(jì)算能力。
正是通過這種聯(lián)動機(jī)制,區(qū)塊鏈保證了自身的可靠性,數(shù)據(jù)一旦寫入,就無法被篡改。這就像歷史一樣,發(fā)生了就是發(fā)生了,從此再無法改變。
每個(gè)區(qū)塊都連著上一個(gè)區(qū)塊,這也是“區(qū)塊鏈”這個(gè)名字的由來。
采礦
由于必須保證節(jié)點(diǎn)之間的同步,所以新區(qū)快的添加速度不能太快。試想一下,你剛剛同步了一個(gè)區(qū)塊,準(zhǔn)備基于它生成下一個(gè)區(qū)塊,但這時(shí)別的節(jié)點(diǎn)又有新區(qū)塊生成,你不得不放棄做了一半的計(jì)算,再次去同步。因?yàn)槊總€(gè)區(qū)塊后面,只能跟著一個(gè)區(qū)塊,你永遠(yuǎn)只能在最新區(qū)塊的后面,生成下一個(gè)區(qū)塊。所以,你別無選擇,一聽到信號,就必須立刻同步。
所以,區(qū)塊鏈的發(fā)明者 中本聰 故意讓添加新區(qū)塊,變得很困難。他的設(shè)計(jì)是,平均每10分鐘,全網(wǎng)才能生成一個(gè)新區(qū)塊,一小時(shí)也就六個(gè)。
這種產(chǎn)出速度不是通過命令達(dá)成的,而是故意設(shè)置了海量的計(jì)算。也就是說,只有通過及其大量的計(jì)算,才能得到當(dāng)前區(qū)塊的有效哈希,從而把新區(qū)塊添加到區(qū)塊鏈。由于計(jì)算量太大,所以快不起來。
這個(gè)過程就叫采礦(mining),因?yàn)橛?jì)算有效哈希的難度,好比在全世界的沙子里面,找到一粒符合條件的沙子。計(jì)算哈希的機(jī)器叫做礦機(jī),操作礦機(jī)的人就叫礦工。
難度系數(shù)
不是任何一個(gè)哈希都可以,只有滿足條件的哈希才會被區(qū)塊鏈接受。這個(gè)條件特別苛刻,使得絕大部分哈希都不滿足要求,必須重算。
原來,區(qū)塊頭包含一個(gè)難度系數(shù)(difficulty),這個(gè)值決定了計(jì)算哈希的難度。區(qū)塊鏈協(xié)議規(guī)定,使用一個(gè)常量除以難度系數(shù),可以得到目標(biāo)值(target)。顯然,難度系數(shù)越大,目標(biāo)值就越小。
target = targetmax / difficulty哈希的有效性跟目標(biāo)值密切相關(guān),只有小于目標(biāo)值的哈希才是有效的,否則哈希無效,必須重算。由于目標(biāo)值非常小,哈希小于該值的機(jī)會極其渺茫,這就是采礦如此之慢的根本原因。
前面說過,當(dāng)前區(qū)塊的哈希由區(qū)塊頭唯一決定。如果要對同一個(gè)區(qū)塊反復(fù)計(jì)算哈希,就意味著,區(qū)塊頭必須不停地變化,否則不可能算出不一樣的哈希。區(qū)塊頭里面所有的特征值都是固定的,為了讓區(qū)塊頭產(chǎn)生變化,中本聰故意增加了一個(gè)隨機(jī)項(xiàng),叫做Nonce。
Nonce是一個(gè)隨機(jī)值,礦工的作用其實(shí)就是猜出 Nonce 的值,使得區(qū)塊頭的哈希可以小于目標(biāo)值,從而能夠?qū)懭雲(yún)^(qū)塊鏈。Nonce 是非常難猜的,目前只能通過窮舉法一個(gè)個(gè)試錯(cuò)。根據(jù)協(xié)議,Nonce 是一個(gè)32位的二進(jìn)制值,即最大可以到21.47億。第100000個(gè)區(qū)塊的 Nonce 值是 274148111,可以理解成,礦工從0開始,一直計(jì)算了2.74億次,才得到一個(gè)有效的 Nonce 值,使得算出的哈希能夠滿足條件。
運(yùn)氣好的話,也許一會就找到了 Nonce。運(yùn)氣不好的話,可能算完了21.47億次,都沒有發(fā)現(xiàn) Nonce,即當(dāng)前區(qū)塊體不可能算出滿足條件的哈希。這時(shí),協(xié)議允許礦工改變區(qū)塊體,開始新的計(jì)算。
難度系數(shù)的動態(tài)調(diào)節(jié)
采礦具有隨機(jī)性,沒法保證正好十分鐘產(chǎn)出一個(gè)區(qū)塊,有時(shí)一分鐘就算出來了,有時(shí)幾個(gè)小時(shí)可能也沒結(jié)果。總體來看,隨著硬件設(shè)備的提升,以及礦機(jī)的數(shù)量增長,計(jì)算速度一定會越來越快。
為了將產(chǎn)出速率恒定在十分鐘,中本聰還設(shè)計(jì)了難度系數(shù)的動態(tài)調(diào)節(jié)機(jī)制。他規(guī)定,難度系數(shù)每兩周(2016個(gè)區(qū)塊)調(diào)整一次。如果這兩周里面,區(qū)塊的平均生成速度是9分鐘,就意味著比法定速度快了10%,因此接下來的難度系數(shù)就要調(diào)高10%;如果平均生成速度是11分鐘,就意味著比法定速度慢了10%,因此接下來的難度系數(shù)就要調(diào)低10%。
難度系數(shù)越調(diào)越高(目標(biāo)值越來越小),導(dǎo)致了采礦越來越難。
區(qū)塊鏈的分叉
即使區(qū)塊鏈?zhǔn)强煽康?#xff0c;現(xiàn)在還有一個(gè)問題沒有解決:如果兩個(gè)人同時(shí)向區(qū)塊鏈寫入數(shù)據(jù),也就是說,同時(shí)有兩個(gè)區(qū)塊加入,因?yàn)樗鼈兌歼B著前一個(gè)區(qū)塊,就形成了分叉。這時(shí)應(yīng)該采納哪一個(gè)區(qū)塊呢?
現(xiàn)在的規(guī)則是,新節(jié)點(diǎn)總是采用最長的那條區(qū)塊鏈。如果區(qū)塊鏈有分叉,將看哪個(gè)分支在分叉后面,先達(dá)到6個(gè)新區(qū)塊(稱為“六次確認(rèn)”)。按照10分鐘一個(gè)區(qū)塊計(jì)算,一小時(shí)就可以確認(rèn)。
由于新區(qū)塊的生成速度由計(jì)算能力決定,所以這條規(guī)則就是說,擁有大多數(shù)計(jì)算能力的那條分支,就是正宗的區(qū)塊鏈。
總結(jié)
區(qū)塊鏈作為無人管理的分布式數(shù)據(jù)庫,從2009年開始已經(jīng)運(yùn)行了8年,沒有出現(xiàn)大的問題。這證明它是可行的。
但是,為了保證數(shù)據(jù)的可靠性,區(qū)塊鏈也有自己的代價(jià)。
- 一是效率,數(shù)據(jù)寫入?yún)^(qū)塊鏈,最少要等待十分鐘,所有節(jié)點(diǎn)都同步數(shù)據(jù),則需要更多的時(shí)間;
- 二是能耗,區(qū)塊的生成需要礦工進(jìn)行無數(shù)無意義的計(jì)算,這是非常耗費(fèi)能源的。
因此,區(qū)塊鏈的適用場景,其實(shí)非常有限。
1. 不存在所有成員都信任的管理當(dāng)局。
2. 寫入的數(shù)據(jù)不要求實(shí)時(shí)使用。
3. 挖礦的收益能夠彌補(bǔ)本身的成本。
如果無法滿足上述的條件,那么傳統(tǒng)的數(shù)據(jù)庫是更好的解決方案。
目前,區(qū)塊鏈最大的應(yīng)用場景(可能也是唯一的應(yīng)用場景),就是以比特幣為代表的加密貨幣。
參考連接
https://blockchain.info/
http://www.ruanyifeng.com/blog/2017/12/blockchain-tutorial.html
總結(jié)
以上是生活随笔為你收集整理的学习笔记:区块链概念入门的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: wdnas群晖nas_西数WD NAS红
- 下一篇: 改进初学者的PID-积分饱和