0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

教你用Python从0开始创建一个区块链

马哥Linux运维 来源:互联网 作者:佚名 2018-04-20 06:55 次阅读

三点钟区块链”无疑成为了大家春节期间焦虑的根源,而“区块链”注定是 2018 年被持续讨论、关注的行业性热点话题

3 月 1 日,朱啸虎对正翻涌不断的区块链热潮再次开炮,在朋友圈一张画满区块链应用的图上,朱啸虎质疑:所有这些应用加在一起,有多少日活用户?“2000 年的互联网泡沫至少还有 eyeball,今天的区块链除了炒币外还有什么”?

在此之前,朱啸虎在朋友圈转发了讽刺区块链投资热的文章《来,喝了这碗区块链的毒鸡汤!》,并声明:“不要拉我进任何 3 点钟群,有些风口宁愿错过,有些钱宁愿不赚,大家晚节保重。”朱啸虎还表示,说ICO 是庞氏骗局是在侮辱庞氏骗局。

作为程序员的你,再不懂这个技术,2018 可能会被淘汰!下面和小编一起从十个幽默段子入门区块链吧!

01 笑喷!区块链十个段子集锦

1、假如你是一位女性,你男朋友每次跟你说一句肉麻的话或者承诺给你买东西,你都立刻录下来并且发给你的和他的所有闺蜜、同学、同事,还有各种群和朋友圈,让他再也无法抵赖,这叫区块链。

2、麻将是中国传统的区块链项目:四个矿工一组,先碰撞出 13 个数字正确哈希值的矿工可以获得记账权并得到奖励。不可篡改。因为说服其他三个人需要消耗太多算力和体力。

3、玩夜店的小姐姐和玩虚拟币的小哥哥们有几处相似:

  • 都是自认聪明的优秀群体

  • 不给自己赚钱的都是傻 X 屌丝

  • 都认识很多大佬

  • 都明白很多道理

  • 都是在等自己涨价或者自己的虚拟币涨价被别人接盘

4、区块链是正经技术,各种币正不正经就不知道了。

5、吴三桂在山海关冲冠一怒,本质是为了争夺睡陈圆圆的权力;大佬们在区块链路上的互怼,本质是为了争夺割韭菜的权力。

6、新学期刚开始,儿子问老爸:「父亲工作一栏怎么填?是写币民吗?」老爸犹豫了一下说:「就写多家上市公司股东。」

7、最近数字货币很火,很多山寨币都是几倍几十倍的增长。很多炒币的开始飘飘然,叫嚣什么「一币一嫩模」。有朋友就问我要不要跟?我观点很简单:淘金热,一窝蜂淘金,风险很大。所以,让他们叫「一币一嫩模」去吧,不要跟风盲目炒币,我们应该赚他们的钱——去当嫩模!当嫩模!嫩模!

8、我昨天遇见一币友,问他:「近来币市暴降,睡觉质量怎么样?」

他说:「还行,像婴儿般睡觉!」

我说:「羡慕了。」

他说:「是睡一个小时,醒了,然后哭一个小时,接着,再睡一个小时,起来再哭一个小时。」

9、老同志语重心长地对 80、90 后说:「别玩那些比特币,那些虚拟的玩意,做点实事在北京买个房、娶个媳妇,多好!」90 后回答说:「你们都把几千块钱成本的房子搞到10万一平米了。我们不另寻出路,搞一串串数字 10 万一个卖给你们,我们拿什么买得起房子啊?」

10、首先感谢公司拿出价值 100 万的比特币作为给员工的奖励,其次我觉得自己很幸运能拿到这 95 万的奖励,然后我觉得我还是要好好规划一下这 86 万的用处,毕竟 70 万也不是一笔小钱,我打算拿出 20 万给父母,剩下的 36 万暂时还没想好怎么用,总之,感谢公司价值 30 万的比特币的奖励,谢谢,祝大家和我一样都能得到这 15 万的奖励。

02 图解:大白话了解到底区块链是个啥?

1. what is 区块链

