博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
从道法术三个层面理解区块链:术
阅读量:6263 次
发布时间:2019-06-22

本文共 3067 字,大约阅读时间需要 10 分钟。

hot3.png

image

区块链对当下的大家来说,都还是盲人摸象的阶段,所以经常群里有各种争论,归结起来,都是有的摸到了大腿,有的摸到了耳朵,相互之间就难以说服对方。

image

各自有各自的认知

笔者尝试从道法术这三个层面来解读下区块链,以便让大家有个更全面的了解,也知道自己的认知的针对性实际是什么。

区块链首先是区块链技术,这也几乎构成了区块链在术部分的全部。 也构成了道和法的基础。离开术来空谈道和法,是不够脚踏实地的,而是空中楼阁。据传,三点钟群如果谈论技术的话,会被踢出群的,这就暴露了大佬们在技术上的虚弱。

我们先来说说区块链的鼻祖比特币用到的计算机技术:

  • 1929年的逆波兰表达式

  • 1970年的布隆过滤器bloom filter

  • 1989年的默克尔merkle树

  • 1999年的椭圆曲线数字签名算法

  • 2000年的p2p网络

  • 2001年的sha-256(还有别的,不写了)

  • 2009年的blockchain(首创)

今年接近90岁的逆波兰表达式构成了比特币的加锁和解锁脚本的栈式执行。比特币的加锁和解锁脚本使得比特币可以支持非常灵活和多样的交易形式,保证交易(bond transaction),返还交易(refund transaction),担保交易,多重签名等。

70后的布隆过滤器(bloom filter)来了,Bloom filter可以在一个有很多元素的集合中高效判断元素是否属于该集合,元素属于该集合的不会误判,元素不属于该集合的会有小概率误判。比特币的轻钱包需要用瘦客户端模式实现的钱包,因为不存储完整区块链,就涉及到如何获取UTXO的问题。比特币就是用布隆过滤器(Bloom filter)在快速检索并返回相关数据的节点

80后的默克尔merkle树可以高效地比对大文件在传输过程中是否有出错或改动,同时还能高效地定位出大文件是哪一个的片段出错了,从而只要重新更新该片段即可。比特币用merkle树来将块中的所有交易作为树的叶节点,来实现块的交易数据的准确高效传输,并把merkle树根作为block header的主要数据。

90后的椭圆曲线数字签名算法正式出场了。所有发行出来的比特币都体现为未花费的交易输出UTXO,也就是目前大约是1640万枚的比特币,是呆在一堆UTXO里。那么这些UTXO理论上是无主的,每个UTXO有一个加密脚本,只要谁有办法解开,谁就可以使用这个UTXO里的比特币。一般地说,大部分的加密用公钥加密,用对应的私钥来解密。由于椭圆曲线计算的非对称性,即求乘积很容易,但求除法很困难,换成加解密的角度来说,就是知道私钥,容易算出公钥,但知道公钥,是算不出来私钥的。这样客观上保证了即使UTXO是公开的,也只有私钥持有者可以使用。

00后的p2p网络重磅登场。其实这个虽然很多人不一定深入了解它的原理,但多数人又都用过。多数人是用过BT或迅雷来下载过文件,它的背后就是p2p的网络。这一技术的发明是为了解决中心化的服务器要不断地扩容才能满足越来越多的用户请求,而且用户越多,系统越慢。p2p由于是peer2peer的,也就是下载的文件来自于全球分散的电脑里,而不是中心化的服务器,这样极大的避免了中心化的服务器的拥堵。而且,用户越多,提供下载的节点也就越多,是一个正向的反馈激励。比特币也是应用p2p网络来进行分布式计算的。每个全节点都要将广播接收来的交易校验、打包成块,并广播出去,将广播接收来的打包好的块检验后记录下来,并在其后进行新的打包成块。p2p网络也是区块链技术中最为重要的一个篇章。

sha-256等报文摘要哈希(hash)函数是为了对数据进行摘要处理,从而发现原始数据是否有被修改,哪怕是非常细微的修改。同时,hash值又可以用来做key value数据库的key,这样查询就可以非常快。比特币采用工作量证明POW(Proof of Work)作为共识算法,又把随机数加块头的一些数据来计算满足难度的双sha-256结果的计算当作工作量。POW有效地避免了公开的交易账本被修改的风险,因为要想修改,也需要足够的算力去重新计算,因为每个块都需要足够的工作量,也就是时间,所以尝试修改的人是难于在落后其他人的情况下追上其他人的。

