區(qū)塊鏈入門教程

區(qū)塊鏈(blockchain)是眼下的大熱門乏苦,新聞媒體大量報(bào)道株扛,宣稱它將創(chuàng)造未來(lái)。

可是汇荐,簡(jiǎn)單易懂的入門文章卻很少洞就。區(qū)塊鏈到底是什么,有何特別之處掀淘,很少有解釋旬蟋。

下面,我就來(lái)嘗試革娄,寫一篇最好懂的區(qū)塊鏈教程倾贰。畢竟它也不是很難的東西,核心概念非常簡(jiǎn)單拦惋,幾句話就能說(shuō)清楚匆浙。我希望讀完本文,你不僅可以理解區(qū)塊鏈厕妖,還會(huì)明白什么是挖礦首尼、為什么挖礦越來(lái)越難等問(wèn)題。

需要說(shuō)明的是叹放,我并非這方面的專家饰恕。雖然很早就關(guān)注,但是仔細(xì)地了解區(qū)塊鏈井仰,還是從今年初開始埋嵌。文中的錯(cuò)誤和不準(zhǔn)確的地方,歡迎大家指正俱恶。

一雹嗦、區(qū)塊鏈的本質(zhì)

區(qū)塊鏈?zhǔn)鞘裁捶兑ǎ恳痪湓挘且环N特殊的分布式數(shù)據(jù)庫(kù)了罪。

首先锭环,區(qū)塊鏈的主要作用是儲(chǔ)存信息。任何需要保存的信息泊藕,都可以寫入?yún)^(qū)塊鏈辅辩,也可以從里面讀取,所以它是數(shù)據(jù)庫(kù)娃圆。

其次玫锋,任何人都可以架設(shè)服務(wù)器,加入?yún)^(qū)塊鏈網(wǎng)絡(luò)讼呢,成為一個(gè)節(jié)點(diǎn)撩鹿。區(qū)塊鏈的世界里面,沒有中心節(jié)點(diǎn)悦屏,每個(gè)節(jié)點(diǎn)都是平等的节沦,都保存著整個(gè)數(shù)據(jù)庫(kù)。你可以向任何一個(gè)節(jié)點(diǎn)础爬,寫入/讀取數(shù)據(jù)甫贯,因?yàn)樗泄?jié)點(diǎn)最后都會(huì)同步,保證區(qū)塊鏈一致看蚜。

二获搏、區(qū)塊鏈的最大特點(diǎn)

分布式數(shù)據(jù)庫(kù)并非新發(fā)明,市場(chǎng)上早有此類產(chǎn)品失乾。但是常熙,區(qū)塊鏈有一個(gè)革命性特點(diǎn)。

區(qū)塊鏈沒有管理員碱茁,它是徹底無(wú)中心的裸卫。其他的數(shù)據(jù)庫(kù)都有管理員,但是區(qū)塊鏈沒有纽竣。如果有人想對(duì)區(qū)塊鏈添加審核墓贿,也實(shí)現(xiàn)不了,因?yàn)樗脑O(shè)計(jì)目標(biāo)就是防止出現(xiàn)居于中心地位的管理當(dāng)局蜓氨。

正是因?yàn)闊o(wú)法管理聋袋,區(qū)塊鏈才能做到無(wú)法被控制。否則一旦大公司大集團(tuán)控制了管理權(quán)穴吹,他們就會(huì)控制整個(gè)平臺(tái)幽勒,其他使用者就都必須聽命于他們了。

但是港令,沒有了管理員啥容,人人都可以往里面寫入數(shù)據(jù)锈颗,怎么才能保證數(shù)據(jù)是可信的呢?被壞人改了怎么辦咪惠?請(qǐng)接著往下讀击吱,這就是區(qū)塊鏈奇妙的地方。

三遥昧、區(qū)塊

區(qū)塊鏈由一個(gè)個(gè)區(qū)塊(block)組成覆醇。區(qū)塊很像數(shù)據(jù)庫(kù)的記錄,每次寫入數(shù)據(jù)炭臭,就是創(chuàng)建一個(gè)區(qū)塊叫乌。

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

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

區(qū)塊體(Body):實(shí)際數(shù)據(jù)

區(qū)塊頭包含了當(dāng)前區(qū)塊的多項(xiàng)元信息徽缚。

生成時(shí)間

實(shí)際數(shù)據(jù)(即區(qū)塊體)的 Hash

上一個(gè)區(qū)塊的 Hash

...

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

所謂 Hash 就是計(jì)算機(jī)可以對(duì)任意內(nèi)容,計(jì)算出一個(gè)長(zhǎng)度相同的特征值似芝。區(qū)塊鏈的 Hash 長(zhǎng)度是256位那婉,這就是說(shuō),不管原始內(nèi)容是什么党瓮,最后都會(huì)計(jì)算出一個(gè)256位的二進(jìn)制數(shù)字详炬。而且可以保證徙菠,只要原始內(nèi)容不同蜜葱,對(duì)應(yīng)的 Hash 一定是不同的论咏。

