[北大肖臻-区块链技术与应用笔记]第七节课——BTC mining

2023-10-31 06:10

本文主要是介绍[北大肖臻-区块链技术与应用笔记]第七节课——BTC mining,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

[北大肖臻-区块链技术与应用笔记]第七节课——BTC mining

文章目录

  • [北大肖臻-区块链技术与应用笔记]第七节课——BTC mining
    • 一、BTC中的节点
      • 全节点
      • 轻结点
    • 二、mining
      • 注意事项
      • 设备
        • 第一代设备:CPU
        • 第二代设备:GPU
        • 第三代挖矿设备:ASIC芯片
      • 大型矿池
        • 矿工无法独吞出块奖励
        • 矿池危害
    • 参考资料

一、BTC中的节点

全节点

1️⃣ 一直在线

2️⃣ 在本地硬盘上维护完整的区块链信息

3️⃣ 在内存中维护UTXO集合,以便快速检验交易的正确性

4️⃣ 监听比特币网络上的交易信息,验证每个交易的合法性

5️⃣ 监听别的矿工挖出的区块,验证其合法性:

区块中的每个交易都要合法(包括铸币交易及其出块奖励)

发布的区块是不是符合难度要求、难度目标阈值的设置是否正确、每两周调整的挖矿难度

区块是在延伸最长合法链

6️⃣ mining:

决定沿着哪条链挖下去

决定哪些交易被打包进区块

决定当出现等长分叉时选择哪个分叉(缺省情况是选择最先接收到的区块的分叉)

轻结点

1️⃣ 不是一直在线

2️⃣ 不用保存完整区块链,只要保存每个区块块头(大小比全节点小的很多)

3️⃣ 不用保存全部交易,只需要保存和自己相关的交易

4️⃣ 没法验证大多数交易的合法性,只能检验与自己相关的交易的合法性

5️⃣ 无法检测比特币网络上发布的区块的正确性

6️⃣ 可以验证挖矿的难度(因为挖矿时候计算哈希值只用到了块头信息)

7️⃣ 只能检测哪个是最长链,不知道哪个是最长合法链(因为无法检测这条链上所包含的交易都是合法的)

BTC中大部分节点都是轻节点,只需要交易不需要mining的话,只需要用轻结点即可

二、mining

注意事项

当在mining过程中发现新发布了一个区块,那么应该停止mining,重新取出一系列合法交易组成候选区块,在刚发布的这个区块后面开始挖矿。

因为一方面这个区块中的交易可能和刚刚在挖的那个区块有重复,另一个本质的原因就是候选区块的块头有指向前一个区块的哈希指针。因为最新的区块已经变了,这个哈希指针也要跟着改变。

挖矿具有无记忆性(memoryless | progress free)——无论是在刚刚的区块上继续挖,还是新组装一个区块继续挖,成功的概率是一样的。

BTC中的安全性由密码学保证以及由共识机制保证,没有私钥就无法转走BTC,前提是拥有大多数算力的节点要保持诚实。

设备

通用->专用

第一代设备:CPU

大部分内存闲置、不划算

第二代设备:GPU

主要用于大规模并行计算,但是其中用于浮点计算的部件还是没有使用,还是不划算

第三代挖矿设备:ASIC芯片

ASIC即Application Specific Integrated Circuit,这之中有专门为了挖矿而设计的芯片,没有多余的电路,干不了别的事,它的性价比是最高的,而且为某一种加密货币设计的ASIC芯片只能挖这一种加密货币的矿,除非两个货币用同一个mining puzzle。

研发周期长,风险大

为了让通用计算机也能参与挖矿过程,抗ASIC芯片化,有些加密货币采用Alternative mining puzzle,以去对抗那些只为了解决特定mining puzzle而设计出来的ASIC矿机。

大型矿池

image-20220612161056141

单个矿工挖矿的收益是很不稳定的,平均出块时间10分钟是对于比特币系统中的所有矿工而言的。一个矿工用一个矿机挖出矿的时间可能要很久,并且除了挖矿之外还要承担全结点的其它责任。

矿池将很多矿工组织起来,一般的架构就是一个矿主(pool manager)全结点去驱动很多矿机,下属矿工只负责计算哈希值,全结点的其它职能只由矿主来承担。有了收益以后再大家一起分配。

image-20220612160202719

如果矿机来自不同机构,这时候矿工很可能分布在世界各地,只是都加入了这个矿池。矿工和矿主联系,矿主将要计算的哈希值的任务分配给他,矿工计算好后将结果发给矿主,最终得到出块奖励后一起参与分红。

每个矿工单打独斗之所以收入不稳定,是因为挖矿难度太大了(相比比特币系统的平均出块区间),所以可以考虑矿池将挖矿的难度降下来。比如本来要求前面有70个0,现在矿池只要求前面有60个0,这样挖到的是一个share(almost valid block),即这个区块差不多在一定程度上是符合难度要求的。