最后是非常狭义角度的区块链。狭义是在于区块链本来只是一种数据结构,也就是最常规的链表结构,每个节点(block)都有一个指针指向前一个节点(block),由于这里采用的是块头block header的数据生成的hash来作为指针,也就天然的让任何一个块的修改,都需要这个块后面的指针全部重新计算。

**我们现在习惯的区块链技术实际是以上技术集成的总称。**可以这样来定义:**区块链(Blockchain)**是指通过去中心化和去信任的方式集体维护一个可靠数据库的技术方案。该技术方案让参与系统中的任意多个节点,把一段时间系统内全部信息交流的数据,通过密码学算法计算和记录到一个数据块(block),并且生成该数据块的指纹用于链接(chain)下个数据块和校验,系统所有参与节点来共同认定记录是否为真。

有了比特币开创的区块链技术和第一个实际应用,我们就容易理解其它区块链应用是怎么回事了。**首先呢,p2p是必不可少的,是区块链应用用来实现分布式计算的网络基础,其次要有数字签名,目前肯定是非对称加密,一般而言也会用椭圆曲线,因为这是目前最难被破解的,再就是要报文摘要hash函数。**merkle树及其变种也是主要的利器。

以太坊主要是针对比特币的脚本系统进行扩展,用虚拟机VM去替代栈式计算,用仿javascript的solidity来替代脚本语言作为智能合约的语言,以准图灵完备来代替比特币的非图灵完备。用merkle patricia树来替代merkle树。就被追捧和成为了区块链2.0. vitalik更是由此封神,并拥有价值300亿美元的eth。

从这些基础的技术展开思考,我们还可以看到采用p2p来搭建系统从技术层面上带来类似用RAID替代高可用硬盘的效果,就是可以用很low的计算机来实现高可用HA(High Availability),从而达到计算成本的降低。推而广之,就是可以不用Iaas层就可以直接开干SaaS,直接构建应用,这样就大大摆脱了对AWS和阿里云的依赖。

本文内容作者:HiBlock区块链社区**“一起写笔记”**小伙伴——星星之火待燎原

原文首发于今日头条

了解和加入“一起搞事情”请看文末详细介绍~

image

HiBlock区块链社区邀请您一起搞事情~

1、一起读代码 社区网址: 一起读代码,比如从以太坊源代码开始

2、一起写笔记 社区网址: 不积跬步无以至千里,每日写500字左右关于我对区块链的理解,或者针对某一个问题发表自己的观点,由HiBlock公众号统一筛选整理对外发布

3、一起译文档 社区网址: 英文文档、资讯有太多太多很有价值的,我们一起来做知识的搬运工吧

当前一起译团队的工作:Solidity官方文档,参考Github仓库,

4、一起磨课程 社区网址: 将专业技术知识分享给更多的人。可以是一堂课的分享,也可以是打磨一个系列课程。

如果您要报名以上哪个活动,请添加微信小助手(baobaotalk_com),然后直接回复姓名+数字【可多选,如Bob 1/2/3】

image

点击“”进入HiBlock“搞事情”的GitHub页面~

转载于:https://my.oschina.net/u/3782027/blog/1797018

你可能感兴趣的文章
c#迭代器 转载
查看>>
JQuery与JavaScript
查看>>
Jmeter--正则表达式提取器
查看>>
设置Slider Control 控件的取值范围
查看>>
struts2 启动tomcat时报错:org.apache.catalina.core.StandardContext filterStart
查看>>
asp.net导入后台代码
查看>>
java web dev知识积累
查看>>
Flex 经纬度匹配正则表达式
查看>>
在SSIS包中使用 Checkpoint从失败处重新启动包[转]
查看>>
为什么开通博客?
查看>>
深入浅出Mybatis系列(四)---配置详解之typeAliases别名(mybatis源码篇)
查看>>
LVS+Keepalived实现高可用负载均衡(转)
查看>>
Django学习【第14篇】:Django之Form组件补充
查看>>
在web.xml中配置初始化参数
查看>>
Java多线程下 ThreadLocal 的应用实例
查看>>
Serializable:序列化代理
查看>>
SQL中表约束是什么意思
查看>>
JS中小数的差,比较大小
查看>>
堆数据结构
查看>>
codeforces / project Euler 泛做
查看>>