舉例來(lái)說(shuō)茬暇,字符串123的 Hash 是a8fdc205a9f19cc1c7507a60c4f01b13d11d7fd0(十六進(jìn)制)穷劈,轉(zhuǎn)成二進(jìn)制就是256位辛慰,而且只有123能得到這個(gè) Hash螺垢。

因此尖昏,就有兩個(gè)重要的推論瓷翻。

推論1:每個(gè)區(qū)塊的 Hash 都是不一樣的聚凹,可以通過(guò) Hash 標(biāo)識(shí)區(qū)塊。

推論2:如果區(qū)塊的內(nèi)容變了齐帚,它的 Hash 一定會(huì)改變妒牙。

四、 Hash 的不可修改性

區(qū)塊與 Hash 是一一對(duì)應(yīng)的对妄,每個(gè)區(qū)塊的 Hash 都是針對(duì)"區(qū)塊頭"(Head)計(jì)算的湘今。

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

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

前面說(shuō)過(guò)蔫饰,區(qū)塊頭包含很多內(nèi)容,其中有當(dāng)前區(qū)塊體的 Hash(注意是"區(qū)塊體"的 Hash愉豺,而不是整個(gè)區(qū)塊)篓吁,還有上一個(gè)區(qū)塊的 Hash。這意味著蚪拦,如果當(dāng)前區(qū)塊的內(nèi)容變了杖剪,或者上一個(gè)區(qū)塊的 Hash 變了,一定會(huì)引起當(dāng)前區(qū)塊的 Hash 改變驰贷。

這一點(diǎn)對(duì)區(qū)塊鏈有重大意義盛嘿。如果有人修改了一個(gè)區(qū)塊,該區(qū)塊的 Hash 就變了括袒。為了讓后面的區(qū)塊還能連到它次兆,該人必須同時(shí)修改后面所有的區(qū)塊,否則被改掉的區(qū)塊就脫離區(qū)塊鏈了锹锰。由于后面要提到的原因芥炭,Hash 的計(jì)算很耗時(shí),同時(shí)修改多個(gè)區(qū)塊幾乎不可能發(fā)生恃慧,除非有人掌握了全網(wǎng)51%以上的計(jì)算能力园蝠。

正是通過(guò)這種聯(lián)動(dòng)機(jī)制,區(qū)塊鏈保證了自身的可靠性痢士,數(shù)據(jù)一旦寫入彪薛,就無(wú)法被篡改。這就像歷史一樣怠蹂,發(fā)生了就是發(fā)生了善延,從此再無(wú)法改變。

每個(gè)區(qū)塊都連著上一個(gè)區(qū)塊城侧,這也是"區(qū)塊鏈"這個(gè)名字的由來(lái)挚冤。

五、采礦

由于必須保證節(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ū)塊棋枕。所以,你別無(wú)選擇妒峦,一聽到信號(hào)重斑,就必須立刻同步。

所以肯骇,區(qū)塊鏈的發(fā)明者中本聰(這是假名窥浪,真實(shí)身份至今未知)故意讓添加新區(qū)塊,變得很困難笛丙。他的設(shè)計(jì)是漾脂,平均每10分鐘,全網(wǎng)才能生成一個(gè)新區(qū)塊胚鸯,一小時(shí)也就六個(gè)骨稿。

這種產(chǎn)出速度不是通過(guò)命令達(dá)成的,而是故意設(shè)置了海量的計(jì)算姜钳。也就是說(shuō)坦冠,只有通過(guò)極其大量的計(jì)算,才能得到當(dāng)前區(qū)塊的有效 Hash傲须,從而把新區(qū)塊添加到區(qū)塊鏈。由于計(jì)算量太大趟脂,所以快不起來(lái)泰讽。

這個(gè)過(guò)程就叫做采礦(mining),因?yàn)橛?jì)算有效 Hash 的難度昔期,好比在全世界的沙子里面已卸,找到一粒符合條件的沙子。計(jì)算 Hash 的機(jī)器就叫做礦機(jī)硼一,操作礦機(jī)的人就叫做礦工累澡。

六、難度系數(shù)

讀到這里般贼,你可能會(huì)有一個(gè)疑問(wèn)愧哟,人們都說(shuō)采礦很難,可是采礦不就是用計(jì)算機(jī)算出一個(gè) Hash 嗎哼蛆,這正是計(jì)算機(jī)的強(qiáng)項(xiàng)啊蕊梧,怎么會(huì)變得很難,遲遲算不出來(lái)呢腮介?

