圆月山庄资源网 Design By www.vgjia.com
谈到比特币,我们都知道挖矿,有些人并不太明白挖矿的含义。这里的挖矿其实就是哈希的碰撞,举个简单例子:
import hashlib x = 11 y = 1 #这里可以调节挖矿难度,也就是哈希的长度 while hashlib.sha256(f'{x*y}'.encode("utf-8")).hexdigest()[5:7]!="00": print(x*y) y +=1 print("找到了:",(x*y))
结果如下:
当然比特币的挖矿要比这个复杂太多,但是原理差不多,有个大概的认知。
关于节点的同步,是取整个节点中最长的区块链进行同步,如图所示:
有了以上内容铺垫,代码实现和理解就容易了,代码如下:
#挖矿原理与网络共识 import datetime import hashlib import json import requests class Blockchain2: def __init__(self): self.chain = [] #区块链列表 self.nodes = set() #节点集合 self.current_tranactions = [] #交易列表 self.new_block(proof=100,preHash=1) #创建第一个区块 #新建一个区块,需要计算,才能追加 def new_block(self,proof,preHash = None): block={ "index":len(self.chain)+1,#区块索引 "timestamp":datetime.datetiem.now(),#区块时间戳 "transactions":self.current_tranactions,#区块交易记录集合 "proof":proof,#算力凭证 "preHash":preHash or self.hash(self.chain[-1]), #上一块的哈希 } self.current_tranactions = [] #开辟新的区块,初始化区块交易记录 self.chain.append(block) @staticmethod def hash(block): #处理为json字符串格式的哈希 block_str = json.dumps(block,sort_keys=True).encode("utf-8") return hashlib.sha256(block_str).hexdigest() #新增交易记录 def new_transaction(self,sender,receiver,amount): transaction ={ "sender":sender, "receiver":receiver, "amount":amount, } self.current_tranactions.append(transaction) return self.last_block["index"]+1 @property def last_block(self): return self.chain[-1] #挖矿,依赖上一个模块,获取工作量证明,即POW共识机制 def proof_of_work(self,last_block): last_proof = last_block["proof"] last_hash = self.hash(last_block) proof = 0 while self.valid_proof(last_proof,proof,last_hash) is False: proof +=1 return proof #校验工作量 @staticmethod def valid_proof(last_proof,proof,last_hash): guess = f'{last_proof}{proof}{last_hash}'.encode("utf-8") guess_hash = hashlib.sha256(guess).hexdigest() return guess_hash[:6] =="000000" #可以调整计算难度 #区块一致性,同步算法, def resolve_conflicts(self): neighbours = self.nodes new_chain = None max_length = len(self.chain) #遍历所有节点,找出最长的链 for node in neighbours: #获取节点区块链信息 response = requests.get(f'http://{node}/chain') if response.status_code ==200: length = response.json()["length"] chain = response.json()["chain"] if length>max_length and self.valid_chain(chain): max_length = length new_chain = chain if new_chain: self.chain = new_chain return True else: return False #校验区块链的合法性 def valid_chain(self,chain): last_block = chain[0] current_index = 1 #校验每一个区块的prehash,proof合法性 while current_index <len(chain): block = chain[current_index] #校验哈希的合法性 if block["preHash"] != self.hash(last_block): return False #校验算力的合法性 if not self.valid_proof(last_block["proof"],block["proof"],block["preHash"]): return False last_block = block current_index +=1 return True
算力校验和pow共识基本实现了
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
python,挖矿算力,测试
圆月山庄资源网 Design By www.vgjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
圆月山庄资源网 Design By www.vgjia.com
暂无评论...
更新日志
2024年11月06日
2024年11月06日
- 雨林唱片《赏》新曲+精选集SACD版[ISO][2.3G]
- 罗大佑与OK男女合唱团.1995-再会吧!素兰【音乐工厂】【WAV+CUE】
- 草蜢.1993-宝贝对不起(国)【宝丽金】【WAV+CUE】
- 杨培安.2009-抒·情(EP)【擎天娱乐】【WAV+CUE】
- 周慧敏《EndlessDream》[WAV+CUE]
- 彭芳《纯色角3》2007[WAV+CUE]
- 江志丰2008-今生为你[豪记][WAV+CUE]
- 罗大佑1994《恋曲2000》音乐工厂[WAV+CUE][1G]
- 群星《一首歌一个故事》赵英俊某些作品重唱企划[FLAC分轨][1G]
- 群星《网易云英文歌曲播放量TOP100》[MP3][1G]
- 方大同.2024-梦想家TheDreamer【赋音乐】【FLAC分轨】
- 李慧珍.2007-爱死了【华谊兄弟】【WAV+CUE】
- 王大文.2019-国际太空站【环球】【FLAC分轨】
- 群星《2022超好听的十倍音质网络歌曲(163)》U盘音乐[WAV分轨][1.1G]
- 童丽《啼笑姻缘》头版限量编号24K金碟[低速原抓WAV+CUE][1.1G]