区块链技术理念

区块链在本质上就是一种记帐方法,固然了,并非经过人来记帐的,而是经过一种 软件,咱们暂且简称为区块链客户端。以上面的例子来讲,张3、李4、王5、赵六等 人,就至关于一个个的区块链客户端软件,它们运行在不一样的设备上,彼此之间独立工 做。一般咱们把运行中的客户端软件称为“节点”。这些节点运行后,彼此之间会认识一 下。它们彼此之间是这样认识的:张三认识李四也认识王五,赵六联系到了张三,让张三 把他认识的人的联系方式发给本身,这样赵六也认识了李四和王五,经过这样的方式,大 家就造成了一张网,有什么事只要招呼一声,立马消息就会传遍整个网络节点。这种方式 跟新闻转发差很少,不须要依靠某一我的,你们就能互通消息了,在区块链软件的结构 中,这种互相通讯的功能称为“网络路由”。算法

在这个网络中,每一个节点都维护着本身的一个帐本,帐本中记录着网络中发生的一笔 笔帐务。具体是什么样的帐务呢?这得看具体是什么样的功能网络。区块链技术属于一种 技术方法,能够用来实现各类不一样的业务功能,小到如上例中的平常记帐,大到各类复杂 的商业合约,等等,记录的数据也就不一样了。网络中的节点是独立记帐的,但是记帐的内 容要保持彼此一致。所用的方法就是设定一个游戏规则,经过这个规则选出一个记帐的节 点,就如上例中的掷骰子。在区块链系统中,这个所谓的“掷骰子”称为“共识算法”,就是 一种你们都遵照的筛选方案,咱们能够先这么简单地理解。选出一个节点后,则一段时间 内的帐务数据都以这个节点记录的为准,这个节点记录后会把数据广播出去,告诉其余的 节点,其余节点只须要经过网络来接收新的数据,接收后各自根据本身现有的帐本验证一 下能不能接得上,有没有不匹配和不规范的,若是都符合要求,就存储到本身的帐本中。网络

在有些系统中,会考虑到被骰子投中的节点的劳动付出,毕竟它要负责整理数据,验 证数据,打包数据,还要再广而告之,这个活仍是挺辛苦的。因而会设计一种激励机制, 负责打包数据的那个节点能够得到系统的奖励,这个奖励相似于论坛积分,站在软件技术 的角度,就是一个数据。这个数据能够视为奖金,有时候你们会很积极地去争取那个奖 金,因而就但愿骰子能投中本身,有些区块链系统在这个环节会设计出一种带有竞争的机 制,让各个节点去抢,谁能抢到这个机会谁就能得到打包数据的权力而且同时得到这笔奖 励,在这种状况下,咱们会形象地将这个竞争的过程称为“挖矿”。区块链

那么,话又说回来了,咱们将一个个运行客户端称为节点,那到底怎么标记不一样的使 用者呢?也是经过用户名注册吗?实则否则。在区块链系统中,这个地方的设计颇有意 思,是经过一种密码算法来实现的,具体来讲是经过一种叫公开密钥算法的机制来实现 的。咱们知道,对于一种密码算法来讲,不管算法过程是什么样的,都会有一个密钥。而 公开密钥算法拥有一对(也就是两个)密钥,跟虎符同样,是彼此配合使用的,能够互相 用来加解密。其中一个叫私钥,另一个叫公钥,公钥能够公开给别人,私钥要本身保管 好。在区块链系统中,公钥就是用来用户身份识别的,通常不会直接使用公钥,由于不容 易让人记住。公钥每每都比较长,实际处理的时候都会进行转换,好比取得公钥的最后20 个字节或者通过一系列更复杂的转换,最后获得一个称为“地址”的转换结果,这个“地 址”就能表明一个用户。加密

为何在区块链系统中要用这么一个奇怪的用户身份表示方法呢?彷佛看起来除了有 些创意外,也没特别的用处。这里咱们就得再介绍下这个公开密钥算法的特别能力。以前 提到说这种算法有两个密钥,那么这两个密钥是怎么配合工做的呢?咱们来简单说明一 下:用公钥加密的数据必须用对应的私钥来解密,而用私钥加密(一般称为“签名”)的数 据必须用对应的公钥来解密。这个特色但是能发挥很大用处的,就如上述的例子中,若是 张三要发送给李四一张支票,那怎么传送呢?就这么发过去,会被那个记帐的人拿到,风 险可就大了。因而张三想了一个办法,他在支票上用李四的公钥加了个密,而后再签上自 己的名字(使用本身的私钥签名),这个时候其余人就算拿到支票也没用,由于只有李四 才有本身的私钥,也只有李四才能解开这张支票来使用。这种功能设计在区块链系统中称 为“脚本系统”。设计

如今咱们知道了,区块链的技术理念,其实就是你们共同来参与记帐,经过一种规则 不断地选出帐务打包者,其余节点接收验证,而且每一个用户都有一对密钥表示本身,经过 脚本系统的功能实如今公共网络中定向发送有价值的数据。游戏

相关文章
相关标签/搜索