原來(lái)不是任意一個(gè) Hash 都可以肥矢,只有滿足條件的 Hash 才會(huì)被區(qū)塊鏈接受。這個(gè)條件特別苛刻叠洗,使得絕大部分 Hash 都不滿足要求甘改,必須重算旅东。

原來(lái),區(qū)塊頭包含一個(gè)難度系數(shù)(difficulty)十艾,這個(gè)值決定了計(jì)算 Hash 的難度抵代。舉例來(lái)說(shuō),第100000個(gè)區(qū)塊的難度系數(shù)是 14484.16236122疟羹。

區(qū)塊鏈協(xié)議規(guī)定主守,使用一個(gè)常量除以難度系數(shù),可以得到目標(biāo)值(target)榄融。顯然参淫,難度系數(shù)越大,目標(biāo)值就越小愧杯。

Hash 的有效性跟目標(biāo)值密切相關(guān)涎才,只有小于目標(biāo)值的 Hash 才是有效的,否則 Hash 無(wú)效力九,必須重算耍铜。由于目標(biāo)值非常小,Hash 小于該值的機(jī)會(huì)極其渺茫跌前,可能計(jì)算10億次棕兼,才算中一次。這就是采礦如此之慢的根本原因抵乓。

區(qū)塊頭里面還有一個(gè) Nonce 值伴挚,記錄了 Hash 重算的次數(shù)。第 100000 個(gè)區(qū)塊的 Nonce 值是274148111灾炭,即計(jì)算了 2.74 億次茎芋,才得到了一個(gè)有效的 Hash,該區(qū)塊才能加入?yún)^(qū)塊鏈蜈出。

七田弥、難度系數(shù)的動(dòng)態(tài)調(diào)節(jié)

就算采礦很難,但也沒法保證铡原,正好十分鐘產(chǎn)出一個(gè)區(qū)塊偷厦,有時(shí)一分鐘就算出來(lái)了,有時(shí)幾個(gè)小時(shí)可能也沒結(jié)果燕刻』Σ福總體來(lái)看,隨著硬件設(shè)備的提升酌儒,以及礦機(jī)的數(shù)量增長(zhǎng)辜妓,計(jì)算速度一定會(huì)越來(lái)越快。

為了將產(chǎn)出速率恒定在十分鐘,中本聰還設(shè)計(jì)了難度系數(shù)的動(dòng)態(tài)調(diào)節(jié)機(jī)制籍滴。他規(guī)定酪夷,難度系數(shù)每?jī)芍埽?016個(gè)區(qū)塊)調(diào)整一次。如果這兩周里面孽惰,區(qū)塊的平均生成速度是9分鐘晚岭,就意味著比法定速度快了10%,因此難度系數(shù)就要調(diào)高10%勋功;如果平均生成速度是11分鐘坦报,就意味著比法定速度慢了10%,因此難度系數(shù)就要調(diào)低10%狂鞋。

難度系數(shù)越調(diào)越高(目標(biāo)值越來(lái)越衅瘛),導(dǎo)致了采礦越來(lái)越難骚揍。

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

即使區(qū)塊鏈?zhǔn)强煽康模F(xiàn)在還有一個(gè)問(wèn)題沒有解決:如果兩個(gè)人同時(shí)向區(qū)塊鏈寫入數(shù)據(jù)信不,也就是說(shuō)嘲叔,同時(shí)有兩個(gè)區(qū)塊加入,因?yàn)樗鼈兌歼B著前一個(gè)區(qū)塊抽活,就形成了分叉硫戈。這時(shí)應(yīng)該采納哪一個(gè)區(qū)塊呢?

現(xiàn)在的規(guī)則是下硕,新節(jié)點(diǎn)總是采用最長(zhǎng)的那條區(qū)塊鏈丁逝。如果區(qū)塊鏈有分叉,將看哪個(gè)分支在分叉點(diǎn)后面卵牍,先達(dá)到6個(gè)新區(qū)塊(稱為"六次確認(rèn)")果港。按照10分鐘一個(gè)區(qū)塊計(jì)算沦泌,一小時(shí)就可以確認(rèn)糊昙。

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

九回挽、總結(jié)

區(qū)塊鏈作為無(wú)人管理的分布式數(shù)據(jù)庫(kù)没咙,從2009年開始已經(jīng)運(yùn)行了8年,沒有出現(xiàn)大的問(wèn)題千劈。這證明它是可行的祭刚。

但是,為了保證數(shù)據(jù)的可靠性,區(qū)塊鏈也有自己的代價(jià)涡驮。一是效率暗甥,數(shù)據(jù)寫入?yún)^(qū)塊鏈,最少要等待十分鐘捉捅,所有節(jié)點(diǎn)都同步數(shù)據(jù)撤防,則需要更多的時(shí)間;二是能耗棒口,區(qū)塊的生成需要礦工進(jìn)行無(wú)數(shù)無(wú)意義的計(jì)算寄月,這是非常耗費(fèi)能源的。

