001/Go语言构建区块链(mooc)

1。区块链发展与现状

视频地址:https://www.imooc.com/video/17452

 

注意:

比特币与以太坊最大的区别在于:

以太坊引入了对图灵完美智能合约的支持,人们可以将任何业务逻辑以合约的形式写入区块链,在以太坊前,发行自己的数字货币,就需要搭建一个独立的区块链网络。

比较稳定,被拿来研究的区块链系统:

【1】。超级账本

         本身不是一个完整的区块链系统,而是方便企业搭建自己的区块链框架。各个组件,如数据存储,共识算法等,都可以灵活替换与组装。对智能合约也有很好的支持。

         因此常被大型行业如银行/金融机构来构建联盟链。

【2】。以太坊

 

运行环境:

1。装好GO语言环境

2。装好IDE或自己喜欢的文本编辑器:如sublime

3。我的环境:mac + GoLand

2。什么是区块链

【1】区块链的分类:

(1)。公有链

          任何人都能读取,任何人都能发动交易,交易能够获得有效确认,任何人都能参与其共识过程的区块链。

          如比特币,以太坊,EOS。

(2)。私有链

         一般为公司或组织内使用。

        如在做区块链应用时,自己在本机上搭建的开发节点和在公司内网测试节点。

(3)。联盟链

        有竟争又需要合作的场景。技术上联盟链是指共识过程受到预选节点控制的区块链。只有准入联盟的节点才可以参与其中。

      如Fabric R3联盟 / EEA (以太坊企业联盟)/阳光链(众筹平台青龙筹)

【2】区块链解决问题:价值传递

 

【3】什么是区块链:

区块链就是一种特殊的分布式数据库

首先:区块链作用是--存储信息 (任何需要保存的数据均可以写入区块链,也可从里面读取。所以它是--数据库)

其次:任何人都可以架设服务器加入区块链网络,成为一个节点。所以它具有--分布式系统特点

区块链世界里面,没有中心节点,每个节点都是平等的。都保存了整个数据库,可向任何节点写入&读取数据。因为所有的节点都会同步。保证区块链一致。

上述:节点分布在全国各个地方,节点与节点之间相互连接。你往任何一个节点发送请求,请求数据都会快速的同步到网络上的所有节点。

说明:

【1】。没有中心,无管理员

         如此庞大的网络没有中心也没有管理员,都是通过区块链协议自管理。

【2】。全民记账

        注:记账而不是记数据 (因为区块链主要用来做价值传递,对于价值传递,重要的是可信的账本。用来记录所有的交易数据。所谓全民记账是这个账本在区块链每个节点上都有一份。每个节点都可以在遵循区块链协议的前提下,往这个账本上写入交易数据)

【3】。只能增查,不能改删

        注:在区块链上的数据操作,指的是对区块链上的交易数据进行操作,而不是最终的状态。

        我们进行转账操作时,余额变动,

【3】区块链特点:

(1)。不可攥改 :区块链只支持添加和查询,不能修改和删除 (区块链上没有404)

(2)。可追溯 :

(3)。去中心化:对数据不可攥改的保证,不能依赖于一个中心。

 

3。区块链架构模型

说明:

数据层-》网络层-》共识层-》激励层-》合约层  (共5层)一起构成区块链基础架构的核心系统。

应用层:代表基于区块链技术构建的各种应用。与区块链5个核心系统分开部署,通过远程过程调用RPC,与区块链核心系统进行交互。

【1】数据层 & 网络层 & 共识层  (构建区块链必要元素)

      A。数据层

      数据层封装了底层数据的链式结构,以及相应的非对称公私钥加密技术和时间戳技术。(整个区块链技术中最底层的数据结构)

      B。网络层

      网络层包括p2p组网机制,数据传播机制和数据验证机制等。

     C。共识层

     共识层封装了网络节点的各类共识机制算法。共识机制算法是区块链的核心技术,这决定了到底是谁来进行计算。计算方式将影响整个系统的安全性和可靠性。

     POW/EOS/DPOS/PBFP等共识算法。

【2】。激励层 (主要应用公有链)

    主要用在公有链中。必须激励遵守规则参与计算的节点。惩罚不遵守规则的节点。(私有链 & 联盟链中不一定要激励,因为参与计算的节点往往在链外就完成了博弈)

【3】。合约层

    用来封装各类脚本,算法和智能合约。是区块链可编程的基础。可简单理解为一份自定义的电子合同。并且这个合同可以在达到一定触发条件后自动执行,不需要人工干预。也可在不满足条件时自动解约。

【4】。应用层

   应用层封装了区块链的应用场景和案例。如搭建的以太坊等〜

 

4。区块链链式结构

链式结构:

链式结构最基础构成单无----区块(由区块头和区块体组成)

区块体:存储交易数据

区块头:父区块hash

问题:为什么每一个区块头都要存储上一下区块的hash值?(同一个值进行hash计算的结果是一致的。)

理解--hash函数

4。链式结构小结

注意:区块1的值有一点改动,hash值都会变化。区块2就会引用一个错误的地址。即区块链2引用的区块1的hash值无效。

区块1值的变动,会引起区块2hash值的变动。。。。依次。。。(要改动所有区块。)

 

5。构建自己的区块链

组成部分:

(一)。实现链式结构

(二)。实现一个简单的http server,对外暴露读写接口

步骤:

step1:创建block   (开发环境:GoLand)

        A。创建工程demochain

             demichain /  Block.go

        B。创建Block文件

        C。创建Block结构体与函数

结构体:

计算hash值

生成新区块

创始区块

step2:创建blockchain

视频地址:https://www.imooc.com/video/17447

A。创建blockchain文件 (Blockchain.go)

B。创建blockchain结构体与相关方法

定义blockchain结构体:

定义相关方法 (向区块链里添加区块)

 

 

验证(不是所有区块都可以添加到区块链)

step3:创建httpserver

视频地址:https://www.imooc.com/video/17448

不仅可以在本地访问也可以提供API接口访问。

包:rpc / 文件 Server.go

(三)。效果展示(3个区块链,可通过地址栏添加新的区块链)

视频地址:https://www.imooc.com/video/17445

posted @ 2018-07-01 14:12  kaixinyufeng  阅读(9199)  评论(0编辑  收藏  举报