阅读本文需要以下知识储备
1、理解区块链的基本原理
2、了解智能合同和共识机制概念
我很好奇,在区块链的网络体系下,如何与外部世界(传统互联网系统)进行数据交换,简而言之,区块链体系内的智能合同如何与传统互联网系统进行数据共享和交换?
假设在区块链体系的租房APP上,租客与房东达成了租赁协议,其中有一个智能合同规定,在退房时,如果租客弄坏了客厅的小米9A电视,则需要按退房当天小米官方的价格原价赔偿。转眼到了退房的那一天,租客在APP上点击一键退房,APP自动下发指令让客厅的小米9A电视自检(确认是否损坏),因为租客在使用过程中,确实弄坏了小米电视,导致自检结果触发了智能合同中的赔偿条款,很不巧的时,当天小米天猫旗舰店正在做活动,比小米商城要便宜300元,此时智能合同赔偿金额要以哪个价格为准?
按照我们传统的思路,智能合同会发起一个外部请求给第三方小米(假设小米提供了一个外部查询接口),然后根据这个接口返回的价格,执行智能合同,但这样做会遇到以下问题:
1、由于区块链是基于共识机制的系统,假设有10000个矿工,需要矿工们对赔偿额度(小米电视9A的价格)达成一致,才能有效执行,而每个矿工的智能合同是独立执行的,这样10000个矿工就会分别向小米系统发送价格查询请求,不仅效率低下,还会形成巨大的资源浪费。
2、如果矿工的网络状况各不相同,造成延迟,一旦小米官方的价格正好有波动,就会导致矿工们获取到的价格各不相同,无法形成共识。
预言机
在上述例子中,还存在一些问题,比如第三方小米提供的数据可靠吗?会不会被恶意篡改过?为了解决这些疑问,预言机(Oracle,注意不是甲骨文数据库)的概念诞生了。预言机是一种可信任的实体,它通过签名引入关于外部世界状态的信息,从而允许确定的智能合约对不确定的外部世界作出反应。预言机具有不可篡改、服务稳定、可审计等特点,并具有经济激励机制以保证运行的动力。这样理解起来确实很烧脑,不过结合上面的例子还是很容易理解。
假设现在有一个第三方系统(预言机)可以提供权威准确、不可篡改、稳定、并可接受审计的价格查询接口,包括查询小米9A电视的价格,在执行赔偿智能合约时会自动触发该预言机,向区块链发送一笔交易,交易的数据块携带了小米电视9A的价格,随着每个矿工节点区块的同步,就保证了价格完全一致。
换一种解释,预言机整个完整的工作流程是这样的,首先预言机从小米官方获取小米9A的电视价格,然后向特定区块链上的地址进行转账,并将价格信息写入交易备注,这样智能合约只需要查看特定地址的交易记录,就可以获取小米9A的价格了。而由于区块链会自动同步存储包含交易的区块,所以智能合约几乎只需要访问本地就能得到价格信息。既保证了访问效率,又保证了价格的一致性。
总的来说就是由预言机(第三方)将数据推送给区块链,而不需要智能合约主动向第三方拉取数据。
预言机网络
在绝大部分情况下,一台预言机已经足够,但在处理重大资产时,常常一台预言机并不能保证完全可靠,有人提出了多台预言机的解决方案,比如设置5台预言机,如果其中有3台或3台以上给出的价格一致,则向区块链发起一笔携带此价格备注的交易。这种由多台单一预言机组成的多重模型又被称为预言机网络。
而这两种不同形态的预言机模型,也被分别称为单一模型和多重模型(预言机网络)。
预测市场
如果说预言机和预言机网络是数据的搬运工,那么预测市场则可以给智能合同提供未来准确的数据。
假设今天晚上在天河体育中心举行世界杯决赛,所有的直播和赛事数据都来自于CCTV5,却没有人能保证CCTV5的网站不被攻击,或者出现无法访问等各种意外情况,而一旦出现这些意外将造成严重的后果,在这种情况下,我们就可以运用预测市场的技术。
预测市场的最终数据从哪里来呢?数据来自于人,而非机器,比如那些博彩,下注,竞猜等一切与比赛结果相关,并捆绑了自身利益的人,都可以成为预测数据的提供者,因为他们捆绑了自身利益,他们不会牺牲自身利益提供虚假数据,从而有效地保证了数据的可靠性和真实性。
预测市场和预言机的功能和目的完全一致,都是为了给智能合约提供可靠的外部数据,他们的核心价值都是解决信任,促成共识,最终保证了区块链与外部世界的连接。他们提供了一个桥梁,让区块链实现了“世界那么大,我想去看看”的愿望。