因此无牵,區(qū)塊鏈的適用場(chǎng)景漾肮,其實(shí)非常有限。

不存在所有成員都信任的管理當(dāng)局

寫入的數(shù)據(jù)不要求實(shí)時(shí)使用

挖礦的收益能夠彌補(bǔ)本身的成本

如果無(wú)法滿足上述的條件合敦,那么傳統(tǒng)的數(shù)據(jù)庫(kù)是更好的解決方案初橘。

目前,區(qū)塊鏈最大的應(yīng)用場(chǎng)景(可能也是唯一的應(yīng)用場(chǎng)景)充岛,就是以比特幣為代表的加密貨幣保檐。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市崔梗,隨后出現(xiàn)的幾起案子夜只,更是在濱河造成了極大的恐慌,老刑警劉巖蒜魄,帶你破解...
    沈念sama閱讀 211,194評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件扔亥,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡谈为,警方通過(guò)查閱死者的電腦和手機(jī)旅挤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)伞鲫,“玉大人粘茄,你說(shuō)我怎么就攤上這事★跖В” “怎么了柒瓣?”我有些...
    開封第一講書人閱讀 156,780評(píng)論 0 346
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)吠架。 經(jīng)常有香客問(wèn)我芙贫,道長(zhǎng),這世上最難降的妖魔是什么傍药? 我笑而不...
    開封第一講書人閱讀 56,388評(píng)論 1 283
  • 正文 為了忘掉前任磺平,我火速辦了婚禮魂仍,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘拣挪。我一直安慰自己蓄诽,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評(píng)論 5 384
  • 文/花漫 我一把揭開白布媒吗。 她就那樣靜靜地躺著仑氛,像睡著了一般。 火紅的嫁衣襯著肌膚如雪闸英。 梳的紋絲不亂的頭發(fā)上锯岖,一...
    開封第一講書人閱讀 49,764評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音甫何,去河邊找鬼出吹。 笑死,一個(gè)胖子當(dāng)著我的面吹牛辙喂,可吹牛的內(nèi)容都是我干的捶牢。 我是一名探鬼主播,決...
    沈念sama閱讀 38,907評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼巍耗,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼秋麸!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起炬太,我...
    開封第一講書人閱讀 37,679評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤灸蟆,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后亲族,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體炒考,經(jīng)...
    沈念sama閱讀 44,122評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評(píng)論 2 325
  • 正文 我和宋清朗相戀三年霎迫,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了斋枢。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,605評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡知给,死狀恐怖瓤帚,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情炼鞠,我是刑警寧澤缘滥,帶...
    沈念sama閱讀 34,270評(píng)論 4 329
  • 正文 年R本政府宣布轰胁,位于F島的核電站谒主,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏赃阀。R本人自食惡果不足惜霎肯,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評(píng)論 3 312
  • 文/蒙蒙 一擎颖、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧观游,春花似錦搂捧、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至搪柑,卻和暖如春聋丝,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背工碾。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工弱睦, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人渊额。 一個(gè)月前我還...
    沈念sama閱讀 46,297評(píng)論 2 360
  • 正文 我出身青樓况木,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親旬迹。 傳聞我的和親對(duì)象是個(gè)殘疾皇子火惊,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • 一、快速術(shù)語(yǔ)檢索 比特幣地址:(例如:1DSrfJdB2AnWaFNgSbv3MZC2m74996JafV)由一串...
    不如假如閱讀 15,897評(píng)論 4 88
  • 一奔垦、區(qū)塊鏈的本質(zhì) 區(qū)塊鏈?zhǔn)鞘裁创;危恳痪湓挘且环N特殊的分布式數(shù)據(jù)庫(kù)宴倍。 首先张症,區(qū)塊鏈的主要作用是儲(chǔ)存信息。任何需要保...
    立起來(lái)的影子閱讀 88評(píng)論 0 0
  • 天有星河鸵贬,地有情歌俗他,慈心如樂(lè),相鳴共合阔逼。 原創(chuàng)作品 (Original Article)
    一詩(shī)一境界閱讀 109評(píng)論 0 0
  • 歡樂(lè)頌2圓滿結(jié)局了兆衅,五美的生活都步入了正軌,作為歡樂(lè)頌的忠實(shí)粉絲嗜浮,我追了整整兩部羡亩,對(duì)于一個(gè)高三狗來(lái)說(shuō)也真是...
    ad41af5044a9閱讀 1,927評(píng)論 2 8
  • Cellier閱讀 440評(píng)論 0 0