Ⅰ 以太坊是什么丨以太坊开发入门指南
以太坊是什么丨以太坊开发入门指南
很多同学已经跃跃欲试投入到区块链开发队伍当中来,可是又感觉无从下手,本文将基于以太坊平台,以通俗的方式介绍以太坊开发中涉及的各晦涩的概念,轻松带大家入门。
以太坊是什么
以太坊(Ethereum)是一个建立在区块链技术之上, 去中心化应用平台。它允许任何人在平台中建立和使用通过区块链技术运行的去中心化应用。
对这句话不理解的同学,姑且可以理解为以太坊是区块链里的Android,它是一个开发平台,让我们就可以像基于Android Framework一样基于区块链技术写应用。
在没有以太坊之前,写区块链应用是这样的:拷贝一份比特币代码,然后去改底层代码如加密算法,共识机制,网络协议等等(很多山寨币就是这样,改改就出来一个新币)。
以太坊平台对底层区块链技术进行了封装,让区块链应用开发者可以直接基于以太坊平台进行开发,开发者只要专注于应用本身的开发,从而大大降低了难度。
目前围绕以太坊已经形成了一个较为完善的开发生态圈:有社区的支持,有很多开发框架、工具可以选择。
智能合约
什么是智能合约
以太坊上的程序称之为智能合约, 它是代码和数据(状态)的集合。
智能合约可以理解为在区块链上可以自动执行的(由事件驱动的)、以代码形式编写的合同(特殊的交易)。
在比特币脚本中,我们讲到过比特币的交易是可以编程的,但是比特币脚本有很多的限制,能够编写的程序也有限,而以太坊则更加完备(在计算机科学术语中,称它为是“图灵完备的”),让我们就像使用任何高级语言一样来编写几乎可以做任何事情的程序(智能合约)。
智能合约非常适合对信任、安全和持久性要求较高的应用场景,比如:数字货币、数字资产、投票、保险、金融应用、预测市场、产权所有权管理、物联网、点对点交易等等。
目前除数字货币之外,真正落地的应用还不多(就像移动平台刚开始出来一样),相信1到3年内,各种杀手级会慢慢出现。
编程语言:Solidity
智能合约的默认的编程语言是Solidity,文件扩展名以.sol结尾。
Solidity是和JavaScript相似的语言,用它来开发合约并编译成以太坊虚拟机字节代码。
还有长像Python的智能合约开发语言:Serpent,不过建议大家还是使用Solidity。
Browser-Solidity是一个浏览器的Solidity IDE, 大家可以点进去看看,以后我们更多文章介绍Solidity这个语言。
运行环境:EVM
EVM(Ethereum Virtual Machine)以太坊虚拟机是以太坊中智能合约的运行环境。
Solidity之于EVM,就像之于跟JVM的关系一样,这样大家就容易理解了。
以太坊虚拟机是一个隔离的环境,在EVM内部运行的代码不能跟外部有联系。
而EVM运行在以太坊节点上,当我们把合约部署到以太坊网络上之后,合约就可以在以太坊网络中运行了。
合约的编译
以太坊虚拟机上运行的是合约的字节码形式,需要我们在部署之前先对合约进行编译,可以选择Browser-Solidity Web IDE或solc编译器。
合约的部署
在以太坊上开发应用时,常常要使用到以太坊客户端(钱包)。平时我们在开发中,一般不接触到客户端或钱包的概念,它是什么呢?
以太坊客户端(钱包)
以太坊客户端,其实我们可以把它理解为一个开发者工具,它提供账户管理、挖矿、转账、智能合约的部署和执行等等功能。
EVM是由以太坊客户端提供的。
Geth是典型的开发以太坊时使用的客户端,基于Go语言开发。 Geth提供了一个交互式命令控制台,通过命令控制台中包含了以太坊的各种功能(API)。Geth的使用我们之后会有文章介绍,这里大家先有个概念。
Geth控制台和Chrome浏览器开发者工具里的面的控制台是类似,不过是跑在终端里。
相对于Geth,Mist则是图形化操作界面的以太坊客户端。
如何部署
智能合约的部署是指把合约字节码发布到区块链上,并使用一个特定的地址来标示这个合约,这个地址称为合约账户。
以太坊中有两类账户:
· 外部账户
该类账户被私钥控制(由人控制),没有关联任何代码。
· 合约账户
该类账户被它们的合约代码控制且有代码与之关联。
和比特币使用UTXO的设计不一样,以太坊使用更为简单的账户概念。
两类账户对于EVM来说是一样的。
外部账户与合约账户的区别和关系是这样的:一个外部账户可以通过创建和用自己的私钥来对交易进行签名,来发送消息给另一个外部账户或合约账户。
在两个外部账户之间传送消息是价值转移的过程。但从外部账户到合约账户的消息会激活合约账户的代码,允许它执行各种动作(比如转移代币,写入内部存储,挖出一个新代币,执行一些运算,创建一个新的合约等等)。
只有当外部账户发出指令时,合同账户才会执行相应的操作。
合约部署就是将编译好的合约字节码通过外部账号发送交易的形式部署到以太坊区块链上(由实际矿工出块之后,才真正部署成功)。
运行
合约部署之后,当需要调用这个智能合约的方法时只需要向这个合约账户发送消息(交易)即可,通过消息触发后智能合约的代码就会在EVM中执行了。
Gas
和云计算相似,占用区块链的资源(不管是简单的转账交易,还是合约的部署和执行)同样需要付出相应的费用(天下没有免费的午餐对不对!)。
以太坊上用Gas机制来计费,Gas也可以认为是一个工作量单位,智能合约越复杂(计算步骤的数量和类型,占用的内存等),用来完成运行就需要越多Gas。
任何特定的合约所需的运行合约的Gas数量是固定的,由合约的复杂度决定。
而Gas价格由运行合约的人在提交运行合约请求的时候规定,以确定他愿意为这次交易愿意付出的费用:Gas价格(用以太币计价) * Gas数量。
Gas的目的是限制执行交易所需的工作量,同时为执行支付费用。当EVM执行交易时,Gas将按照特定规则被逐渐消耗,无论执行到什么位置,一旦Gas被耗尽,将会触发异常。当前调用帧所做的所有状态修改都将被回滚, 如果执行结束还有Gas剩余,这些Gas将被返还给发送账户。
如果没有这个限制,就会有人写出无法停止(如:死循环)的合约来阻塞网络。
因此实际上(把前面的内容串起来),我们需要一个有以太币余额的外部账户,来发起一个交易(普通交易或部署、运行一个合约),运行时,矿工收取相应的工作量费用。
以太坊网络
有些着急的同学要问了,没有以太币,要怎么进行智能合约的开发?可以选择以下方式:
选择以太坊官网测试网络Testnet
测试网络中,我们可以很容易获得免费的以太币,缺点是需要发很长时间初始化节点。
使用私有链
创建自己的以太币私有测试网络,通常也称为私有链,我们可以用它来作为一个测试环境来开发、调试和测试智能合约。
通过上面提到的Geth很容易就可以创建一个属于自己的测试网络,以太币想挖多少挖多少,也免去了同步正式网络的整个区块链数据。
使用开发者网络(模式)
相比私有链,开发者网络(模式)下,会自动分配一个有大量余额的开发者账户给我们使用。
使用模拟环境
另一个创建测试网络的方法是使用testrpc,testrpc是在本地使用内存模拟的一个以太坊环境,对于开发调试来说,更方便快捷。而且testrpc可以在启动时帮我们创建10个存有资金的测试账户。
进行合约开发时,可以在testrpc中测试通过后,再部署到Geth节点中去。
更新:testrpc 现在已经并入到Truffle 开发框架中,现在名字是Ganache CLI。
Dapp:去中心化的应用程序
以太坊社区把基于智能合约的应用称为去中心化的应用程序(DecentralizedApp)。如果我们把区块链理解为一个不可篡改的数据库,智能合约理解为和数据库打交道的程序,那就很容易理解Dapp了,一个Dapp不单单有智能合约,比如还需要有一个友好的用户界面和其他的东西。
Truffle
Truffle是Dapp开发框架,他可以帮我们处理掉大量无关紧要的小事情,让我们可以迅速开始写代码-编译-部署-测试-打包DApp这个流程。
总结
我们现在来总结一下,以太坊是平台,它让我们方便的使用区块链技术开发去中心化的应用,在这个应用中,使用Solidity来编写和区块链交互的智能合约,合约编写好后之后,我们需要用以太坊客户端用一个有余额的账户去部署及运行合约(使用Truffle框架可以更好的帮助我们做这些事情了)。为了开发方便,我们可以用Geth或testrpc来搭建一个测试网络。
注:本文中为了方便大家理解,对一些概念做了类比,有些严格来不是准确,不过我也认为对于初学者,也没有必要把每一个概念掌握的很细致和准确,学习是一个逐步深入的过程,很多时候我们会发现,过一段后,我们会对同一个东西有不一样的理解。
Ⅱ DAPP与智能合约的关系
DAPP 是DecentralizedApplication的缩写,译为:分散式的应用程序。DAPP是一种互联网应用程序,与传统的APP最大的区别是:DAPP运行在去中心化的网络上,也就是区块链网络中。网络中不存在中心化的节点可以完整的控制DAPP。而APP我们都知道,是中心化的。需要请求某台服务器来获取数据,处理数据等。北京木奇移动技术有限公司,专业的区块链开发公司,欢迎交流合作。
何为智能合约?
智能合约其实是一种计算机协议,用一段计算机指令实现自我验证、自动执行,并产生可以验证的证据来证明合约操作的有效性。智能合约和传统纸质合约的区别在于智能合约是由计算机很多区块链网络使用的智能合约功能类似于自动售货机。智能合约与自动售货机类比:如果你向自动售货机(类比分类账本)转入比特币或其他加密货币,一旦输入满足智能合约代码要求,它会自动执行双方约定的义务。生成的。因此,代码本身解释了参与方的相关义务。
DAPP 与智能合约 以太坊中一般会认为智能合约就是DAPP,当然更准确的可以认为智能合约相当于服务器后台,另外要实现用户体验,还需要UI交互界面,通过RPC与后台对接,那么DAPP就是包含完整的智能合约+用户UI交互界面。 区块链相对于DAPP来说是应用运行的底层环境。简单的可以类比为IOS,Android等手机操作系统于运行与之上的各种App。
一个完全的DAPP是需要满足完全开源并且是自治的应用程序。DAPP一经部署完毕,,便不可更改。应用的升级必须由大部分用户达成共识之后才可以进行升级。所有的数据必须进行加密存储在去中心化的区块链应用平台上。其次DAPP必须要有token机制。区块链DAPP能够进行容错,不会出现单点故障。它们没有中心化的机构能够进行干扰。不会出现某些数据的删除或者修改。甚至不能被关闭。
Ⅲ Zether 基于账户模型的隐私合约
Zether是以太坊上第一个基于账户模型的智能合约方案,提供保密性(隐藏交易金额)和匿名性(发送者和接收者地址),于2019提出。
Zether由ZSC (Zether Smart Contract) 和 ZTH (Zether token) 实运扮芹现旁毕。 Zether可缺姿以看作为以太坊上部署的智能合约ZSC, 代币为ZTH,地址是Elgamal 公钥。
目前存在的匿名支付方案,像Zcash, Monero都是采用UTXO模型,采用同态承诺隐藏交易中的金额。Zether则利用Elgamal的一种变体形式加密,并附加一个证明,保证交易的有效性。
假如Alice 想要和Zether交互,首先需创建Elgamal密钥对 , 并发起一个交易向 存部分 ether 。 ZSC 然后创建一个账户 , 余额为存款的金额的ZTH。之后,Alice 可以向其它的Zether账户秘密发送ZTH.。为了隐藏Alice 的账户,Alice 选择一些Zether账户作为匿名集,其它人只能看到是匿名集中的某个账户在转账。 Alice 同时能将她的ZTH转成ether.
Zether思路比较简单,更多细节见参考。
https://medium.com/@loveshharchandani/notes-on-zether-towards-privacy-in-a-smart-contract-world-6c4333f975d
https://crypto.stanford.e/~buenz/papers/zether.pdf
https://ethresear.ch/t/zether-the-first-privacy-mechanism-designed-for-ethereum/5029
Ⅳ 36个主流的去中心化交易所协议
本文汇总整理了目前主流的用于区块链加密资产点对点交易所的协议清单,即我们通常所说的DEX协议 —— DE centralize E xchange。如果你希望在自己的应用中快速加入加密货币兑换功能而又不希望依赖于币安这样的中心化的加密货币交易所,相信这篇文章会对你有所帮助。
这些去中心化协议的体系架构之间可能存在巨大的差异。在某些项目中,去中心化交易所协议是 通过智能合约来实现的,因此任何人都可以访问;但是在另一些项目中的DEX协议则采用封闭方案, 虽然他们也使用了经过公开验证和审计的智能合约来实现;还有一些项目则选择创建一个自有的区块链来实现交易所协议。实现资产流动的方式多种多样。有些协议,例如Bancor包含了内建的对手方发现逻辑,而另一些协议,例如0x,则允许使用链下的资产流动池,这意味着需要在链下找到交易的对手方。
1、 0x
0x协议构建于以太坊区块链之上,因此仅支持ERC20代币的交易。0x协议是开放的架构,它采用链下的中继器来实现资产的流动。
官网:https://0x.org/
2、Bancor
Bancor协议也是构建于以太坊区块链上,因此也只支持ERC20代币的交易。Bancor协议采用链上交易和出价。
官网:https://www.bancor.network/
3、Bisq
Bisq是构建于比特币区块链上的开放DEX协议,支持所有类型的加密货币。
官网:https://bisq.network/
4、Bitshares
Bitshares是基于自有的Bitshares区块链实现的开放DEX协议,支持所有类型的加密货币。
官网:https://bitshares.org/
5、Blocknet
Blocknet也是基于自有的区块链(Blocknet)实现的开放DEX协议,支持比特币及山寨币。
官网:https://www.blocknet.co/
6、CDx
CDx是构建与以太坊之上的开放DEX协议,目前还在开发中。
官网:https://cdxproject.com/
7、CDX
CDX是基于以太坊和Youdex侧链的开放DEX协议,支持所有类型的加密货币,支持跨链交易。
官网:https://github.com/YouDex/cdx
8、COMIT
COMIT协议目前还处于提议阶段,计划支持所有的区块链、所有类型的加密货币,使用状态通道和第三方流动性提供商。
官网:https://www.comit.network/
9、Compound
Compound是基于以太坊的开放DEX协议,支持ERC20代币的去中心化交易。Comound依赖于中心化的预言机(Oracle),因此是部分去中心化的协议。
官网:https://compound.finance/
10、Counterparty
Counterparty是基于比特币区块链的开放DEX协议,它通过扩展比特币协议而实现,因此仅支持比特币和Counterparty代币的P2P交易。
官网:https://counterparty.io/
11、DEAL
DEAL是基于NEO区块链上的智能合约实现的封闭DEX协议,仅支持NEO资产的点对点交易。
官网:https://aphelion.org/wp.html
12、Dharma
Dharma协议基于以太坊实现,支持ERC20代币和Dharma代币的点对点交易。Dharma目前还在开发阶段。
官网:https://dharma.io/
13、Dydx
Dydx是在以太坊区块链上基于0x协议实现的开放DEX协议,支持ERC20代币和Dydx衍生品(期权等)的去中心化交易。Dydx目前还处于开发阶段。
官网:https://dydx.exchange/
14、Emoon
Emoon是在以太坊区块链上实现的封闭DEX协议,主要目的是迎合 游戏 界的需求,支持ERC20代币 和ERC721资产的去中心化交易。
官网:https://www.emoon.io/
15、Enigma
Enigma协议目前还在提议阶段,计划支持所有链、所有加密资产的去中心化交易。
官网:https://www.enigma.co/
16、Exchange Union
Exchange Union目前还在开发阶段,计划支持链下支付、跨链交易、去中心化委托单传播等。
官网:https://www.exchangeunion.com/
17、Hydro Protocol
Hydro Protocol是基于以太坊和TRON的DEX协议,支持ERC20代币,链下委托、链上结算。
官网:https://hydroprotocol.io/
18、Komodo
Komodo协议目前在Alpha测试阶段,基于自有的Komod链实现。
官网:https://www.komodoplatform.com/
19、Kyber Network
Kyber Network是基于Ethereum区块链的封闭DEX协议,支持ERC20代币的点对点交易。Kyber的实现包含了以太坊上的智能合约以及交易所,但是只有Kyber自己的交易所可以使用这些合约。
官网:https://kyber.network/
20、Lendloid
Lendloid是基于Ethereum区块链的开放DEX协议,目前还在开发中。
官网:https://www.lendroid.com/
21、Loopring Protocol
Loopring是基于以太坊和NEO区块链的开放DEX协议,支持ERC20代币和NEP5代币的去中心化交易。
官网:https://loopring.org/
MARKET Protocol是基于以太坊的开放协议,主要用于衍生品的交易,目前还在开发中。
官网:https://www.marketprotocol.io/
23、Melon
Melon是基于以太坊的开放DEX协议,支持ERC20代币和Melon资产的交易。
官网:https://melonport.com/
24、OmiseGo
OmiseGo目前还在开发当中,计划构建自己的区块链,实现全币种支持。
官网:https://omisego.network/
25、Raiden Network
Raiden Network是基于以太坊的链下ERC20代币交易协议,类似于比特币的闪电网络。Raiden目前还在开发当中。
官网:https://raiden.network/
26、Ren
Ren是基于以太坊和比特币区块链的开放DEX协议,支持ERC20代币、以太币、比特币的去中心化交易。
官网:https://renproject.io/
27、Ripple
Ripple是Ripple链的开放协议,内置了对兑换交易的支持,允许任何人在不可信环境中交易Ripple资产。
官网:https://ripple.com/
28、Saturn
Saturn是基于以太坊的开放DEX协议,支持ERC20代币和ERC233代币的点对点交易。Saturn目前还在开发中。
官网:https://rados.io/saturn-protocol-saturn--updates-for-radex-and-rados/
29、Set
Set是基于以太坊的开放协议,计划支持ERC20代币和Set代币,目前还在开发中。
官网:https://www.setprotocol.com/
30、Snowglobe
Snowglobe是基于以太坊的开放协议,计划支持ERC20代币的去中心化交易,目前还在开发中。
官网:https://aurora.com/faq/
31、Stellar
Stallar协议有自己的区块链,协议内置了对去中心化交易Stellar资产的支持。
官网:https://www.stellar.org/developers/guides/concepts/exchange.html
32、Swap
Swap是基于以太坊的封闭DEX协议,支持ERC20代币,目前还在开发中。
官网:https://swap.tech/whitepaper/
33、TPL
TPL基于TBC链实现,目前还在概念验证阶段。
官网:https://tplprotocol.org/
34、Uniswap
Uniswap是基于以太坊的开放协议,支持ERC20代币的去中心化交易。
官网:https://uniswap.io/
35、Wandex
Wandex是基于以太坊的封闭DEX协议,目前还在开发当中。
官网:https://www.wandx.co/
36、Wyvern
Wyvern是基于以太坊的开放协议,主要支持非同质化通证的交易,链下委托。
官网:https://wyvernprotocol.com/
原文链接:区块链去中心化交易所协议汇总 — 汇智网
Ⅳ 【ETH钱包开发04】web3j转账ERC-20 Token
在上一篇文章中讲解了ETH转账,这一篇讲一下ERC-20 Token转账。
【ETH钱包开发03】web3j转账ETH
1、直接用web3j的API
2、java/Android调用合约的 transfer 方法
不管用哪种方式来转账,你都需要先写一个solidity智能合约文件来创建ERC-20 Token,然后部署合约,最后才是通过客户端来调用。
注意:erc-20 token转账和eth转账的区别如下:
1、erc-20 token创建交易对象用的是这个方法 createTransaction
2、erc-20 token需要构建 Function ,它其实对应的就是erc-20 token合约中的那些方法。它的第一个参数就是ERC20中那几个方法的名称,第二个参数的话就是对应合约方法中的参数,第三个参数是和第二个参数对应的,按照我那样就行了。转账的话就是 transfer ,我们从合约的 transfer 可以看到第一个参数是收款地址,第二个参数是金额,所以 Function 这里对应起来就好。
这种方法不需要使用web3j封装的方法,而是直接调用solidity合约的方法。
步骤
1、web3j加载一个已经部署的合约
2、验证合约是否加载成功 isValid
3、如何加载合约成功,则调用合约的 transfer 方法
注意:
1、这里的 TokenERC20 是根据solidity智能合约生成的对应的Java类,用于java/Android和智能合约交互的,如果你对这里不太清楚,不妨看看我之前的一篇文章。
以太坊Web3j命令行生成Java版本的智能合约
2、如果加载合约失败,可能的一个原因是合约对应的Java类中的 BINARY 的值不对,这个值是你部署合约成功之后的bytecode,你最好检查对比一下。
我发送一笔交易,可以通过这个地址查询
https://rinkeby.etherscan.io/tx/
Ⅵ 「官方」搭建Web3:Filecoin与以太坊携手共进
这是Protocol Labs创始人Juan Benet在EthCC 2021上的演讲概要,查看完整内容:
https://www.bilibili.com/video/BV1eb4y1r7E1
Filecoin网络是面向生态的,它与Protocol Labs搭建模块化解决方案的倾向是一致的。因为它本来就是设计给其他人使用,所以Filecoin在Web3领域的其他栈、应用和生态里如鱼得水。自从其在2020年10月的启动开始,Filecoin已经增长到超过8 exbibytes的可用存储空间,有超过400个项目进入了这个生态。以太坊就是一个能持续证明其可协作性和共同利益的生态系统。
Filecoin + 以太坊
>>>>Filecoin和以太坊虚拟机(EVM)
Filecoin生态意识到网络支持智能合约的好处。最初,开发者社区相信架设在以太坊和Filecoin之间的桥服务足够在Filecoin上支持智能合约了。不过,通过桥来使用智能合约是很笨重的方式,相比于直接在以太坊实现智能合约的功能和可组合性更是不足。有一个提议是在Filecoin上加入以太坊虚拟机(EVM),从而在存储层启用对智能合约的支持,以及为这两个生态的结合提供更多机会。
>>>>开发者工具和资源
Fleek:让用户能为去中心化网络架设网站、存储和分发文件及开发dapp。Fleek可以让每一个人(从专业的开发者到日常的互联网用户)更容易以去中心化的方式创建app和存储文件,从而加速去中心化网络的采用率。Fleek可以在Filecoin上进行自动化存档,并通过ENS(以太坊域名服务)这样的应用来利用以太坊的生态系统。
https://fleek.co/
Web3.Storage:是一个让开发者在Filecoin去中心化存储网络上存取数据的简单接口。Web3.Storage为开发者(包括以太坊dapp开发者)提供了搭建应用的简单方式,这些应用可以带有冗余的去中心化的存储以及安全的内容寻址数据。
http://web3.storage/
PowerLoom:以去中心化的方式将链上和链下数据聚合起来以生成带有密码学证明的快照。它旨在通过一个丰富的节点和利益相关者生态系统(他们被激励参与到协议里)来搭建信任,并按需提供洞见。PowerLoom特别适用于以太坊DeFi这样的生态,这类系统是非常复杂的,而且需要基于验证的信任。
https://powerloom.io/
>>>>DeFi应用
SecuredFinance(https://secured-finance.com/)是一个综合平台,整合了基于智能合约的点对点固定利率贷款、抵押品管理服务、货币间交易和其他类型的利率产品。Secured Finance的协议是去中心化的点对点金融协议,提供了由以太坊智能合约赋能的区块链上的中后台银行业务。Secured Finance可以满足Filecoin网络内的需求,它提供的解决方案能够满足Filecoin存储提供者对FIL贷款的强烈需求。
>>>>数据市场
OceanProtocol(https://t.co/misApE3ggc?amp=1)是一个在Filecoin上搭建的数据市场。Ocean的数据token(data tokens)是以太坊ERC-20 token,可以轻易地用于发布和消费数据服务。如果你有1个数据token,你可以访问一个特定的数据服务。Ocean market是一个专门为数据服务的去中心化交易所,它分叉了一个Balancer AMM(自动化做市商)来降低gas成本。在这个市场中,用户可以对数据进行发布、购买、销售、消费和stake操作。
通过Filecoin,用户可以利用Ocean来发起自己的Filecoin数据市场,或创建一个Filecoin dataDAO或指数基金。通过Ocean Protocol的工具和Filecoin的去中心化存储数据库,我们正见证新生的开放数据经济。
>>>>视频应用
LivePeer:是一个去中心化的在线视频流媒体基础设施,由以太坊区块链确保安全性。将Filecoin和IPFS结合提供存储和内容分发功能后,去中心化视频应用就成为可能了。
https://livepeer.org/
Voodfy:正为私有的视频架设服务提供去中心化工具。这是一个多功能的安全流媒体解决方案,让用户能完全控制自己的内容,这包括了访问权的设定以及变现的方式。它利用了Livepeer、Ethereum、Textile Powergate和Filecoin.
https://voodfy.com/
VideoCoin:正搭建一个能可靠地创建、存储和交易基于视频的NFT解决方案,它可以绕过在以太坊上存储实际内容时固有的复杂性和费用。VideoCoin正将其去中心化视频处理网络与Filecoin整合起来,以搭建首个专门为创建和交易视频NFT服务的平台。这个平台是新生的全球数字收藏品市场急需的一部分。
https://videocoin.io/
>>>>NFT
nft.storage(http://nft.storage/)是一个由Protocol Labs实验室和Pinata支持的服务,它专门为存储NFT数据而设计。
nft.storage让开发者通过内容寻址和去中心化存储来保护其NFT资产和相关的元数据,确保所有的NFT遵循最佳实践以实现长期的可访问性。
未来的使用场景
随着Filecoin和Ethereum生态系统的成长和重叠,会出现更多的新生用例和开发者机会。一些可以进行创新的用例包括:
>>>>可组合的DeFIL
将存储和Defi的世界结合可以产生一些机会。人们可以将市场订单(如要价、出价和交易)带到一个去中心化交易所上,以观察市场是如何评判这些订单的价值的。通过这样的能力,生态系统可以开始想象硬件期货(hardware futures)和时空期货(spacetime futures)等的出现。
>>>>数据丰富的NFT
NFT将会越来越复杂,而Web3社区需要 探索 采用数据丰富(data-rich)的NFT的方式。VideoCoin已经将其视频处理引擎与Filecoin连接起来,以结合以太坊对NFT的支持能力及Filecoin的存储能力。像VideoCoin这样的工具可以用来创建一类新型的NFT,如短电影、视频片段和完整长度的专题特写。
>>>>按观看次数支付的媒体
通过在Filecoin上存储的信息,我们可以利用以太坊的token支持能力去创建由token保护的页面和媒体(文章、电影和音乐等)。我们可以复制Web2时代的按观看次数支付模式,而无需复制数据和广告模型。
这只是一个开始!Filecoin和以太坊生态有长期的协作 历史 和机会,未来可期。
Ⅶ 什么是DApp
DApp是Decentralized Application的缩写,中文叫分布式应用/去中心化应用,是基于区块链底层开发平台建立的,比如以太坊和EOS。DApp与底层平台的关系,就好比APP与IOS和Android系统。
一个真正的DApp应用,需要同时满足以下几个条件:
1. 应用必须完全开源、自治,且没有一个实体控制着该应用超51%Token。该应用必须能够根据用户的反馈及技术要求进行升级,且应用升级必须由大部分用户意见达成一致之后方可进行;
2. 应用的数据必须加密后存储在公开的区块链上;
3. 应用必须拥有Token机制(可用基于相同底层区块链平台的通用代币或自行发行新币),矿工或应用维护节点需要得到代币奖励;
4. 应用代币的产生必须依据标准的加密算法,有价值的节点可以根据该算法获取应用的代币奖励。
以最著名的以太坊的游戏——CryptoKitties(加密猫)为例,其是一款运行在以太坊的DApp,玩家可以创建、照顾、购买、喂养并出售存储在以太坊区块链中的以太猫,并且每15分钟产出一只小猫,而每只猫都具有独一无二的特性,可以通过配对等繁衍新的小猫。
该DApp并不是由一个实体所拥有,而是创建在以太坊上,永不消失,没有人能够抢走你的猫,没有人能够改变任何一只猫的样子(V神就是在暴雪取消术士的"生命虹吸"技能后开始走向以太坊的创立)也没有一个实体对这个DApp有独断的意志。
在这个游戏发行出来之后,每个人都可以参与该游戏,并且由于以太坊的架构,所以参与者的隐私都能够得到良好的保护。所以在未来,投资DApp有着非常值得想象的升值空间。
Ⅷ 多链(Multichain)与以太坊(Ethereum)——战斗正在进行中
GrandReview 进行的研究表明,区块链市场在快速增长,并且没有迹象表明这种增长会在短期内放缓。当区块链处于起步阶段时,它是紧密社区的领域,但现在已经扩展到大型企业、投资者甚至地方政府。但伴随着如此快速的扩张而来的是一波新的挑战,尤其是在可扩展性方面。
解决区块链可扩展性问题
众所周知,区块链存在拥塞和可扩展性问题。这影响深远,会导致交易处理时间变慢和交易费用增加,从而导致用户体验不佳。
这不是特定链所独有的问题,但在以太坊——仅次于比特币的第二大区块链网络——的情况下尤其明显。这导致一些开发人员变得如此沮丧,以至于他们转向了其他网络,例如提供更高速度的 Solana 或 Cardano。
同时,大多数开发者都认为,要让 DeFi 继续获得普及和牵引力,以及让这些解决方案为大众所接受,解决方案在于合作,而不是竞争。输入多链宇宙的想法。
什么是多链(Multichain)?
多链能否解决可扩展性问题?顾名思义,多链生态系统是一个多链生态系统,其中多个区块链相互连接,最终目标是提升用户体验、提高效率并允许更广泛地采用。但这需要有效的跨链解决方案。好消息是其中一些已经在生产中。让我们看看 SushiSwap 和 Aave 采用多链。
SushiSwap 和 Aave 中的多链采用
SushiSwap 早在今年 3 月就进入了多链领域,现在是最大的多链采用者之一,存在于 13 条链上:包括 Ethereum、Binance Smart Chain、Polygon、Avalanche 和 Fantom。
Aave 将效仿。它已经通过其加密借贷产品取得了成功,这导致许多用户锁定了资产。
Aave 的创始人最近表示,该协议正在考虑在许多不同的网络上启动。他还谈到了 通过 EVM 兼容的解决方案 Neon Labs、 Avalanche和 Optimistic Rollup 解决方案 Arbitrum 和 Optimism 在 Solana上扩展 Aave的借贷市场,作为其多链战略的一部分。
多链聚合器从何而来?
多链或跨链聚合器确定实现跨区块链生态系统交易的最佳途径。因此,它们减轻了现有区块链用户的负担,并消除了新加入者的一些进入障碍。
这种聚合器的一个例子是Apeboard,它使用户能够跨不同平台监控他们的投资组合。Apeboard 支持 11 条链,包括 Ethereum、Binance Smart Chain、Polygon、Solana 和 Terra。它非常适合监控多个链之间的资产和跟踪余额。
这里还值得一提的是 1Inch,这是一个交易所聚合器,它通过扫描 DEX 来为交易者找到最低的加密货币价格。1inch 为以太坊、币安智能链和 Polygon 的 78 个平台提供流动性。
流行的多资产区块链 - Orbit Chain、Polkadot 和 Cosmos
在谈论多链未来时,重要的是要讨论多资产区块链,它使用去中心化跨链通信 (IBC) 存储、传输和验证存在于整个公共区块链上的信息和资产。其中最受欢迎的是 Orbit Chain、Polkadot 和 Cosmos。
多链未来的多种可能性
目前区块链仍然由其每个组成部分定义和体验,这意味着从用户的角度来看,它缺乏流动性。有些人甚至将其与互联网的早期阶段进行了比较。多链技术将颠覆这种体验,以至于用户甚至可能不知道他们在哪个链上操作。这种变化对于使区块链过渡到高增长行业至关重要。
多链将支持许多部门采用区块链,尤其是金融和银行业。如果没有这种互操作性,使用不同区块链的银行之间的交易对于所有相关人员来说都将非常复杂。但是使用多链方法,传输数据不仅简单,而且快速且安全。
同样,在供应链管理中,区块链互操作性可以带来巨大的好处。区块链的特性允许断开的供应链管理系统在没有高投资成本的情况下互操作。因此,利用这些特征来改变供应链是有意义的。
最后,互操作性的一个重要好处是,以前在孤岛中工作的不同开发团队可以利用彼此的解决方案,从而推动整个行业的创新。
为什么以太坊可能会阻止多链
目前,阻碍多链未来的最大发展是 ETH 2.0的推出——网络升级将使以太坊网络更具可扩展性和安全性。为实现这一目标,以太坊将其共识机制从工作量证明(PoW)更改为权益证明(PoS)。升级可能会对以太坊的价格产生重大影响,因为其较低的费用和更快的交易将使网络向更多的用户群体开放。
以太坊已经允许在 L2 汇总上进行资产转移——以太坊智能合约内的链下交易聚合器。他们的目标是通过增加区块链的吞吐量来减少费用和拥塞。但在资产转移方面,它们也提供了许多解决方案。
人们普遍认为,L2 解决方案在使以太坊赢得主流用户方面发挥了重要作用。据估计,L2 每秒可以处理 2,000-4,000 笔交易,这已经非常接近 Visa 的处理能力。随着第 1 层与以太坊 2.0 和第 2 层的扩展,以太坊将利用一些强大的经济带宽。
事实上,如果 ETH 2.0 全面生效,开发人员可能看不到任何拥抱多链的理由——以太坊将为他们提供所需的一切。
Ⅸ 区块链之联盟链(三) 认识Fabric
Fabric 是超级账本联盟推出的核心区块链框架,它适合在复杂的企业内和企业间搭建联盟链。根据超级账本联盟的目标, Fabric 被建设为一个模块化的、支持可插拔组件的基础联盟链框架。;
与以太坊系的Quorum不同,Fabric从一开始就只考虑企业间的应用。其独有的channel概念,将企业根据业务目的不同以不同的子网连接起来, 每一个子网对应一个channel,而每个channel有自己独立的区块链。而Quorum很显然是只有一个公网(所有企业节点都加入进去),企业与企业间的私有业务是通过Private Manager 完成的。
理解channel的最简单方法就是,将它类比为一个消息服务提供的Topic,实际上Fabic最早就是基于Kafka 的分布式消息服务来实现。
在Fabric网络中,一个企业可以有一个或多个节点加入整个联盟链;一个企业可以加入1个或者多个Channel(子网); 一个节点可以加入1个或者多个channel。每个channel构成一个子网,所以Fabric 是 一种由子网组成的网络。
那么Fabric是怎么实现智能合约的执行和完成业务上链(将事务结果记录在区块链里)的呢?
与其它框架不同, Fabric 将整个过程分成了三个阶段:
业务背书阶段 : 客户的请求发送的背书节点,通过智能合约完成业务的计算(但不更新状态),并完成背书;将背书结果返回个客户端。
业务的排序阶段 : 客户端将背书结果通过Channel被发送到排序节点(orderer),在排序节点完成事务的排序,并打包到block里,最后下发给所有连接到channel的节点。
业务验证并写入账本阶段 : 通过Gossip 网络,所有Channel的节点都会接收到新的block,节点会验证block中的每一个事务,确定是否有效:有效地将会跟新world state,无效的将会标志为“无效”,不会更新World state,但整个block会被完整的加入到帐本中(包括无效的事务)。
根据以上的描述,Fabric 节点实际可以分为 ,普通节点和Order节点:
Peer, 普通节点, 完成背书(包括只能合约的执行)和验证.
orderer, 排序节点,完成排序。
加入orderer节点的Fabric网络可以被描述如下:
每一个Channel,都定义了所有属于channel的节点,但是并不需要所有节点都连接到Orderer 节点(节点间可以通过gossip 协议通讯来传播私有数据或事务).
在区块链中,共识是区块链的基础。与公有链不同,联盟链的共识要求所有加入账本的事务是确定的、最终的,也就是不可以有分叉,区块与区块间的顺序是一定的,只存在唯一条链。在Fabric 中,这个客观需求正是由排序实现的,所有的事务将被提交给orderer节点获得确定的顺序,并最终打包成block进入帐本。 Fabric 从1.4.1开始支持基于Raft实现排序服务, 可以认为基于Raft实现共识。
基于RAFT的排序服务相对于早期的Kafka 具有更好的分布性,配置更加简单,是联盟链里常用的一个常用的达成共识的算法,Quorum就 默认使用RAFT作为共识层。简单的说,RAFT是一个leader和follower的模式, 所有加入RAFT网络的节点,任意时候都有一个leader, 只有这个leader有权决定事务的顺序,并打包成Block,其它节点只能作为follower提交事务和同步block。
基于FAFT网络,每个企业可以有一个或多个节点参与到Orderer中去。在Frabric中企业间的网络连接可以变化成如下形式:
区块链的使用用户在以太网中被称作EOA(External of Account), EOA的载体是钱包。我们沿用这个概念,来看看Fabric是如何实现用户和发起事务的。Fabric中EOA是一个CA中心发布的certificate(x.509),一个Certificate代表一个Identity(这与以太坊还是有很大区别的, 以太坊中一个EOA其实是一个hash地址),EOA能够参与的channel以及被授权的操作是有channel的MSP( Membership Service Provider)决定的(如下图)。
注:certificate 是一种密码学上验证身份的通用做法; certificate包含了个人的信息,公钥以及发布这个certificate的CA的签名。验证方只需要拥有这个CA的证书(包含CA的公钥),就可以验证这个签名是否正确,certificate的内容是否有篡改。简单的说,通过CA和Certificate,我们可以获得一个可验证的的身份和信任链。
如上图,fabric中通要使用Wallet作为EOA的载体,一个Wallet中可以包含多个Identity(x.509 certificate)。 Identity 通过 CA提供的信任链来验证正确性。
验证了身份之后, Fabric 通过MSP在区块链网络中解决该身份是否代表组织的成员和在组织内具有什么角色。例如,channel首先会验证当前用户Identity是否是有效地身份,然后通过MSP查看其所处的企业和具有的角色,最终确定该用户是否有权执行操作。
可以说,Fabric的访问控制是通过MSP来完成的。在每一个需要访问控制的地方都需要定义一个MSP。 例如,每个channel都定义一个MSP,这个MSP规定了在channel范围内资源的访问权限。 MSP 是Fabric里一个晦涩难懂的概念,也是其赋予企业间安全访问的基础。
前文提到, Fabric 将业务处理和上网分成了三个部分, 背书,排序,验证后加入账本。
其中背书是Fabric执行智能合约的阶段。以太坊中,智能合约是在EVM中执行的,有多种语言支持。 在Fabric,智能合约被称为chaincode: 一个chaincode 可以理解为是智能合约的容器,可以包含一个或多个智能合约, 不用于EVM, chaincode是在 JVM 或NodeJS中执行。
客户应用程序通过智能合约来访问账本,每一个可访问的智能合约都被安装在客户端可以访问的节点上,并被定义在channel里。(有只能合约的节点被称为背书节点,没有只能合约的节点被称未提交节点,提交节点只维护账本)
客户应用提交一个交易请求, 请求到达背书节点, 背书节点首先会验证客户的签名,确保客户的身份有权执行本次交易,接着执行交易提及的智能合约(chaincode),并生成一个背书响应(或者叫做交易提案,tran-proposal)。这个背书响应中通常包含World state 的读集合,写集合, 以及节点对本次交易的签名。这里与以太坊系联盟链最主要的不同是: 背书阶段只模拟交易,并不真正更新交易结果。 而真正更新交易在第三阶段完成。背书节点最后将生成的背书响应fanhui给客户端, 智能合约部分的执行就结束了。
通常一个交易的执行需要多方的签名,所以客户端需要将一个交易发送给多个背书节点,这些背书节点的选择需要满足背书策略的要求。
下图是一个包含有客户、背书节点,提交节点的网络示意图。
根据Fabric官方的参考文档,客户交易的正果过程可使用下图描述。
如上图,从1到3,为背书阶段,4为排序阶段,4.1,4,2, 5为验证提交阶段。 参考 Frabic的节点 概念,可以了解更多在交易细节的概念。
总的来看, Fabric 更专注于企业间,通过上文,可以让大家对Fabric的基本构成与概念有一个总的了解。 Fabric本身并不神秘,都是使用的现有的企业间的技术。要更好的了解,建议参考阅读分布式消息系统和企业的安全基础设施(CA相关)的支持。与以太坊系联盟链实现比较, Fabric 的子网更概念对于复杂企业间应用适应更强,但是其复杂的安全考量,使得运营成本很高,另外,Fabric 使用Certificate做为用户身份,有很大的局限性,在新的2.0里,Fabric对于此处将有所改变。
下一篇,我们将来看看Sawtooth , 由Inter 提供的区块链框架。
区块链之联盟链(一) 认识以太坊
区块链之联盟链(二) 认识Quotum
区块链之联盟链(三) 认识Fabric
区块链之联盟链(四) 认识Sawtooth