“区块链仅仅是一门技术而已”,“比特币”仅仅是区块链技术的一种应用而已, 就好比,一个人会厨艺的技术,但是应用起他的厨艺可以做出“宫保鸡丁”、”鱼香肉丝”等各式的菜肴。

那么,到底“区块链”是个啥?我们这里借助网上一个比较流行的段子,将它用图形的形式展示给大家。

我们可以将“比特币”抽象成“某荣的照片”如上图所示,如果网上很多用户想要得到某荣的照片,需要到一个固定的网站去搜索。

当然你也没其他地方可去嘛,那么好了,这个某榴网站天天给你弹出广告啊,小窗口啊,你都得忍着,没办法,因为就这一个地方可以获取嘛。

再者,这个网站突然被警察叔叔封杀了咋办?或者断电?断网?管他啥的,反正就是服务器崩溃了,那么悲剧的“某荣”粉丝们心爱的 2100 张照片将全部失去提供资源的场所。

这就是网上流传的新词“中心化”喽,他的弊端就是资源集中一起,抗风险容错性很弱。资源容易丢失。

那么,怎么解决这个问题呢?我们试想,能不能让每个“某荣”粉丝,都拥有这 2100 张照片呢?比如下图:

这样的话,貌似就不用在依赖那个“某榴”网站了呢。即使某个粉丝突然电脑崩溃,他随便找一个其他粉丝来获得这 2100 张照片,不愁了,不愁了。

后来,一个叫“某本聪”的一个虚拟人物提供了,一个拥有协议的某荣照片共享文件夹,用户可以从中获取照片,但是必须遵循协议。

这样,每个粉丝都可以从这个文件夹中获取那 2100 张某荣的照片,但是全部获取的粉丝必须要遵循一个协议,当然是人家某本聪定义的协议啦。

“不得复制,修改,共享文件中的任意照片,粉丝们在共享文件夹中的任何行为都会被记录,并且是按照时间去记录!”

粉丝们这么喜爱某荣,而且不需要去某榴获取,当然就纷纷踊跃加入了~

忽然,有一天,调皮的小 One 想要违背规则,在 2018 年 1 月 15 日中午 12 点删除编号为 1-100 的某荣照片。

根据协议,这个行为会被记录,并且会广播给其他粉丝。

照片到底被删除了么?当然不是,因为小露手里也有照片嘛,她收到广播后可以立刻恢复共享文件夹中已经删除的照片,小 One 永远别想对“共享文件夹”搞修改破坏,且所有行为都同步记录在其他用户的电脑里。

这就是区块链,数据分散存储,去中心化。按时间戳广播记录所有行为,无法修改、破坏数据源或造假。

除非同一时刻炸掉 100 万个用户的电脑,或互联网消失,或世界毁灭....否则数据将永远存在~~

如何增加区块链保护的资源?“某本聪”又来了。他说,你们是可以在文件中添加某荣照片的,但是呢,你们各位必须达到某种“共识”?啥是“共识”,就是我们都承认的规则喽。

那到底是个啥共识呢?啊,小 One 和小露立刻了解了某本聪的意思,在每年规定的时间内,尽快拍出 100 张某荣的照片,这样就可以添加到“某荣共享文件夹”了,我们的资源就扩充了。

但是,好景不长。某本聪发现大量的拍照,冲击前 100,那很快就能达成了,拍照就没有难度了。

而且照片质量还差,好像谁都能轻易的添加照片资源,这样就保证不了某荣的照片质量了。于是,某本聪再次降临,增加拍照的共识难度。

小 One 和小露作为忠实的粉丝,怎能放弃,他们买了高端相机,让某荣摆出各种姿势,花费大量的时间和汗水完成了高质量的照片,当然自己也非常的辛苦。

这样高质量的照片就可以添加到“某荣的文件夹”中了。

2. 何为 ICO?

小 One 想:每张照片都是不可造假破坏的,所以具有唯一性,还有单独编号,给每一张照片估价,它不就值钱了吗?就像现实世界中无法复制的名画一样!

