热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

1。区块链发展与现状视频地址:https://www.imooc.com/video/17452 
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

技术分享图片


推荐阅读
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • Android Studio Bumblebee | 2021.1.1(大黄蜂版本使用介绍)
    本文介绍了Android Studio Bumblebee | 2021.1.1(大黄蜂版本)的使用方法和相关知识,包括Gradle的介绍、设备管理器的配置、无线调试、新版本问题等内容。同时还提供了更新版本的下载地址和启动页面截图。 ... [详细]
  • MACElasticsearch安装步骤及验证方法
    本文介绍了MACElasticsearch的安装步骤,包括下载ZIP文件、解压到安装目录、启动服务,并提供了验证启动是否成功的方法。同时,还介绍了安装elasticsearch-head插件的方法,以便于进行查询操作。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 解决Cydia数据库错误:could not open file /var/lib/dpkg/status 的方法
    本文介绍了解决iOS系统中Cydia数据库错误的方法。通过使用苹果电脑上的Impactor工具和NewTerm软件,以及ifunbox工具和终端命令,可以解决该问题。具体步骤包括下载所需工具、连接手机到电脑、安装NewTerm、下载ifunbox并注册Dropbox账号、下载并解压lib.zip文件、将lib文件夹拖入Books文件夹中,并将lib文件夹拷贝到/var/目录下。以上方法适用于已经越狱且出现Cydia数据库错误的iPhone手机。 ... [详细]
  • [翻译]微服务设计模式5. 服务发现服务端服务发现
    服务之间需要互相调用,在单体架构中,服务之间的互相调用直接通过编程语言层面的方法调用就搞定了。在传统的分布式应用的部署中,服务地 ... [详细]
  • 后台自动化测试与持续部署实践
    后台自动化测试与持续部署实践https:mp.weixin.qq.comslqwGUCKZM0AvEw_xh-7BDA后台自动化测试与持续部署实践原创 腾讯程序员 腾讯技术工程 2 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 无损压缩算法专题——LZSS算法实现
    本文介绍了基于无损压缩算法专题的LZSS算法实现。通过Python和C两种语言的代码实现了对任意文件的压缩和解压功能。详细介绍了LZSS算法的原理和实现过程,以及代码中的注释。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 一面自我介绍对象相等的判断,equals方法实现。可以简单描述挫折,并说明自己如何克服,最终有哪些收获。职业规划表明自己决心,首先自己不准备继续求学了,必须招工作了。希望去哪 ... [详细]
author-avatar
多米音乐_35794462
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有