[北大肖臻-区块链技术与应用笔记]第七节课——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

相关文章

MobaXterm远程登录工具功能与应用小结

《MobaXterm远程登录工具功能与应用小结》MobaXterm是一款功能强大的远程终端软件,主要支持SSH登录,拥有多种远程协议,实现跨平台访问,它包括多会话管理、本地命令行执行、图形化界面集成和... 目录1. 远程终端软件概述1.1 远程终端软件的定义与用途1.2 远程终端软件的关键特性2. 支持的

5分钟获取deepseek api并搭建简易问答应用

《5分钟获取deepseekapi并搭建简易问答应用》本文主要介绍了5分钟获取deepseekapi并搭建简易问答应用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需... 目录1、获取api2、获取base_url和chat_model3、配置模型参数方法一:终端中临时将加

JavaScript中的isTrusted属性及其应用场景详解

《JavaScript中的isTrusted属性及其应用场景详解》在现代Web开发中,JavaScript是构建交互式应用的核心语言,随着前端技术的不断发展,开发者需要处理越来越多的复杂场景,例如事件... 目录引言一、问题背景二、isTrusted 属性的来源与作用1. isTrusted 的定义2. 为

Python调用另一个py文件并传递参数常见的方法及其应用场景

《Python调用另一个py文件并传递参数常见的方法及其应用场景》:本文主要介绍在Python中调用另一个py文件并传递参数的几种常见方法,包括使用import语句、exec函数、subproce... 目录前言1. 使用import语句1.1 基本用法1.2 导入特定函数1.3 处理文件路径2. 使用ex

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

Linux中Curl参数详解实践应用

《Linux中Curl参数详解实践应用》在现代网络开发和运维工作中,curl命令是一个不可或缺的工具,它是一个利用URL语法在命令行下工作的文件传输工具,支持多种协议,如HTTP、HTTPS、FTP等... 目录引言一、基础请求参数1. -X 或 --request2. -d 或 --data3. -H 或

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

java中VO PO DTO POJO BO DO对象的应用场景及使用方式

《java中VOPODTOPOJOBODO对象的应用场景及使用方式》文章介绍了Java开发中常用的几种对象类型及其应用场景,包括VO、PO、DTO、POJO、BO和DO等,并通过示例说明了它... 目录Java中VO PO DTO POJO BO DO对象的应用VO (View Object) - 视图对象