小 One 就把之前的某荣照片,构造出来相应的“某荣币”,当然这个行为就向我们的政府通过国库的黄金数额发行等价的人民币类似啦。

估值呢,当然小 One 说的算啦,人家是照片的拥有者嘛。

为了证实某荣币 5W 块一个,小 One 首先购买了 2100 个中的 1100 个,剩下的发行给吃瓜群众们啦,我们已经用 5W 买一个,说明他已经值这个价钱啦,剩下 1000 个大家一起买吧。

这样的话如果 2100 个全部认购出去,2100 个某荣币可以就估值 1.05 亿块哦~这种通过数字货币的发行而得到融资的过程就是 ICO 啦。

根据这个图的含义,如果小 One 和小露是一个可信任的机构或者公众人物,还是可以相信他们的,当然啦也会有很多不法分子恶意发行货币来套现的。

这也是我们国家为什么禁止 ICO 发行的原因啦,因为目前没有一个完善的 ICO 监管条例能够保证发行货币的机构的可信任性和合法的监管他们,所以吃瓜群众们要自己承担风险找到一个可信的机构。

这样 2100 个某荣币全部认购成功,基金成立,这就是 ICO。当然吃瓜群众也可以继续拍照创造某荣币,就是有点难罢了。

现在各位了解什么是区块链和 ICO 了吧~下面手把手教你如何用Python语言创建一个区块链?

03 用 Python 从 0 开始创建一个区块链

对数字货币的崛起感到新奇的我们,并且想知道其背后的技术——区块链是怎样实现的。本文通过 Python 构建一个区块链可以加深对区块链的理解。

1. 准备工作

本文要求读者对 Python 有基本的理解,能读写基本的 Python,并且需要对 HTTP 请求有基本的了解。

我们知道区块链是由区块的记录构成的不可变、有序的链结构,记录可以是交易、文件或任何你想要的数据,重要的是它们是通过哈希值(hashes)链接起来的。

如果你还不是很了解哈希,可以查看这篇文章https://learncryptography.com/hash-functions/what-are-hash-functions。

(1)环境准备:

环境准备,确保已经安装Python3.6+、pip、Flask、requests。

(2)安装方法:


        

pip install Flask==0.12.2 requests==2.18.4

同时还需要一个 HTTP 客户端,比如 Postman、cURL 或其他客户端。

参考源代码(原代码在我翻译的时候,无法运行,我 fork 了一份,修复了其中的错误,并添加了翻译,感谢 star)。

2. 开始创建 Blockchain

新建一个文件 blockchain.py,本文所有的代码都写在这一个文件中,可以随时参考源代码。

(1)Blockchain 类

首先创建一个 Blockchain 类,在构造函数中创建了两个列表,一个用于储存区块链,一个用于储存交易。

以下是 Blockchain 类的框架:


        

classBlockchain(object):def__init__(self):self.chain = []self.current_transactions = []defnew_block(self):# Creates a new Block andadds it to the chainpassdefnew_transaction(self):# Adds a new transaction to the list of transactionspass @staticmethoddefhash(block):# Hashes a Blockpass @propertydeflast_block(self):# Returns the last Block in the chainpass

Blockchain 类用来管理链条,它能存储交易、加入新块等,下面我们来进一步完善这些方法。

(2)块结构

每个区块包含属性:索引(index)、Unix 时间戳(timestamp)、交易列表(transactions)、工作量证明(稍后解释)以及前一个区块的 Hash 值。

以下是一个区块的结构:


        

block = {'index': 1,'timestamp': 1506057125.900785,'transactions': [ {'sender':"8527147fe1f5426f9dd545de4b27ee00",'recipient':"a77f5cdfa2934df3954a5c7c7da5df1f",'amount': 5, } ],'proof': 324984774000,'previous_hash':"2cf24dba5fb0a30e26e83b2ac5b9e29e1b161e5c1fa7425e73043362938b9824"}

