摘要:最近了解了一些區(qū)塊鏈的東西,動了一些深入了解的心思。同時,為了使區(qū)塊的添加速率趨于平均比特幣的設(shè)計是大約分鐘生成一個新的區(qū)塊,并不是隨便一個新建的區(qū)塊都可以被添加到鏈上。
最近了解了一些區(qū)塊鏈的東西,動了一些深入了解的心思。
了解的過程中會不斷補(bǔ)充和完善這篇文章,理解的不一定對,隨意看看得了,每篇文章都會把閱讀過的資料列出來,也方便大家去源頭看看。
區(qū)塊鏈(blockchain)區(qū)塊鏈?zhǔn)鞘裁矗?/p>
一句話,它是一種特殊的分布式數(shù)據(jù)庫
這句定義中有兩個關(guān)鍵詞分布式和數(shù)據(jù)庫.
首先,我們可以把區(qū)塊鏈看成是數(shù)據(jù)庫,但是這個數(shù)據(jù)庫并沒有管理員,也沒有中心,每個應(yīng)用鏈的人,都具有平等的權(quán)利。
區(qū)塊區(qū)塊鏈?zhǔn)怯梢粋€個的區(qū)塊(block)組成的, 每個區(qū)塊可以看做是一個存儲數(shù)據(jù)的單元,每寫入一次數(shù)據(jù),就會新建一個區(qū)塊,一個一個區(qū)塊連接起來,就成了鏈狀。
每個區(qū)塊分成兩個部分:
區(qū)塊頭(Block Head)
包含了當(dāng)前區(qū)塊的基本信息,包括 生成時間, 區(qū)塊體的 hash 值, 上一個區(qū)塊的 hash 等信息。
區(qū)塊的 hash 就是根據(jù)區(qū)塊頭的內(nèi)容來生成的。
區(qū)塊體(Block Body)
區(qū)塊體就是所含數(shù)據(jù)的真實內(nèi)容
hash區(qū)塊的根本是源于 hash, 如果把區(qū)塊鏈想象成一個真實的鏈狀結(jié)構(gòu)的話,那么 hash 就是每個元素之間的連接點。
關(guān)于 hash 的詳盡定義,可以在 wikipedia中查看,這里簡單總結(jié)一下 hash 的特征:
如果兩個 hash 是不相同的(根據(jù)同一函數(shù)),那么這兩個 hash 的原始輸入也是不相同的
hash 的輸入和輸出不是唯一對應(yīng)關(guān)系的,如果兩個 hash 值相同,兩個輸入值很可能是相同的,但也可能不同,這是由具體的 hash 計算方法決定的
區(qū)塊的內(nèi)容與 hash 是一一對應(yīng)的,每個區(qū)塊的 hash 值都是不同的。同時,每一個區(qū)塊又都保存著上一個區(qū)塊的 hash 值。
按照這個邏輯,如果一個區(qū)塊的 hash 值變了的話,那么它之后的每一個區(qū)塊的 hash 值都需要進(jìn)行更新。
進(jìn)而延伸一下,如果有人想更新某一區(qū)塊上的內(nèi)容,那么他必須有能力依次更新這個區(qū)塊后面所有區(qū)塊的 hash 值才行,否則的話,被更新的區(qū)塊就會脫離整個鏈了。由于更新區(qū)塊 hash 的計算很復(fù)雜且耗時,所以除非掌握了全網(wǎng) 50% 以上的運算能力,否則更新某一區(qū)塊的行為根本不可能成功。
正是通過這種環(huán)環(huán)相扣的機(jī)制,區(qū)塊鏈才可以保證自身數(shù)據(jù)的不可修改的特性。
區(qū)塊鏈?zhǔn)侨绾芜\行的 挖礦由于區(qū)塊鏈?zhǔn)且粭l單一的鏈,每個區(qū)塊都依賴于上一個區(qū)塊,所以同一時間,只能向鏈上添加一個區(qū)塊。
又由于必須保證各個節(jié)點間的同步,所以添加完一個區(qū)塊,各個節(jié)點又必須進(jìn)行同步。
也就是說,假設(shè)節(jié)點 A 正忙著生成新的區(qū)塊,突然收到消息:“B 已經(jīng)在鏈上添加了一個區(qū)塊!”。這個時候 A 之前做的計算就都白做了,又得基于 B 新添加的節(jié)點,重新剛才的計算。并且計算的過程中,還會有類似的事情發(fā)生。
上面我們說過,在區(qū)塊鏈的運行機(jī)制中,通過區(qū)塊自身的 hash 來判斷當(dāng)前區(qū)塊是否可以被加入到鏈上。
同時,為了使區(qū)塊的添加速率趨于平均(比特幣的設(shè)計是大約10分鐘生成一個新的區(qū)塊),并不是隨便一個新建的區(qū)塊都可以被添加到鏈上。
通常會設(shè)置一個準(zhǔn)入條件,只有符合該條件的區(qū)塊,才可以被添加到鏈上,設(shè)計者通過設(shè)置海量的計算,來使計算滿足加入條件的區(qū)塊 hash 值變得非常困難,這個過程就叫做挖礦,也叫(mining), 繼續(xù)挖礦計算的機(jī)器, 我們就叫做礦機(jī), 操作機(jī)器的人(其實是程序), 我們就叫做礦工。
用 js 代碼運行一下簡單的挖礦機(jī)制首先,每一個區(qū)塊,我們可以看成是由這幾部分組成:
這是我們這個鏈上的第一個區(qū)塊,這個區(qū)塊包括了這樣幾個信息
index: 區(qū)塊的 index 值, 這里應(yīng)該是 0
previous hash: 前一個區(qū)塊的 hash
timestamp: 區(qū)塊創(chuàng)建時的時間戳
data: 區(qū)塊包含的數(shù)據(jù)內(nèi)容
hash: 區(qū)塊本身的 hash
nonce: 計算區(qū)塊 hash 的難度系數(shù)
我們先假定這個區(qū)塊的名字是 A, 接下來,我們在它后面再添加個區(qū)塊 B.
那么我的這個 B 將包含以下這些信息:
index: 1
previous hash: 也就是 A 的 hash
timestamp
data: I love Blockchain
hash: ?
nonce: ?
如果要將 B 添加到鏈上,那么我們接下來的工作就是計算出 hash 和 nonce 的值,
那么就假設(shè)我們計算 hash 的算法是這樣的:
CryptoJS.SHA256(index + previousHash + timestamp + data + nonce)
接下來我們來計算這個 hash 值是否是一個準(zhǔn)入的 hash, 代碼如下:
function isValidHashDifficulty(hash, difficulty) { for (var i = 0, b = hash.length; i < b; i ++) { if (hash[i] !== "0") { break; } } return i >= difficulty; }
我們這里的準(zhǔn)入條件為 hash 中連續(xù)不為 0 的值必須不小于 difficulty.
參數(shù)中的 difficulty, 也可以稱為難度系數(shù), 通過這個系數(shù)的動態(tài)調(diào)整,可以維持新增區(qū)塊的平均速率。
另外,我們上面計算 hash 的算法中 index, previousHash, timestamp 和 data 都是固定的,所以重復(fù)計算出來的 hash 值也應(yīng)該是一樣的,為了使每次計算出的 hash 不同, nonce被設(shè)計成了一個變化的值, 通過 nonce值的變化, 計算出不同的 hash, 從而判斷 hash 值是否符合準(zhǔn)入條件, 用代碼表示的話. 就是這樣:
let nonce = 0; let hash; let input; while(!isValidHashDifficulty(hash, difficulty)) { nonce = nonce + 1; input = index + previousHash + timestamp + data + nonce; hash = CryptoJS.SHA256(input) }
看到這里, 我們可以發(fā)現(xiàn), 其實礦工的工作就是去猜nonce的值, 因為這個值很大, 所以計算難道也就比較大, 挖礦也就成了一件費時費力的事情。
相應(yīng)的, 既然挖礦是如此費時費力的一件事, 那么礦工也不會是義務(wù)勞動的, 礦工獲得的相應(yīng)收益, 會在下一部分 比特幣 中, 以比特幣的運行規(guī)則來描述一下。
Reference區(qū)塊鏈入門教程
How does blockchain really work? I built an app to show you
Ethereum for web developers
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/24253.html
摘要:也就是說,比特幣是一個完全出于社區(qū)共識的貨幣。所謂全稱為,它是比特幣交易的基本單位。根據(jù)比特幣的協(xié)議,一個區(qū)塊的大小是而一筆交易大概是,因此一個區(qū)塊大概可以包含筆交易。 誕生 比特幣誕生于 2008 年,一個網(wǎng)名為中本聰?shù)娜耍岢隽艘粋€設(shè)想: 創(chuàng)造一種不受政府或任何組織控制的貨幣 比特幣的本質(zhì)就是一串?dāng)?shù)字,沒有任何資產(chǎn)支持(現(xiàn)行貨幣背后都是國家或銀行提供資產(chǎn)支持)。也就是說,比特幣是一...
摘要:和比特幣協(xié)議有所不同的是,以太坊的設(shè)計十分靈活,極具適應(yīng)性。超級賬本區(qū)塊鏈的商業(yè)應(yīng)用超級賬本超級賬本是基金會下的眾多項目中的一個。證書頒發(fā)機(jī)構(gòu)負(fù)責(zé)簽發(fā)撤 showImg(https://segmentfault.com/img/bV2ge9?w=900&h=385); 從比特幣開始 一個故事告訴你比特幣的原理及運作機(jī)制 這篇文章的定位會比較科普,盡量用類比的方法將比特幣的基本原理講出來...
摘要:圍繞以太坊的開發(fā)生態(tài)是目前相對最成熟的,比如有開發(fā)框架,有智能合約在線集成開發(fā)環(huán)境,還有專設(shè)的開發(fā)者問答頻道。 showImg(https://segmentfault.com/img/bVbaJOL?w=1200&h=514); 張泉靈說,時代拋棄我們的時候連聲再見都不會說,馬云說對于新興事物,絕大多數(shù)人是看不見、看不起、看不懂、來不及。自從學(xué)完 Coursera 上的 Crypto...
摘要:圍繞以太坊的開發(fā)生態(tài)是目前相對最成熟的,比如有開發(fā)框架,有智能合約在線集成開發(fā)環(huán)境,還有專設(shè)的開發(fā)者問答頻道。 showImg(https://segmentfault.com/img/bVbaJOL?w=1200&h=514); 張泉靈說,時代拋棄我們的時候連聲再見都不會說,馬云說對于新興事物,絕大多數(shù)人是看不見、看不起、看不懂、來不及。自從學(xué)完 Coursera 上的 Crypto...
摘要:本文分享自華為云社區(qū)技術(shù)解析代碼實戰(zhàn),帶你入門華為云政務(wù)區(qū)塊鏈平臺,作者敏捷的小智。點擊關(guān)注,第一時間了解華為云新鮮技術(shù) 摘要:政務(wù)區(qū)塊鏈平臺是行業(yè)區(qū)塊鏈平臺的初步實踐,未來在區(qū)塊鏈技術(shù)的發(fā)展下,還會打造面向其他領(lǐng)域的鏈管平臺,構(gòu)建多方協(xié)同的分布式賬本,讓區(qū)塊鏈應(yīng)用更便捷高效的為產(chǎn)業(yè)服務(wù)。...
閱讀 1069·2023-04-25 14:35
閱讀 2831·2021-11-16 11:45
閱讀 3421·2021-09-04 16:48
閱讀 2187·2021-08-10 09:43
閱讀 532·2019-08-30 13:17
閱讀 1627·2019-08-29 13:27
閱讀 892·2019-08-26 13:58
閱讀 2157·2019-08-26 13:48