矿工挖到这样的区块之后,将其提交给矿主,矿主拿到这些区块并没有什么用,仅仅是因为目标空间是这个问题的解空间的子集,并且求解两个问题的过程是一样的(都是计算哈希),因此这些区块可以作为证明矿工所做的工作量的证明。等到某个矿工真正挖到矿,获取出块奖励之后,再按照提交的share的多少来进行分配。——工作量证明。

矿工无法独吞出块奖励

每个矿工的任务是由矿主来分配的,矿主负责组装好区块,然后交给矿工去不断尝试nonce和CoinBase transaction中的extra nonce,有可能就是划分一下,然后分配给不同的矿工去做,要注意铸币交易CoinBase transaction中的收款人地址是矿主的地址,不是任何一个矿工的地址。

如果自己把铸币交易的地址改成自己的,然后去挖矿,这样提交上去的share矿主是不认可的,所以还是没有用。

矿池危害

如果没有矿池,如果要发动51%攻击,攻击者要花费大量的硬件成本。有了矿池以后,矿池实际上将算力集中了起来,攻击者未必拥有很多算力,只要吸引大量的不明真相的群众将算力集中到自己的矿池就可以。

假设有矿池占据了半数以上的算力,能够发动下面这些攻击:

1️⃣ 分叉攻击

交易对矿工来说是不知道的,他们的算力可能被矿主利用产生分叉攻击

2️⃣ Boycott

假设攻击者不喜欢某个账户A,不允许和A有关的所有交易上链。这时如果有人发布了含有和A有关的交易的区块,它可以很快发布一个不包含这些交易的区块,然后不必等候6个确认区块,立即发布到比特币网络上竞争最长合法链

这里不必等候的原因是,之前普通分叉攻击等候几个确认区块只是为了让收款人认为已经没问题了,已经成功收款了,这里没有这种顾虑。

参考资料

1、【区块链学习笔记】7:比特币中的挖矿

这篇关于[北大肖臻-区块链技术与应用笔记]第七节课——BTC mining的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/313360

相关文章

Java中的Lambda表达式及其应用小结

《Java中的Lambda表达式及其应用小结》Java中的Lambda表达式是一项极具创新性的特性,它使得Java代码更加简洁和高效,尤其是在集合操作和并行处理方面,:本文主要介绍Java中的La... 目录前言1. 什么是Lambda表达式?2. Lambda表达式的基本语法例子1:最简单的Lambda表

Python结合PyWebView库打造跨平台桌面应用

《Python结合PyWebView库打造跨平台桌面应用》随着Web技术的发展,将HTML/CSS/JavaScript与Python结合构建桌面应用成为可能,本文将系统讲解如何使用PyWebView... 目录一、技术原理与优势分析1.1 架构原理1.2 核心优势二、开发环境搭建2.1 安装依赖2.2 验

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

SpringShell命令行之交互式Shell应用开发方式

《SpringShell命令行之交互式Shell应用开发方式》本文将深入探讨SpringShell的核心特性、实现方式及应用场景,帮助开发者掌握这一强大工具,具有很好的参考价值,希望对大家有所帮助,如... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

MySQL 分区与分库分表策略应用小结

《MySQL分区与分库分表策略应用小结》在大数据量、复杂查询和高并发的应用场景下,单一数据库往往难以满足性能和扩展性的要求,本文将详细介绍这两种策略的基本概念、实现方法及优缺点,并通过实际案例展示如... 目录mysql 分区与分库分表策略1. 数据库水平拆分的背景2. MySQL 分区策略2.1 分区概念

Spring Shell 命令行实现交互式Shell应用开发

《SpringShell命令行实现交互式Shell应用开发》本文主要介绍了SpringShell命令行实现交互式Shell应用开发,能够帮助开发者快速构建功能丰富的命令行应用程序,具有一定的参考价... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定义S

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

C语言函数递归实际应用举例详解

《C语言函数递归实际应用举例详解》程序调用自身的编程技巧称为递归,递归做为一种算法在程序设计语言中广泛应用,:本文主要介绍C语言函数递归实际应用举例的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录前言一、递归的概念与思想二、递归的限制条件 三、递归的实际应用举例(一)求 n 的阶乘(二)顺序打印

SpringBoot3实现Gzip压缩优化的技术指南

《SpringBoot3实现Gzip压缩优化的技术指南》随着Web应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈,为了减少数据传输量,提高用户体验,我们可以使用Gzip压缩HTTP响应,... 目录1、简述2、配置2.1 添加依赖2.2 配置 Gzip 压缩3、服务端应用4、前端应用4.1 N