到这里区块链的概念就清楚了,每个新的区块都包含上一个区块的 Hash,这是关键的一点,它保障了区块链的不可变性。

如果攻击者破坏了前面的某个区块,那么后面所有区块的Hash都会变得不正确。不理解的话,慢慢消化,可参考{% post_link whatbc 区块链技术原理 %}。

(3)加入交易

接下来我们需要添加一个交易,来完善下 new_transaction 方法:


        

classBlockchain(object):...defnew_transaction(self, sender, recipient, amount):""" 生成新交易信息,信息将加入到下一个待挖的区块中 :paramsender: Address of the Sender :param recipient: Address of the Recipient :param amount: Amount :return: The index of the Block that will hold this transaction """ self.current_transactions.append({'sender': sender,'recipient': recipient,'amount': amount, })returnself.last_block['index'] +1

方法向列表中添加一个交易记录,并返回该记录将被添加到的区块(下一个待挖掘的区块)的索引,等下在用户提交交易时会有用。

(4)创建新块

当 Blockchain 实例化后,我们需要构造一个创世块(没有前区块的第一个区块),并且给它加上一个工作量证明。每个区块都需要经过工作量证明,俗称挖矿,稍后会继续讲解。

为了构造创世块,我们还需要完善 new_block(),new_transaction() 和hash() 方法:


        

importhashlibimportjsonfromtimeimporttimeclassBlockchain(object):def__init__(self):self.current_transactions = [] self.chain = []# Create the genesis blockself.new_block(previous_hash=1, proof=100)defnew_block(self, proof, previous_hash=None):""" 生成新块 :param proof: The proof given by the Proof of Work algorithm :param previous_hash: (Optional) Hash of previous Block :return: New Block """ block = {'index': len(self.chain) +1,'timestamp': time(),'transactions': self.current_transactions,'proof': proof,'previous_hash': previous_hashorself.hash(self.chain[-1]), }# Reset the current list of transactionsself.current_transactions = [] self.chain.append(block)returnblockdefnew_transaction(self, sender, recipient, amount):""" 生成新交易信息,信息将加入到下一个待挖的区块中 :param sender: Address of the Sender :param recipient: Address of the Recipient :param amount: Amount :return: The index of the Block that will hold this transaction """ self.current_transactions.append({'sender': sender,'recipient': recipient,'amount': amount, })returnself.last_block['index'] +1@propertydeflast_block(self):returnself.chain[-1]@staticmethoddefhash(block):""" 生成块的 SHA-256 hash值 :param block: Block :return: """ # We must make sure that the Dictionary is Ordered, or we'll have inconsistent hashesblock_string = json.dumps(block, sort_keys=True).encode()returnhashlib.sha256(block_string).hexdigest()

通过上面的代码和注释可以对区块链有直观的了解,接下来我们看看区块是怎么挖出来的。

(5)理解工作量证明

新的区块依赖工作量证明算法(PoW)来构造。PoW 的目标是找出一个符合特定条件的数字,这个数字很难计算出来,但容易验证。这就是工作量证明的核心思想。

为了方便理解,举个例子:

假设一个整数 x 乘以另一个整数 y 的积的 Hash 值必须以 0 结尾,即 hash(x * y) = ac23dc...0。设变量 x = 5,求 y 的值?

用 Python 实现如下:


        

fromhashlibimportsha256x =5y =0# y未知whilesha256(f'{x*y}'.encode()).hexdigest()[-1] !="0": y +=1print(f'The solution is y ={y}')

结果是:y = 21,因为:


        

hash(5 * 21) = 1253e9373e...5e3600155e860

在比特币中,使用称为 Hashcash 的工作量证明算法,它和上面的问题很类似,矿工们为了争夺创建区块的权利而争相计算结果。

通常,计算难度与目标字符串需要满足的特定字符的数量成正比,矿工算出结果后,会获得比特币奖励。当然,在网络上非常容易验证这个结果。

(6)实现工作量证明

让我们来实现一个相似 PoW 算法,规则是:寻找一个数 p,使得它与前一个区块的 proof 拼接成的字符串的 Hash 值以 4 个零开头。


        

