如果你打算使用比特币或Liquid开发软件,有几个概念你需要熟悉。本文以开发人员为目标,基于我过往在实现区块链钱包开发项目经验所做的一次演示。
**免责声明:这是一个介绍,并没有涵盖所有内容,因此我故意简化了一些解释。
什么是比特币,比特币其实是基于分布式账本技术:区块新看点:什么是分布式账本技术?
简单来说
比特币以后台进程守护程序的形式出现。主要由以下组件组成:
区块链:交易的分布式分类账
共识协议:一种具有PoW共识的对等网络
钱包:管理资金的工具
脚本:一种用于说明事务行为的编程语言
API:与比特币节点交互的RPC接口
我们将讨论这些概念,我将在这些主题的基础上添加一些其他重要的概念。
区块链
本质上,比特币区块链是一个链接列表,其中一个节点有一个到其父节点的链接。
三亚市中级人民法院依法审理一起以“区块链技术”为幌子的案:近日,三亚市中级人民法院依法审理一起案,以犯组织、领导活动罪,分别判处被告人彭某玲、王某民有期徒刑6年和5年,分别处罚金2万元。2018年8月,吴某芮、刘某(二人均另案处理)等人策划开展Astar集资项目,后吴某芮找到陈某某(另案处理)合作推广该项目。陈某某等人以“区块链技术”为幌子,拉人头式推广虚拟货币“星群币”,同时以报销机票,免费旅游、住宿、饮食为噱头,以高额返利为诱饵吸引被害人投资Astar项目。经海口中天华信会计师事务所鉴定,集资数额共计4962195.27元;经福建中证司法鉴定中心鉴定:彭某玲组织参与活动人员428人,下线会员层级共25层;王某民组织参与活动人员427人,下线会员层级21层。(海南特区报)[2021/1/7 16:38:16]
比特币区块结构
节点也包含以下信息:
一个Merkle树索引并包含事务;
一个时间戳,用于说明区块被添加到区块链的时间;
在采矿过程中被操纵的暂时状态。
比特币区块中还有更多信息,但这些是最基本的。
UTXOs
在研究共识协议之前,我认为理解比特币中使用的交易模型和UTXO的概念很重要。
声音 | 百慕大总理:区块链共识大会上的交流有助于吸引大型公司对百慕大长期投资:据businesswire消息,百慕大总理David Burt最近在接受采访时,强调了该岛全球知名的金融科技业务监管和法律框架,其政府和行业专家代表团已连续第二年参加纽约区块链共识大会。此次会议包括IBM,德勤等主要赞助公司,以及微软,花旗,RBC和eBay等与会公司。他表示,“我们利用这个机会与财富管理行业的领先公司会面,讨论在百慕大开展长期投资的机会,讨论取得了丰硕成果,可以用来继续改善我们不断发展的财富管理服务。”百慕大目前已经完成了加密资产商业立法,建立了专门的金融科技部门,监管沙箱,BMA创新中心。[2019/5/16]
交易示例
在一次传输中,输入的和总是等于输出的和,如上面的例子所示。
UTXO代表未使用的交易输出。这是你可以花费的实际资金,被视为投入。
在本例中,Alice将0.5BTC发送给Bob,并将其余的发送回她。为了最大限度地保护隐私,输入的其他所有者通常会被发送回另一个不同于原始UTXO的地址,称为“更改地址”。
您可以使用多个UTXO作为输入为交易提供资金。
共识协议
共识协议旨在确保比特币资金的安全,并验证真相的来源。
为了做到这一点,比特币节点是对等网络的一部分,在区块链中添加块的权利以某种方式是随机的。
动态 | LV母公司正在计划使用区块链技术追踪奢侈品:据CoinDesk消息,路易威登(Louis Vuitton)母公司LVMH正在计划使用区块链技术追踪奢侈品。据悉,LVMH已招募了一个区块链团队,研发AURA区块链平台,预计将在5月或6月与其另一个品牌Parfums Christian Dior同时上线,随后将拓展到LVMH的其它60多个品牌,最终将支持竞争队手的品牌。AURA将提供奢侈品的真实性证明,从原产地的原材料一直追溯到销售点,再到二手货市场的全过程。[2019/3/26]
达成共识的两个步骤是:
向网络发送交易信号时
广播交易的比特币节点的直接对等方将评估交易,如果交易有效,则将其添加到其mempool中,并继续传播信息。
向网络提交新块时
提交区块的比特币节点的直接对等方将评估区块,如果区块有效,则将其附加到其区块链中,并将其广播给其他对等方。
mempool
mempool是一个固定大小的缓冲区,用于记录挂起的事务。每个比特币节点都有自己的mempool实例,通过对等网络进行同步。
请注意,如果mempool已满,费用最低的交易将开始取消。
因为它是一个有限大小的缓冲区,所以您与其他进行交易的人竞争。因此,交易包括费用。你可以调整这个费用,以增加你在一个区块内快速被记录的机会。你支付的费用越高,矿商就必须在你的交易中包含越多的利息,以使他们的收益最大化。
韩国通讯公司KT为基于区块链的电子文书管理系统(EDMS)开发与韩国IT公司Inzent达成合作:韩国通讯公司KT为基于区块链的电子文书管理系统(EDMS)开发与韩国IT公司Inzent达成合作。此系统是可以把数据存在区块链,并且附加KT自主开发的技术来管理电子文书与文稿。[2018/5/25]
采矿和工作证明
为了获得向区块链添加块的权利,比特币节点使用工作证明的概念。
在比特币网络上,每个节点上都有一个被称为难度的变量。该变量对应于挖掘难度。为了获得附加块的权利,我们的目标是在比特币守护进程提供的块模板中尝试不同的nonce,直到哈希值低于根据难度推断的特定目标哈希值。
通过查看块的散列可以看到它,例如:
在区块2,难度为1,区块散列:000000006A625F06636B8BB6AC7B960A8D03705D1ACE08B1A19DA3FDCC99DDBD,
在718023块,难度为24371874614345,块哈希为000000000000024D244993522537474AF74E93C4C50553C1EC747375953。
难度越高,找到块的机会越小,目标数就越小,因此前导零的数量就越多。
在第一个街区,难度是1。每2016个街区,难度会上下调整,以确保我们平均每10分钟获得一次街区。因为这种尝试nonce和散列的操作实际上是可预测的。
22个欧盟国家签署协议建立欧洲区块链联盟:外媒消息,欧盟委员会在一份声明中宣布,共有22个欧盟国家在周二签署了一份协议以建立欧洲区块链联盟。该联盟将成为成员国在区块链技术和监管领域交流经验和传播专业知识的平台,并为启动欧盟范围内区块链技术应用做准备。欧盟委员会强调,这一行动将促使欧洲继续在区块链技术的发展和应用方面发挥主导作用。[2018/4/11]
网络分裂
最后一个有趣的注意事项是网络对网络分裂的反应。想象一下,一个恶意的国家在其边境切断互联网。还阻止了所有比特币矿商。一开始,难度太高,他们无法每10分钟找到一个街区,甚至根本找不到任何街区。然后,网络会将难度调整到一个与过去两周的哈希率相匹配的低值。
那一刻,也许困难又回到了1。如果他们重新启动所有比特币矿工,那么他们不仅会每10分钟验证一次区块,还可能每秒钟或更短时间验证一次区块。很快,他们的国内比特币区块链将超过世界其他地区的区块链高度。如果他们开放互联网边界会发生什么?好吧,他们抹去区块链的所有努力都将被粉碎。
因为比特币会同意,一条真正的区块链是最长、工作最多的链。因此,提前准备了X个区块但减少了Y个区块的国内供应链将很快被世界其他地区的供应链所取代,这些供应链的区块更少,但投入的工作更多。
钱包
比特币使用的是一种被称为分层确定钱包的东西。
BIP32分层锭性钱包
钱包的目标是:简化资金和UTXO的管理。比特币节点将通过对金额最高的UTXO进行优先级排序,自动为您的交易提供资金,而不是操纵粒度较小的UTXO。
我们从一个初始种子创建一对公钥和私钥。
可以派生这些密钥,以获取子密钥。
最初,人们认为这种衍生可能管理多个账户和多枚硬币。实际上,你的钱包里通常不会混装硬币,但以太坊也可能使用高清钱包。
拥有多个帐户的第一个用例是更改地址。这样,您就可以确保您为接收付款而动态生成的地址不会与更改地址重叠。最大限度地保护隐私。
多重签名钱包
钱包也可以在多个所有者之间共享,我们称之为多重签名钱包。
多重签名钱包
上述:Justin、Vittie和Craig各自持有打开multisig钱包所需的三把钥匙中的一把。
多重签名钱包有两个主要使用案例:
多人共享资金。想象一下,一家公司拥有一堆比特币,比如加密交易所,拥有一个多重签名钱包,可以确保如果有人不在,团队中的其他人可以访问这些资金。
真实例子:
首席执行官突然去世后,一家加密货币交易所可能损失了1.45亿美元
把你的钱包备份一下。想象一下,你可以在电脑、手机上有一个签名,而在旧设备上隐藏第三个签名。如果您丢失了任何一台设备,那么您仍然有机会访问您的资金并将其转移到新的钱包中。
拥有多个账户有助于拆分余额,以管理不同的预算。
脚本
比特币提供了一种简单的基于堆栈的编程语言,非图灵完全。下面是比特币维基页面上的一个例子。
来源:比特币维基
由于这种语言,比特币有时被称为可编程货币。
它描述了应该如何验证UTXOs。
我想请您阅读比特币维基上的一些脚本示例,以快速理解该语言的本质
仅供参考,操作码OP_RETURN可用于在区块链上留下信息。
API
为了与比特币守护进程交互,它公开了一个RPC接口。这就是比特币CLI工具所使用的,但您也可以使用curl或任何HTTP客户端与比特币节点通信。
来源:bitcoinBillions项目组com/bitcoin/bips
这就是开发者社区达成共识的地方。
我们现在所知道的定义钱包的BIP示例:
BIP32githubBillions项目组com/bitcoin/bips/blob/master/bip-004..
讨论中的BIP之一将被纳入比特币的下一个主要版本:
BIP119github#com/bitcoin/bips/blob/master/bip-011..
结论
从2022年开始,再过几年,如果你理解了那篇文章中引用的所有概念,你就足够好了,可以开始使用比特币进行开发。
根据你将使用或使用比特币的哪一部分,以下是一些你应该从哪里开始挖掘的提示:
关于采矿,区块包含的信息比我引用的要多,
关于事务和脚本,有不同类型的事务使用脚本:p2sh、p2pkh、p2wpkh,但也有一个有趣的东西叫做HashedTimeLockContract,
关于钱包,你可能想看看Taproot的最新更新,它允许多签名钱包拥有更多隐私,
更普遍的是,Lightning是比特币支付结算解决方案的第二层,Liquid是比特币的一个侧链,包含机密交易和资产发行。
-END-
重要声明:本文部分观点来源引用和转载,非全部为笔者观点,所以转载本文时请备注清楚为“区块新看点-行业整理分析报告”!本文笔者:区块新看点-程伟,未经区块新看点授权允许,请勿转载,谢谢!,谢谢关注和分享!
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。