มาสร้าง Blockchain ของเราเองกันเถอะ ( 2 ) , Mining

Mining ( ขุด ) คือกระบวนการสร้าง block. ใหม่ แล้วเพิ่มเข้าไปใน blockchain
มีขั้นตอนการทำงานดังต่อไปนี้
const nonce = bitcoin.proofOfWork(previousBlockHash, currentBlockData);
const blockHash = bitcoin.hashBlock(previousBlockHash, currentBlockData, nonce);
const newBlock = bitcoin.createNewBlock(nonce, previousBlockHash, blockHash);
เรามาดู code ของ function เหล่านี้กันดีกว่า
Blockchain.prototype.createNewBlock = function(nonce, previousBlockHash, hash) {
const newBlock = {
index: this.chain.length + 1,
timestamp: Date.now(),
transactions: this.pendingTransactions,
nonce: nonce,
hash: hash,
previousBlockHash: previousBlockHash
};
this.pendingTransactions = [];
this.chain.push(newBlock);
return newBlock;
};
Blockchain.prototype.hashBlock = function(previousBlockHash, currentBlockData, nonce) {
const dataAsString = previousBlockHash + nonce.toString() + JSON.stringify(currentBlockData);
const hash = sha256(dataAsString);
return hash;
};
Blockchain.prototype.proofOfWork = function(previousBlockHash, currentBlockData) {
let nonce = 0;
let hash = this.hashBlock(previousBlockHash, currentBlockData, nonce);
while (hash.substring(0, 4) !== '0000') {
nonce++;
hash = this.hashBlock(previousBlockHash, currentBlockData, nonce);
}
return nonce;
};
เราควรจะเริ่มดูที่ hashBlock function ซึ่งถูกเรียกใช้บ่อย function นี้ไม่มีอะไรซับซ้อนมาก แค่ทำการ hash ค่าของ previousBlockHash + nonce + currentBlockData ด้วย sha256
proofOfWork function คือการหา hash ที่ขึ้นต้นด้วย 0000 ให้เจอ เราจะเห็นว่า nonce คือตัวแปรที่เพิ่มค่าไปเรื่อยๆ ใน while loop เมื่อเราเจอ nonce ที่ถูกต้องแล้ว function ก็จะ return
const nonce = bitcoin.proofOfWork(previousBlockHash, currentBlockData);
const blockHash = bitcoin.hashBlock(previousBlockHash, currentBlockData, nonce);
const newBlock = bitcoin.createNewBlock(nonce, previousBlockHash, blockHash);
กลับมาดู code ที่พูดในตอนแรกจะเห็นได้ว่า createNewBlock เพียงแค่รับ parameter ที่ได้จาก output ของ proofOfWork และ hashBlock
Articles
- LangChain + Ollama で RAGチャットボットを作る方法
- How to Apply RAG Chatbot with LangChain + Ollama
- วิธีสร้าง RAG Chatbot ด้วย LangChain + Ollama
- การใช้งาน SCPI กับอุปกรณ์ EXFO: คู่มือฉบับใช้งานจริง
- SCPI を使った EXFO 機器の自動化:実践ガイド
- Automating EXFO Instruments with SCPI: A Practical Guide
- レガシーコードを扱いやすくするためのデザインパターン
- Design Patterns ที่ช่วยให้จัดการ Legacy Code ได้ง่ายขึ้น
- Design Patterns That Help Tame Legacy Code (With Python Examples)
- 🧠 レガシーコードに安全に新機能を追加する方法
- วิธีเพิ่มฟีเจอร์ใหม่ในซอฟต์แวร์ Legacy อย่างปลอดภัย
- How to Safely Add New Features to Legacy Code — A Developer’s Guide
- レガシーソフトウェアを安全に近代化 — 全面リライト不要!
- ปรับปรุงซอฟต์แวร์เก่า ให้ทันสมัย โดยไม่ต้องเขียนใหม่ทั้งหมด
- Modernizing Legacy Software — Without Breaking Everything
- OpenSearchの仕組みとは?リアルタイム検索エンジンの内部構造を解説
- OpenSearch ทำงานอย่างไร? เข้าใจระบบค้นหาและวิเคราะห์ข้อมูลแบบเรียลไทม์
- How OpenSearch Works — Architecture, Internals & Real-Time Search Explained
- DjangoでBasicとPremium機能を分けるベストな戦略とは?
- เลือกกลยุทธ์ที่ใช่ สำหรับการแยกระดับผู้ใช้งาน Basic กับ Premium บน Django
Our Products
Articles
- LangChain + Ollama で RAGチャットボットを作る方法
- How to Apply RAG Chatbot with LangChain + Ollama
- วิธีสร้าง RAG Chatbot ด้วย LangChain + Ollama
- การใช้งาน SCPI กับอุปกรณ์ EXFO: คู่มือฉบับใช้งานจริง
- SCPI を使った EXFO 機器の自動化:実践ガイド
- Automating EXFO Instruments with SCPI: A Practical Guide
- レガシーコードを扱いやすくするためのデザインパターン
- Design Patterns ที่ช่วยให้จัดการ Legacy Code ได้ง่ายขึ้น
- Design Patterns That Help Tame Legacy Code (With Python Examples)
- 🧠 レガシーコードに安全に新機能を追加する方法
- วิธีเพิ่มฟีเจอร์ใหม่ในซอฟต์แวร์ Legacy อย่างปลอดภัย
- How to Safely Add New Features to Legacy Code — A Developer’s Guide
- レガシーソフトウェアを安全に近代化 — 全面リライト不要!
- ปรับปรุงซอฟต์แวร์เก่า ให้ทันสมัย โดยไม่ต้องเขียนใหม่ทั้งหมด
- Modernizing Legacy Software — Without Breaking Everything
- OpenSearchの仕組みとは?リアルタイム検索エンジンの内部構造を解説
- OpenSearch ทำงานอย่างไร? เข้าใจระบบค้นหาและวิเคราะห์ข้อมูลแบบเรียลไทม์
- How OpenSearch Works — Architecture, Internals & Real-Time Search Explained
- DjangoでBasicとPremium機能を分けるベストな戦略とは?
- เลือกกลยุทธ์ที่ใช่ สำหรับการแยกระดับผู้ใช้งาน Basic กับ Premium บน Django