importhashlibimportjsonfromtimeimporttimefromuuidimportuuid4classBlockchain(object):...defproof_of_work(self, last_proof):""" 简单的工作量证明: - 查找一个 p' 使得 hash(pp') 以4个0开头 - p 是上一个块的证明, p' 是当前的证明 :param last_proof: :return: """ proof =0whileself.valid_proof(last_proof, proof)isFalse: proof +=1returnproof@staticmethoddefvalid_proof(last_proof, proof):""" 验证证明: 是否hash(last_proof, proof)以4个0开头? :param last_proof: Previous Proof :param proof: Current Proof :return: True if correct, False if not. """ guess =f'{last_proof}{proof}'.encode() guess_hash = hashlib.sha256(guess).hexdigest()returnguess_hash[:4] =="0000"

衡量算法复杂度的办法是修改零开头的个数。使用 4 个零来用于演示,你会发现多一个零都会大大增加计算出结果所需的时间。

现在 Blockchain 类基本已经完成了,接下来使用 HTTP requests 来进行交互。

2. Blockchain 作为 API接口

我们将使用 Python Flask 框架,这是一个轻量 Web 应用框架,它方便将网络请求映射到 Python 函数,现在我们来让 Blockchain 运行在 Flask Web 上。

我们将创建三个接口:

  • /transactions/new 创建一个交易并添加到区块

  • /mine 告诉服务器去挖掘新的区块

  • /chain 返回整个区块链

(1)创建节点

我们的“Flask 服务器”将扮演区块链网络中的一个节点,我们先添加一些框架代码:


        

importhashlibimportjsonfromtextwrapimportdedentfromtimeimporttimefromuuidimportuuid4fromflaskimportFlaskclassBlockchain(object):...# Instantiate our Nodeapp = Flask(__name__)# Generate a globally unique address for this nodenode_identifier = str(uuid4()).replace('-','')# Instantiate the Blockchainblockchain = Blockchain()@app.route('/mine', methods=['GET'])defmine():return"We'll mine a new Block"@app.route('/transactions/new', methods=['POST'])defnew_transaction():return"We'll add a new transaction"@app.route('/chain', methods=['GET'])deffull_chain():response = {'chain': blockchain.chain,'length': len(blockchain.chain), }returnjsonify(response),200if__name__ =='__main__': app.run(host='0.0.0.0', port=5000)

简单的说明一下以上代码:

  • 第 15 行:创建一个节点。

  • 第 18 行:为节点创建一个随机的名字。

  • 第 21 行:实例 Blockchain 类。

  • 第 24–26 行:创建 /mine GET 接口。

  • 第 28–30 行:创建 /transactions/new POST 接口,可以给接口发送交易数据。

  • 第 32–38 行:创建 /chain 接口, 返回整个区块链。

  • 第 40–41 行:服务运行在端口5000 上。

(2)发送交易

发送到节点的交易数据结构如下:


        

{"sender":"my address","recipient":"someone else's address","amount":5}

之前已经有添加交易的方法,基于接口来添加交易就很简单了:


        

importhashlibimportjsonfromtextwrapimportdedentfromtimeimporttimefromuuidimportuuid4fromflaskimportFlask, jsonify, request...@app.route('/transactions/new', methods=['POST'])defnew_transaction():values = request.get_json()# Check that the required fields are in the POST'ed datarequired = ['sender','recipient','amount']ifnotall(kinvaluesforkinrequired):return'Missing values',400# Create a new Transactionindex = blockchain.new_transaction(values['sender'], values['recipient'], values['amount']) response = {'message':f'Transaction will be added to Block{index}'}returnjsonify(response),201

(3)挖矿

挖矿正是神奇所在,它很简单,做了以下三件事:

  • 计算工作量证明 PoW。

  • 通过新增一个交易授予矿工(自己)一个币。

  • 构造新区块并将其添加到链中。


        

importhashlibimportjsonfromtextwrapimportdedentfromtimeimporttimefromuuidimportuuid4fromflaskimportFlask, jsonify, request...importhashlibimportjsonfromtimeimporttimefromuuidimportuuid4fromflaskimportFlask, jsonify, request...@app.route('/mine', methods=['GET'])defmine():# We run the proof of work algorithm to get the next proof...last_block = blockchain.last_block last_proof = last_block['proof'] proof = blockchain.proof_of_work(last_proof)# 给工作量证明的节点提供奖励.# 发送者为 "0" 表明是新挖出的币blockchain.new_transaction( sender="0", recipient=node_identifier, amount=1, )# Forge the new Block by adding it to the chainblock = blockchain.new_block(proof) response = {'message':"New Block Forged",'index': block['index'],'transactions': block['transactions'],'proof': block['proof'],'previous_hash': block['previous_hash'], }returnjsonify(response),200

注意交易的接收者是我们自己的服务器节点,我们做的大部分工作都只是围绕 Blockchain 类方法进行交互。到此,我们的区块链就算完成了,我们来实际运行下。

(4)运行区块链

你可以使用 cURL 或 Postman 去和 API 进行交互。

启动 server:


        

$ python blockchain.py* Runingonhttp://127.0.0.1:5000/ (Press CTRL+C to quit)

让我们通过请求 http://localhost:5000/mine 来进行挖矿:

通过 post 请求,添加一个新交易:

如果不是使用 Postman,则用以下的 cURL 语句也是一样的:


        

$ curl -X POST -H"Content-Type: application/json"-d '{"sender":"d4ee26eee15148ee92c6cd394edd974e","recipient":"someone-other-address","amount": 5}'"http://localhost:5000/transactions/new"

在挖了两次矿之后,就有 3 个块了,通过请求 http://localhost:5000/chain 可以得到所有的块信息。


        

{"chain": [ {"index":1,"previous_hash":1,"proof":100,"timestamp":1506280650.770839,"transactions": [] }, {"index":2,"previous_hash":"c099bc...bfb7","proof":35293,"timestamp":1506280664.717925,"transactions": [ {"amount":1,"recipient":"8bbcb347e0634905b0cac7955bae152b","sender":"0"} ] }, {"index":3,"previous_hash":"eff91a...10f2","proof":35089,"timestamp":1506280666.1086972,"transactions": [ {"amount":1,"recipient":"8bbcb347e0634905b0cac7955bae152b","sender":"0"} ] } ],"length":3}

3. 一致性(共识)

我们已经有了一个基本的区块链可以接受交易和挖矿,但是区块链系统应该是分布式的。

既然是分布式的,那么我们究竟拿什么保证所有节点有同样的链呢?这就是一致性问题,我们要想在网络上有多个节点,就必须实现一个一致性的算法。

(1)注册节点

在实现一致性算法之前,我们需要找到一种方式让一个节点知道它相邻的节点。

每个节点都需要保存一份包含网络中其他节点的记录,因此让我们新增几个接口:

  • /nodes/register 接收 URL 形式的新节点列表。

  • /nodes/resolve 执行一致性算法,解决任何冲突,确保节点拥有正确的链。

我们修改下 Blockchain 的 init 函数并提供一个注册节点方法:


        

...fromurllib.parseimporturlparse...classBlockchain(object):def__init__(self):... self.nodes = set() ...defregister_node(self, address):""" Add a new node to the list of nodes :param address: Address of node. Eg. 'http://192.168.0.5:5000' :return: None """ parsed_url = urlparse(address) self.nodes.add(parsed_url.netloc)

我们用 set 来储存节点,这是一种避免重复添加节点的简单方法。

(2)实现共识算法

前面提到,冲突是指不同的节点拥有不同的链,为了解决这个问题,规定最长的、有效的链才是最终的链,换句话说,网络中有效最长链才是实际的链。

我们使用以下的算法,来达到网络中的共识:


        

...import requestsclassBlockchain(object)...defvalid_chain(self, chain):""" Determine if a given blockchain is valid :param chain: A blockchain :return: True if valid, False if not """ last_block = chain[0] current_index =1whilecurrent_index < len(chain): block = chain[current_index] print(f'{last_block}') print(f'{block}') print(" ----------- ")# Check that the hash of the block is correctifblock['previous_hash'] !=self.hash(last_block):returnFalse# Check that the Proof of Work is correctifnotself.valid_proof(last_block['proof'], block['proof']):returnFalse last_block = block current_index +=1returnTruedefresolve_conflicts(self):""" 共识算法解决冲突 使用网络中最长的链. :return: True 如果链被取代, 否则为False """ neighbours =self.nodes new_chain = None# We're only looking for chains longer than oursmax_length = len(self.chain)# Grab and verify the chains from all the nodes in our networkfornodeinneighbours:response = requests.get(f'http://{node}/chain')ifresponse.status_code ==200: length = response.json()['length'] chain = response.json()['chain']# Check if the length is longer and the chain is validiflength > max_lengthandself.valid_chain(chain): max_length = length new_chain = chain# Replace our chain if we discovered a new, valid chain longer than oursifnew_chain:self.chain = new_chainreturnTruereturnFalse

第一个方法 valid_chain() 用来检查是否是有效链,遍历每个块验证 hash 和 proof。

第二个方法 resolve_conflicts() 用来解决冲突,遍历所有的邻居节点,并用上一个方法检查链的有效性, 如果发现有效更长链,就替换掉自己的链。

让我们添加两个路由,一个用来注册节点,一个用来解决冲突。


        

@app.route('/nodes/register', methods=['POST'])defregister_nodes(): values = request.get_json() nodes = values.get('nodes')ifnodes isNone:return"Error: Please supply a valid list of nodes",400fornodeinnodes:blockchain.register_node(node) response = {'message':'New nodes have been added','total_nodes': list(blockchain.nodes), }returnjsonify(response),201@app.route('/nodes/resolve', methods=['GET'])defconsensus(): replaced = blockchain.resolve_conflicts()ifreplaced:response = {'message':'Our chain was replaced','new_chain': blockchain.chain }else:response = {'message':'Our chain is authoritative','chain': blockchain.chain }returnjsonify(response),200

你可以在不同的机器运行节点,或在一台机机开启不同的网络端口来vwin 多节点的网络。

这里在同一台机器开启不同的端口演示,在不同的终端运行以下命令,就启动了两个节点:

  • http://localhost:5000

  • http://localhost:5001


        

pipenvrunpythonblockchain.pypipenvrunpythonblockchain.py-p5001

然后在节点 2 上挖两个块,确保是更长的链,然后在节点 1 上访问接口 /nodes/resolve,这时节点 1 的链会通过共识算法被节点 2 的链取代。

好啦,你可以邀请朋友们一起来测试你的区块链。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表德赢Vwin官网 网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • python
    +关注

    关注

    53

    文章

    4748

    浏览量

    83953
  • 区块链
    +关注

    关注

    110

    文章

    15558

    浏览量

    105115

原文标题:看完此文再不懂区块链算我输:手把手教你用Python从零开始创建区块链

文章出处:【微信号:magedu-Linux,微信公众号:马哥Linux运维】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    [下载]教你用Protel ***的抄板功能

    教你用Protel ***的抄板功能下载地址:http://www.ctpcb.cn/read.php?tid-8329199.html
    发表于09-25 09:28

    社区看区块发展

    在其基础上 创建社群与组织,构成了 相对开放的的生态系统。 区块 技术正是起源于这样的网络社区组织。2008年11月1日,
    发表于01-04 13:32

    什么是区块区块有什么

    的分布式账本数据库,没有中心,数据存储的每个节点都会同步复制整个账本,信息透明难以篡改。  近几年,越来越多的机构 开始重视并参与 区块 技术研发。 最初的比特币、以太坊,到各种类型的
    发表于03-26 11:31

    SHA在区块中的应用

    )基于 区块中所有交易的256位Hash值接受 交易时32 [/tr] [tr=transparent]Time(时间戳)
    发表于03-30 22:20

    区块技术对诸多行业的冲击

    了很多颠覆性的改变。   区块 去中心化的分布式数据库账本技术,有 一个一个区块组成,
    发表于12-07 14:45

    现在是时候让汽车高管们开始使用区块

    区块 创建条不变的审计线索包括相应的数据,以提供 矿山到终端制造商生产钴的证据。除了零部件的可追溯性外,汽车公司也越来越需要能够跟踪软
    发表于01-30 23:32

    企业结合区块创建区块技术落地应用有什么特色

    操作都会使得账册状态发生改变,比如增加 条记录;(2) 区块(Block):记录某段时间内发生的所有交易和状态结果,是对当前账本状态的 次共识;(3) (Chain):由
    发表于12-19 11:30

    区块+全球50案例看区块的应用与未来》高清pdf

    区块 + 全球50 案例看 区块 的应用与未来》高清pdf百度网盘链接: https://pan
    发表于03-13 00:42

    区块分成两部分,一个区块一个

    区块 技术把共享账本(类似分布式数据库)中需要存储的数据分成了不同的 区块,每个 区块通过特定的信息链接到上 一区块的后面,前后按时间顺序连接起来
    发表于03-20 08:55

    教你用热像仪检测锂电池

    教你用热像仪检测锂电池
    发表于02-07 13:26 13次下载

    教你用Zview拟合交流阻抗谱

    教你用Zview拟合交流阻抗谱(稳压电源技术参数)- 教你用Zview拟合交流阻抗
    发表于08-31 13:03 7次下载
    <b class='flag-5'>一</b>步<b class='flag-5'>一</b>步<b class='flag-5'>教你用</b>Zview拟合交流阻抗谱

    0开始创建AWTK应用程序】开发及调试环境搭建

    AWTK是基于C语言开发的跨平台GUI框架。本系列文章介绍如何 0 开始创建AWTK应用程序,包括搭建开发调试环境、使用AWTK 创建Hello工程并在模拟器上运行、将AWTK应用程序移植
    的头像 发表于11-11 10:00 497次阅读
    【<b class='flag-5'>从</b><b class='flag-5'>0</b><b class='flag-5'>开始创建</b>AWTK应用程序】开发及调试环境搭建

    0开始创建AWTK应用程序】创建应用程序并在模拟器运行

    AWTK是基于C语言开发的跨平台GUI框架。本系列文章介绍如何 0 开始创建AWTK应用程序,包括搭建开发调试环境、使用AWTK 创建Hello工程并在模拟器上运行、将AWTK应用程序移植
    的头像 发表于12-01 08:24 338次阅读
    【<b class='flag-5'>从</b><b class='flag-5'>0</b><b class='flag-5'>开始创建</b>AWTK应用程序】<b class='flag-5'>创建</b>应用程序并在模拟器运行

    0开始创建AWTK应用程序】编译应用到嵌入式Linux平台运行

    AWTK是基于C语言开发的跨平台GUI框架。本系列文章介绍如何 0 开始创建AWTK应用程序,包括搭建开发调试环境、使用AWTK 创建Hello工程并在模拟器上运行、将AWTK应用程序移植
    的头像 发表于12-07 12:08 502次阅读
    【<b class='flag-5'>从</b><b class='flag-5'>0</b><b class='flag-5'>开始创建</b>AWTK应用程序】编译应用到嵌入式Linux平台运行

    0开始创建AWTK应用程序】编译应用到RTOS平台

    AWTK是基于C语言开发的跨平台GUI框架。本系列文章介绍如何 0 开始创建AWTK应用程序,包括搭建开发调试环境、使用AWTK 创建Hello工程并在模拟器上运行、将AWTK应用程序移植
    的头像 发表于03-21 08:23 418次阅读
    【<b class='flag-5'>从</b><b class='flag-5'>0</b><b class='flag-5'>开始创建</b>AWTK应用程序】编译应用到RTOS平台