您正在查看: Ethereum 分类下的文章

以太坊开发者工具列表

以太坊开发者工具列表

这是一份关于在以太坊上开发应用程序的优质工具清单指南,其中包含一些工具、组件、应用、平台以及服务等。

该列表的创建受到ConsenSys产品经理的推动,他们认为有必要在初级开发与经验丰富的区块链开发人员之间更好地共享工具,开发模式和组件。

该资源旨在专注于开发人员工具,但还包括一些生态系统资源:

以太坊生态系统资源,关于有用的DApp,教育资源,钱包和服务。

欢迎捐款!

可以随意拉取并提交请求,补充您想要添加(或删除!)的工具。如果添加新工具,请添加您认为新开发人员会理解的简短描述。

感谢众多贡献者包括@corbpage和@pakaplace为Meridio做出的贡献,并感谢@jpantunes以更合理的方式重组清单列表。

  • 没有有效产品的项目将不会被添加。

  • 不推荐使用或不再维护的项目将被删除。

  • 没有开放源代码或开发者审核发现是付费/受限制服务的项目将得到进一步审查。

^以上规则公平吗?在此处分享您的想法:

https://github.com/ConsenSys/ethereum-developer-tools-list/pull/70

目录

新开发者从这里开始

  • Solidity - 最受欢迎的智能合约语言。
  • Truffle - 最受欢迎的智能合约开发,测试和部署框架。通过npm安装cli,然后从此处开始编写您的第一个智能合约。
  • Metamask - Chrome扩展程序钱包,可与Dapps进行交互。
  • Truffle boxes - 以太坊生态系统的打包组件。
  • OpenZeppelin Starter Kits - 开发人员的多合一入门组件,可快速启动其受智能合约支持的应用程序。包括Truffle,OpenZeppelin SDK,OpenZeppelin / contracts-ethereum-package EVM经审核的智能合约EVM软件包,react-app和rimble,易于设计。
  • EthHub.io - 以太坊的全面信息概述-它的历史,治理,未来计划和开发资源。
  • EthereumDev.io - 关于以太坊智能合约编程入门的权威指南。
  • Cobra - 一个快速,灵活,简单的以太坊智能合约开发环境的框架。将智能合约,测试和部署到以太坊虚拟机(EVM)上。
  • Kauri.io - 基于Web3的社区和新兴技术的知识平台。分享精选内容,并就最新,高质量的技术文章和系列进行协作。 请查看“入门”社区以学习基础知识。
  • dfuse - Slick 区块链 API 可以构建世界一流的应用程序。
  • Biconomy - 通过使用简单易用的SDK启用元交易来在dapp中进行无Gas交易。

开发者工具

开发智能合约

智能合约语言

  • Solidity - 以太坊智能合约编程语言。
  • Vyper - 新的实验性类python编程语言。

框架

  • Truffle - 最受欢迎的智能合约开发,测试和部署框架。Truffle套件包括 Truffle, Ganache, 和 Drizzle. 在这里深入了解松露
  • Embark - DAPP开发框架
  • Waffle - 先进的智能合同开发和测试框架,体积小,灵活,快捷(基于ethers.js)
  • Dapp - DApp开发的框架,DApple的继承者
  • Etherlime - 基于ethers.js的框架用于Dapp部署
  • Parasol - 敏捷的智能合同开发环境,测试,部署INFURA,合约文件等。它具有灵活,不受限制的设计以及无限的可定制性。
  • 0xcert - 用于构建去中心化应用程序的JavaScript框架
  • OpenZeppelin SDK - OpenZeppelin SDK:一套工具,可帮助您开发,编译,升级,部署智能合约并与之交互。
  • sbt-ethereum - 一个基于选项卡的,基于文本的控制台,用于智能合约的交互和开发,包括钱包和ABI管理,ENS支持和高级Scala集成。
  • Brownie - Brownie是一个Python框架,用于部署,测试以太坊智能合约并与之交互。
  • Cobra - 一个快速,灵活,简单的开发环境的框架,用于以太坊智能合约的测试和部署。

集成开发环境

其他工具

测试区块链网络

  • ethnode - 运行以太坊节点(Geth)进行开发,简单执行 npm i -g ethnode && ethnode.
  • Ganache - 具备UI和日志的区块链测试应用
  • Kaleido - 使用Kaleido来建立联盟区块链网络。非常适合PoC和测试
  • Besu Private Network - 在Docker容器中运行Besu节点的专用网络Orion -PegaSys进行私人交易的组件 Artemis - PegaSys的以太坊2.0信标链的Java实现。
  • Cliquebait - 使用类似于真实区块链网络的docker实例简化智能合约应用程序的集成和测试
  • Local Raiden - 在Docker容器中运行本地Raiden网络以进行演示和测试
  • Private networks deployment scripts - 专用PoA网络的现成部署脚本
  • Local Ethereum Network - 专用PoW网络的现成部署脚本
  • Ethereum on Azure - 联盟以太坊PoA网络的部署和治理
  • Ethereum on Google Cloud - 基于工作量证明构建以太坊网络
  • Infura -以太坊API访问以太坊网络(Mainnet,Ropsten,Rinkeby,Goerli,Kovan)
  • CloudFlare Distributed Web Gateway - 通过Cloudflare提供对以太坊网络的访问,而不是运行自己的节点
  • Chainstack - 共享和专用的以太坊节点即服务(Mainnet,Ropsten)

测试以太币水龙头

与以太坊通信

前端以太坊API

  • Web3.js - Javascript Web3
  • Eth.js - Javascript Web3替代者
  • Ethers.js - Javascript Web3替代,有用的实用程序和钱包功能
  • light.js 为轻客户端优化的高级反应式JS库。
  • Web3Wrapper - Typescript Web3替代者
  • Ethereumjs - 以太坊的实用程序功能集合,例如ethereumjs-utilethereumjs-tx
  • flex-contractflex-ether - 零配置的高级库,用于与智能合约进行交互并进行交易。
  • ez-ens - ens-简单的零配置以太坊域名服务地址解析器。
  • web3x - web3.js的TypeScript端口。好处包括小巧的构造和全类型的安全性,包括与合同进行交互时的安全性。
  • Nethereum - 跨平台的以太坊开发框架
  • dfuse - 使用TypeScript实现的dfuse Ethereum API 以太坊API库
  • Drizzle - Redux库将前端连接到区块链
  • Tasit SDK -一个React Native库,使用在移动端与以太坊进行交互。
  • useMetamask - 一个自定义的React Hook来管理以太坊ĐApp项目中的Metamask
  • WalletConnect - 用于将电子钱包连接到分散应用程序(DApp)的开放协议
  • Subproviders - 与Web3-provider-engine 结合使用的几个有用的子提供商(包括用于向您的dApp添加Ledger硬件钱包)
  • ethvtx - 支持以太坊&框架无关的Redux存储配置。文档
  • 严格类型-Javascript 替代者
  • ChainAbstractionLayer - 使用单个界面与不同的区块链(包括以太坊)进行通信。
  • Delphereum - 以太坊区块链的Delphi接口,允许开发适用于Windows,macOS,iOS和Android的dApp开发。
  • Torus - 源SDK构建dapps的无缝衔接的UX
  • Fortmatic - 一种易于使用的SDK,无需扩展或下载即可构建web3 dApp。
  • Portis - 具有SDK的非托管钱包,可轻松与DApp进行交互而无需安装任何东西。

后端以太坊API

  • Web3.py - Python Web3
  • Web3.php - PHP Web3
  • Ethereum-php - PHP Web3
  • Web3j - Java Web3
  • Nethereum - .Net Web3
  • Ethereum.rb - Ruby Web3
  • Web3.hs - Haskell Web3
  • KEthereum - Kotlin Web3
  • Eventeum - 由Kauri用Java编写的以太坊智能合约事件和后端微服务之间的桥梁
  • Ethereumex - 以太坊区块链的Elixir JSON-RPC客户端
  • Ethereum-jsonrpc-gateway - 一个网关,允许您运行多个以太坊节点以实现冗余和负载平衡。可以作为Infura的替代品(或在其之上)运行。用Golang写的。
  • EthContract - 一组帮助在Elixir中查询ETH智能合约的助手方法
  • Ethereum Contract Service - 一种MESG服务,可根据其地址和ABI与任何以太坊合约进行交互。
  • Ethereum Service - 一种MESG服务,用于与以太坊中的事件进行交互并与其进行交互。
  • Marmo - Python,JS和Java SDK,以简化与以太坊的交互。使用中继器将交易成本分担给中继器。

开箱即用工具

  • Truffle boxes - 以太坊生态系统的打包组件
  • Besu Private Network - 在Docker容器中运行Besu节点的专用网络
  • Testchains - 用于快速响应(PoA)的预配置由.NET开发
  • Blazor/Blockchain Explorer - Wasm区块链浏览器(功能示例)
  • Local Raiden - 在Docker容器中运行本地Raiden网络以进行演示和测试
  • Private networks deployment scripts - 专用PoA网络的现成部署脚本
  • Parity Demo-PoA Tutorial - 分步教程,用于构建具有2个节点且具有Parity授权回合共识的PoA测试链
  • Local Ethereum Network - 专用PoW网络的现成部署脚本
  • Kaleido - 使用Kaleido来建立联盟区块链网络。非常适合PoC和测试
  • Cheshire - CryptoKitties API和智能合约的本地沙盒实现,可以作为松露盒使用
  • aragonCLI - aragonCLI用于创建和开发Aragon应用程序和组织。
  • ColonyJS - JavaScript客户端,提供用于与Colony Network智能合约进行交互的API。
  • ArcJS - 便于javascript应用程序访问DAOstack Arc以太坊智能合约的库。
  • Arkane Connect - JavaScript客户端,提供用于与Arkane Network进行交互的API,Arkane Network是用于构建用户友好的dapp的钱包提供商。
  • Blocknative - Assist.js是可嵌入的小部件,可提高Dapp的可用性。该工具以编程方式识别并概述了清晰的操作,供最终用户在与MetaMask进行交互时应遵循的操作,以克服(甚至防止)常见的陷阱和障碍。
  • web3-react - 用于构建单页以太坊dApp的React框架

以太坊ABI(应用程序二进制接口)工具

  • ABI decoder - 用于解码以太坊交易中的数据参数和事件的库
  • ABI-gen - gen-从合同ABI生成Typescript合同包装。
  • Ethereum ABI UI - UI-从以太坊合约ABI自动生成UI表单字段定义和相关的验证器
  • headlong - Java中类型安全的合约ABI和递归长度前缀库
  • One Click dApp - 使用ABI在唯一的URL上快速的创建dApp前端页面。
  • Truffle Pig - 一种开发工具,提供简单的HTTP API来查找和读取Truffle生成的合同文件,以便在本地开发期间使用。通过http提供新的合同ABI。
  • Ethereum Contract Service - 一种MESG服务,可根据其地址和ABI与任何以太坊合约进行交互。
  • Nethereum-CodeGenerator - CodeGenerator-基于Web的生成器,可基于Solidity智能合约创建基于Nethereum的C#接口和服务。

模式和最佳做法

智能合约开发的模式
可升级性

基础设施

以太坊客户端

  • Besu - 在Apache 2.0授权开发和用Java编写的开源以太坊客户端。该项目由Hyperledger托管。
  • Geth - Go客户端
  • Parity - Rust客户端
  • Aleth - C++ 客户端
  • Nethermind - .NET 客户端
  • Infura - 一种托管服务,提供符合以太坊客户端标准的API
  • Trinity -使用Python客户端 py-evm
  • Ethereumjs - 使用ethereumjs-vm的JS客户端
  • Seth - Seth是一个以太坊客户端工具,就像“命令行的MetaMask”一样
  • Mustekala - Metamask的以太坊轻客户端项目
  • Exthereum - Elixir客户
  • EWF Parity - Tobalaba测试网络的Energy Web Foundation客户端
  • Quorum - JP Morgan授权的以太坊支持数据隐私的实现
  • Mana - 用Elixir写的以太坊全节点实现。
  • Chainstack - 提供共享和专用Geth节点的托管服务
  • QuikNode - 具有API访问和节点即服务的区块链开发云。

存储

  • IPFS - 分散存储和文件引用
    • Mahuta - 具有附加搜索功能的IPFS存储服务,以前是IPFS-Store
    • OrbitDB - IPFS之上的分散式数据库
    • JS IPFS API - 使用JavaScript实现的IPFS HTTP API客户端库
    • TEMPORAL - 易于在IPFS和其他分布式/分散式存储协议中使用的API
    • PINATA - 使用IPFS的最简单方法
  • Swarm - 分布式存储平台和内容分发服务,以太坊的数据存储服务层
  • Infura -托管IPFS API网关和固定服务
  • 3Box Storage - 用于用户控制的分布式存储的api。建立在IPFS和Orbitdb之上。

讯息传递

  • Whisper - DApp相互通信的通信协议,这是以太坊web3堆栈的基础层服务
  • DEVp2p Wire Protocol - 运行以太坊/低语的节点之间的对等通信
  • Pydevp2p - RLPx网络层的Python实现
  • 3Box Threads - API,使开发人员能够持久地实现IPFS,或在内存中实现对等消息传递。

测试工具

  • Truffle Teams - 零配置持续集成松露项目
  • Solidity code coverage - Solidity代码覆盖率工具
  • Solidity coverage - Solidity 智能合约的代码覆盖率
  • Solidity function profiler - Solidity 合约功能分析器
  • Sol-profiler - 替代和更新的Solidity智能合约分析器
  • Espresso - 快速,并行,热加载的Solidity测试框架
  • Eth tester - 用于测试以太坊应用程序的工具套件
  • Cliquebait - 使用与真实区块链网络非常相似的Docker实例简化智能合约应用程序的集成和接受测试
  • Hevm - hevm项目是以太坊虚拟机(EVM)的实现,专门用于单元测试和调试智能合约
  • Ethereum graph debugger - Solidity 图形化调试器
  • Tenderly CLI - 通过可读的堆栈跟踪加快开发速度
  • Solhint - 为Solidity智能合约验证提供安全性,样式指南和最佳实践规则
  • Ethlint - 用于识别和修复Solidity(以前为Solium)中的样式和安全问题
  • Decode - npm软件包,它将tx提交到本地testrpc节点的解析,使它们更具可读性和易懂性
  • truffle-assertions - 一个npm软件包,其中包含其他断言和实用程序,用于测试带有松露的Solidity智能合约。最重要的是,它增加了断言是否已发出特定事件的能力。
  • Psol - 具有mustache.js样式的语法,宏,条件编译和自动远程依赖关系包含的Solidity词法预处理器。
  • solpp -具有全面指令和表达式语言,高精度数学和许多有用的辅助函数的Solidity预处理器和帮助插件。
  • Decode and Publish – 解码和发布原始的以太坊TX。类似于https://live.blockcypher.com/btc-testnet/decodetx/
  • Doppelgänger - 一个用于在单元测试期间模拟智能合约依赖关系的库。
  • rocketh - 一个简单的库来测试以太坊智能合约,允许使用任何web3库和测试运行器。
  • pytest-cobra - PyTest插件,用于测试以太坊区块链的智能合约。

安全工具

  • MythX - 以太坊开发人员的安全验证平台和工具生态系统
  • Mythril - 开源EVM字节码安全性分析工具
  • Oyente - 替代静态智能合约安全性分析
  • Securify - 安全扫描器以太坊智能合约
  • SmartCheck - 静态智能合约安全分析器
  • Ethersplay - EVM反汇编程序
  • Evmdis - 替代EVM反汇编程序
  • Hydra - 框架cryptoeconomic合同的安全性,分散的治安悬赏
  • Solgraph - 可视化Solidity控制流程以进行智能合约安全性分析
  • Manticore - 智能合约和二进制文件上的符号执行工具
  • Slither - 一个Solidity静态分析框架
  • Adelaide - SECBIT静态分析扩展到Solidity编译器
  • solc-verify - 用于Solidity智能合约的模块化验证器
  • Solidity security blog - 已知攻击媒介和常见反模式的完整列表
  • Awesome Buggy ERC20 Tokens -受影响的代币中ERC20智能合约中的漏洞的集合
  • Free Smart Contract Security Audit - Callisto Network提供的免费的智能合约安全审核
  • Piet - 可视化Solidity体系结构分析器

监控方式

  • Alethio - 一个先进的以太坊分析平台,提供实时监控,洞察和异常检测,令牌指标,智能合约审计,图形可视化和区块链搜索。还可以探索以太坊去中心化交易所的实时市场信息和交易活动。
  • amberdata.io - 提供实时监控,洞察力和异常检测,令牌指标,智能合约审计,图形可视化和区块链搜索。
  • Neufund - Smart Contract Watch - 一种监视大量智能合约和交易的工具
  • Scout - 以太坊上智能合约的活动和事件日志的实时数据馈送
  • Tenderly - 一种平台,可通过Web仪表板的形式为用户提供可靠的智能合约监控和警报,而无需用户托管或维护基础架构
  • Chainlyt - 使用已解码的交易数据探索智能合约,查看合约的使用方式以及通过特定功能调用搜索交易
  • BlockScout - 一种用于检查和分析基于EVM的区块链的工具。唯一以太坊网络的功能齐全的区块链浏览器。
  • Terminal - 用于监视dapp的控制面板。终端可用于监视用户,dapp,区块链基础设施,交易等。 infrastructure, transactions and more.
  • Ethereum-watcher - 用Golang编写的可扩展框架,用于侦听链上事件并做一些响应。

其他杂项工具

  • aragonPM - 由aragonOS和Ethereum支持的去中心化软件包管理器。aragonPM支持对软件包升级进行分散式管理,从而消除集中式故障点。
  • Truffle boxes - 用于快速构建DApp的打包组件
    • Cheshire - CryptoKitties API和智能合约的本地沙盒实现,可以作为松露盒使用
  • Solc - Solidity 编译器
  • Sol-compiler -项目级Solidity编译器
  • Solidity cli - 更快,更轻松,更可靠地编译Solidity代码
  • Solidity flattener - Solidity项目组合到平面文件实用程序。对于可视化导入的合同或在Etherscan上验证合同很有用
  • Sol-merger - 替代方案,将所有导入合并到单个文件中以签订固定合同
  • RLP - JavaScript中的递归长度前缀编码
  • eth-cli - 一系列CLI工具的帮助以太坊学习和开发
  • Ethereal - Ethereal是用于管理以太坊中常见任务的命令行工具
  • Eth crypto - 以太坊的加密javascript函数以及将其与web3js和solidity结合使用的教程
  • Parity Signer - 移动应用程序允许签署交易
  • py-eth - 以太坊生态系统的Python工具集合
  • truffle-flattener - 合并在Truffle框架下开发的Solidity的所有依赖项
  • Decode - npm软件包,它将tx提交到本地testrpc节点的解析,使它们更具可读性和易懂性
  • TypeChain - 以太坊智能合约的Typescript绑定
  • EthSum - 一个简单的以太坊地址校验和工具
  • PHP based Blockchain indexer - 允许索引块或侦听PHP中的事件
  • Purser - JavaScript的基于以太坊的钱包通用钱包工具。支持软件,硬件和Metamask-使所有钱包进入dApp开发的一致且可预测的界面。
  • Node-Metamask - 从node.js连接到MetaMask
  • Solidity-docgen - Solidity项目的文档生成器
  • Ethereum ETL - 将以太坊区块链数据导出到CSV或JSON文件
  • prettier-plugin-solidity - solidity-用于格式化Solidity代码的漂亮插件
  • Unity3dSimpleSample - 以太坊和Unity集成演示
  • Flappy - 以太坊和Unity集成演示/样本
  • Wonka - Nethereum业务规则引擎演示/样本
  • Resolver-Engine - 一组用于标准化框架中Solidity导入和工件解析的工具。
  • eth-reveal - 检查事务的节点和浏览器工具-使用在线找到的ABI尽可能解码方法,事件日志和任何还原原因。
  • Ethereum-tx-sender -一个用Golang编写的有用的库,用于可靠地发送交易-提取一些棘手的底层细节,例如气体优化,随机数计算,同步和重试。
  • truffle-plugin-verify - 从Truffle命令行在Etherscan上无缝验证合同源代码。

智能合约标准和类库

ERCs - 以太坊评论提案库

  • 代币
    • ERC-20 - 同质化资产的原始代币合同
    • ERC-721 - 非同质化资产的代币标准
    • ERC-777 - 替代资产的改进令牌标准
    • ERC-918 - 可采矿代币标准
  • ERC-165 - 创建一种标准方法来发布和检测智能合约实现的接口。
  • ERC-725 - 密钥管理和执行的代理合同,用于建立区块链身份。
  • ERC-173 - 合同所有权的标准接口

流行的智能合约库

第二层基础架构开发人员指南

可扩展性

付款渠道

Plasma

  • Learn Plasma - 网站作为节点应用程序,始于康奈尔大学的2018 IC3-以太坊加密新手训练营,涵盖所有Plasma用例(MVP /现金/借记)
  • Plasma MVP - OmiseGO的最小可行Plasma研究实施
  • Plasma MVP Golang -Golang实施和最小可行Plasma规范的扩展
  • Plasma Guard - 在需要时自动观察和挑战或退出Omisego Plasma网络。
  • Plasma OmiseGo Watcher - 与Plasma OmiseGo网络互动并通知任何拜占庭事件。

侧链

隐私/保密

zkSNARKs
  • ZoKrates - 以太坊上的zkSNARKS的工具箱
  • The AZTEC Protocol - 以太坊网络上的机密交易,在以太坊主网上实时实施
  • Nightfall - 将任何ERC-20 / ERC-721令牌设为私人-开源工具和微服务
  • Proxy Re-encryption (PRE)
    NuCypher Network - 代理重新加密网络,可在分散系统中实现数据保密
    pyUmbral -门限代理重新加密密码库
    ** NuFHE - NuFHE -GPU加速的FHE库

可扩展性+隐私

ZK-STARKs

预建的UI组件

转载:https://github.com/ConsenSys/ethereum-developer-tools-list

Heco系统合约分析

官方文档:https://docs.hecochain.com/#/consensus?id=%e7%b3%bb%e7%bb%9f%e5%90%88%e7%ba%a6
合约源代码:https://github.com/HuobiGroup/huobi-eco-contracts

系统合约

目前验证人的管理,均由系统合约完成,目前的系统合约有:

  • Proposal 负责管理验证人的准入资格,管理验证人提案和投票;
  • Validators 负责对验证人进行排名管理、质押和解质押操作、分发区块奖励等;
  • Punish 负责对不正常工作的活跃验证人进行惩罚操作;

区块链调用系统合约

  • 每个块结束的时候,会调用Validators合约,将区块中所有交易的手续费分发给active validator;
  • 发现validator没有正常工作的时候,会调用Punish合约,对validator进行惩罚;
  • 每个epoch结束的时候,会调用Validators合约,根据排名,更新active validator;

质押

任何账户,都可以对validator进行任意数量的质押操作,每个validator的最小质押量是32HT。 如果想取回已质押的HT,需要按照如下操作进行:

  1. 发送调用Validators合约,发送针对某一个validator的解质押(unstake)的声明交易;
  2. 等待86400个块之后,调用Validators合约,发送提取质押(withdrawStaking)的交易,将所有在此validator的质押取回;

惩罚措施

每当发现验证人没有按照预先设定进行出块的时候,就会在这个块结束时,自动调用Punish合约,对验证人进行计数。当计数达到24时,罚没验证人的所有收入。当计数达到48时,将验证人移除出活跃验证人列表,同时取消验证人资格。

合约初始化

系统合约会在第一区块时被全部初始化
(github code)
(github code2)

// Initialize all system contracts at block 1.
if header.Number.Cmp(common.Big1) == 0 {
    if err := c.initializeSystemContracts(chain, header, state); err != nil { // 在此初始化三个系统合约
        log.Error("Initialize system contracts failed", "err", err)
        return err
    }
}

取消验证验证者资格

当前验证者至少需要保留一个
https://github.com/HuobiGroup/huobi-eco-contracts/blob/d01906925c8ea017334df2e725134de0c22a17a2/contracts/Validators.sol#L757

function tryRemoveValidatorInHighestSet(address val) private {
        for (
            uint256 i = 0;
            // ensure at least one validator exist
            i < highestValidatorsSet.length && highestValidatorsSet.length > 1; // 当前验证者至少保留一个
            i++
        ) 
  1. 当前所在投票数落后于 最大验证者数(排名大于MaxValidators 21)
    https://github.com/HuobiGroup/huobi-eco-contracts/blob/d01906925c8ea017334df2e725134de0c22a17a2/contracts/Validators.sol#L611
  2. 到达惩罚条件
    https://github.com/HuobiGroup/huobi-eco-contracts/blob/d01906925c8ea017334df2e725134de0c22a17a2/contracts/Punish.sol#L68
  3. 投票数小于MinimalStakingCoin
    https://github.com/HuobiGroup/huobi-eco-contracts/blob/d01906925c8ea017334df2e725134de0c22a17a2/contracts/Validators.sol#L336

编译合约

修改solc的依赖版本

 // Configure your compilers
  compilers: {
    solc: {
      version: "^0.6.1", // 修改为该版本以上,不然会报找不到对应的版本,此时会下载0.6.12版本

编译合约

truffle compile

此时会在./build/contracts下生成各个合约对应的abi json文件

参考

https://ethereum.stackexchange.com/questions/234/what-is-an-abi-and-why-is-it-needed-to-interact-with-contracts
https://ethereum.stackexchange.com/questions/1437/do-i-need-a-compiled-contract-just-to-get-the-abi-definition
https://zhuanlan.zhihu.com/p/26089385

Heco 编译及多节点部署

运行环境

测试环境
OS: Ubuntu 18.04
Go: go1.15.6 linux/amd64

源代码

git clone https://github.com/HuobiGroup/huobi-eco-chain.git

当前测试 master 分支

编译

cd huobi-eco-chain/
make geth

编译完成后,生成文件在./build/bin/geth

创建 geth.toml

参考 https://github.com/HuobiGroup/huobi-eco-chain-docs/blob/master/dev/deploy.md

[Eth]
SyncMode = "fast"
DiscoveryURLs = []
TrieCleanCacheRejournal= 300000000000

[Eth.Miner]
GasFloor = 8000000
GasCeil = 8000000
GasPrice = 0
Recommit = 3000000000
Noverify = false

[Eth.Ethash]
CacheDir = "ethash"
CachesInMem = 2
CachesOnDisk = 3
CachesLockMmap = false
DatasetDir = "/data/heco/data/.ethash"
DatasetsInMem = 1
DatasetsOnDisk = 2
DatasetsLockMmap = false
PowMode = 0

[Eth.TxPool]
Locals = []
NoLocals = false
Journal = "transactions.rlp"
Rejournal = 3600000000000
PriceLimit = 1
PriceBump = 10
AccountSlots = 16
GlobalSlots = 4096
AccountQueue = 64
GlobalQueue = 1024
Lifetime = 10800000000000

[Node]
DataDir = "/data/heco/data"
InsecureUnlockAllowed = true
NoUSB = true
IPCPath = "geth.ipc"
HTTPHost = "0.0.0.0"
HTTPPort = 8545
HTTPCors = ["*"]
HTTPVirtualHosts = ["*"]
HTTPModules = ['eth', 'net', 'web3']

WSHost = "0.0.0.0"
WSPort = 8546
WSModules = ['eth', 'net', 'web3']

GraphQLVirtualHosts = ["localhost"]


[Node.P2P]
MaxPeers = 50
NoDiscovery = false

ListenAddr = ":32668"
EnableMsgEvents = false

[Node.HTTPTimeouts]
ReadTimeout = 30000000000
WriteTimeout = 30000000000
IdleTimeout = 120000000000

预先创建一个账户地址

使用MetaMask或者其他工具预先创建一个账户地址,并保存好私钥,后面这个地址会配置在初始的Validators中,并用做boot节点启动挖矿coinbase地址

创建genesis.json

参考https://docs.hecochain.com/#/genesis
根据需要修改特定的字段,常规的比如

  • chainId 修改为自己的独有链id
  • extraData 修改为预先创建的地址
  • alloc中的0xdaf88b74fca1246c6144bc846aaa3441ed095191修改为初始资金接收地址,balance根据业务需要,计算相应预先发行数量(精度18位)的16进制

对于共识参数,根据需要再做修改吧

"congress": {
    "period": 3, // 出块间隔(秒)
    "epoch": 200 // 出块顺序刷新间隔(块数)
}

初始化并启动geth

将上面修改好的geth.tomlgenesis.json放到规划好的位置,我们此时假设为/data/heco

初始化geth

在上面目录/data/heco中执行数据初始化

./geth --datadir ./data init genesis.json

我们将链相关数据保存在/data/heco/data下,方便磁盘数据管理,以及后期磁盘空间升级及其迁移

首次启动geth

./geth --config geth.toml --nodiscover

启动后,进入ipc导入我们预先生成的地址私钥,作为此节点的coinbase
从另一个终端进入

./geth attach ipc:/data/heco/data/geth.ipc

在geth命令行中导入预先生成地址的私钥,123456为钱包密码,在此目录创建password文件,并将密码保存在该文件,后面后台启动会需要

personal.importRawKey("e9bc9ae610535514。。。56a272f69fd59d7986b9f4f49c025cc","123456")

并设置该地址为无限期解锁,因为后面需要使用该私钥进行出块签名。0为无限期

personal.unlockAccount("0x48F155527f2。。。7e84692AA0025C0","123456",0)

此时geth命令行中输入eth,查看

> eth
{
  accounts: ["0x48F155527f2。。。7e84692AA0025C0"],
  blockNumber: 4412,
  coinbase: "0x48F155527f2。。。7e84692AA0025C0",

accountscoinbase都为预先生成的地址

后台运行geth

此时关闭前面运行的geth,重新后台运行

nohup ./geth --config geth.toml --networkid 65525 --unlock "0x48F155527f2。。。7e84692AA0025C0" --password ./password --mine --nodiscover --etherbase 0 2>> ./geth.log &

此时查看geth.log文件

tail -f geth.log

即可看到geth 已经正常单节点出块

测试查询

查看前面预先设置的初始资金接收地址

eth.getBalance("0x48F155527。。。。692AA0025C0")

可查看到,该地址已经存入了balance设置对应的代币

测试转账

eth.sendTransaction({from: "0x48F155527f25EB1。。。。4692AA0025C0" , to: "0x5849cce8b6ea2。。。。7436b628df34217", value: web3.toWei(10,"ether")})

执行完,查看from和to双方账户资金转移正常

MetaMask扩展配置

Chrome浏览器安装好扩展后,进入设置->网络->添加网络,输入相关信息

  • 网络名称 -> 任意信息,只是本地备注
  • 新增 RPC URL -> 该geth运行所在服务器访问地址+端口(端口是上面geth.toml配置的Node->HTTPPort)
  • 链ID -> 上面genesis.json中配置的chainId
  • 符号(选填)-> 该节点的系统代币的符号
  • 屏蔽管理器 URL(选填)-> 汉化翻译不准确,其实就是区块浏览器的地址,后期可以自己拿Etherscan自己部署一套

此时就可以通过MetaMask扩展进行地址代币管理了

多节点部署

如果只是本地测试,单点足以满足需求的话,可以不必继续部署
在其他需要部署节点的服务器上准备好geth节点程序以及上面同样的geth.toml和genesis.json文件,(同一机器多个geth运行实例,修改对应端口和data目录,流程同理)
然后照搬上面的流程的初始化并启动geth后台运行geth
执行完成后会报

WARN [02-24|15:35:05.457] Block sealing failed                     err="unauthorized validator"

是因为此节点的coinbase并不在初始的Validators中,先忽略,等下后面跟进合约动态添加到Validators

数据链接

由于节点启动时关闭了自发现,所以需要我们主动去连接下
两边节点分别查下节点信息

admin.nodeInfo

将enode存下来,将ip地址127.0.0.1修改为当前节点对应的可其他节点访问的地址
节点A

enode://219a81569be3b9f3e261f40e0edbf4893ccde5bc94df6525135eacc337122ef060bad7f220d90622349ab189b87106f26637520f272e5ae73f9797cd6506ddd4@172.17.116.158:32668?discport=0

节点B

enode://425ef46887ac2cb08076bc78e54ba11fb280c9cb2ff6a7bc173001933cfcd2b98b9f49afa3ac3857cc5e49ad01e64595a07c8c2053416390459409da7920a1c9@172.17.116.159:32668?discport=0

然后分别再对方节点上增加自己的节点
节点A执行

admin.addPeer("enode://425ef46887ac2cb08076bc78e54ba11fb280c9cb2ff6a7bc173001933cfcd2b98b9f49afa3ac3857cc5e49ad01e64595a07c8c2053416390459409da7920a1c9@172.17.116.159:32668?discport=0")

节点B执行

admin.addPeer("enode://219a81569be3b9f3e261f40e0edbf4893ccde5bc94df6525135eacc337122ef060bad7f220d90622349ab189b87106f26637520f272e5ae73f9797cd6506ddd4@172.17.116.158:32668?discport=0")

此时A节点正常出块,B节点正常从A节点同步区块,其他节点同理加入

编译合约

修改solc的依赖版本

 // Configure your compilers
  compilers: {
    solc: {
      version: "^0.6.1", // 修改为该版本以上,不然会报找不到对应的版本,此时会下载0.6.12版本

编译合约

truffle compile

此时会在./build/contracts下生成各个合约对应的abi json文件
其中的"abi"节点的内容,就是下面myetherwallet要用到的abi

合约设置

经过上面的操作,多节点网络已经运行了,下一步进行系统合约设置
以下合约操作通过https://www.myetherwallet.com/interface/interact-with-contract 工具进行交互

申请成为出块节点

选择执行createProposal
参数

  • dst 需要申请添加的地址
  • details 附加信息(选填)

对于genesis的预设地址,默认会在系统初始化时,自动添加到审核通过

审核出块申请

选择执行voteProposal,当前设计,合约签名地址需要为已经通过申请的用户,赞同总数或者拒绝总数,哪个先超过当前正在出块人数的 1/2+1,就执行对应的决定。这个不合理,应该是需要正在出块人中的1/2+1赞同才有效,那些之前通过审核,但不是正在出块的地址,没有审核资格。
参数

取消出块资质

选择执行setUnpassed,目前合约需要当前合约权限才能禁止掉其他人,不合理,后面进行合约修改,同样需要发起申请,通过1/2+1人通过,才会取消对应地址的资格。

创建validator地址

选择执行createOrEditValidator,需要先申请,通过后才允许创建
参数

  • feeAddr 该矿工领取奖励时的接收地址
  • moniker 昵称(选填)
  • identity 身份(选填)
  • website 网址(选填)
  • email 邮箱(选填)
  • details 附加信息(选填)

抵押系统代币

选择执行stake,需要创建完validator,才能进行抵押,抵押量不小于32 ether,后面挖矿奖励会根据当前用户抵押量所占总比例进行分配。

矿工主动提交所得,进行分配

链程序出块后,自动执行distributeBlockReward将打包所得手续费转到合约进行池分配(后期排查,节点程序是否可作恶,抽水),代币总量到合约后,合约根据currentValidatorSet中各自地址抵押总额,以及各自占比进行分配记账(validatorInfo[地址].hbIncoming),(对于合约分配逻辑,后面单独写文章讲解)

领取出块奖励

选择执行 withdrawProfits,参数validator为矿工地址,执行签名地址需要与创建时设置的feeAddr一致,领取时间间隔24小时(28800块)

参考

https://github.com/sigp/lighthouse/issues/2115

基于ETH的链修改调研

调研背景

目前有个项目计划基于ETH做链修改,完成类似DPOS版本的ETH,
主要是为了整合现有的ETH生态,以及一些商业需求。
也为后面EOS商业链中间层组件(IBC Relayer)做储备。

现有三方项目

https://github.com/HuobiGroup/huobi-eco-chain
https://github.com/meitu/go-ethereum
https://github.com/mingjingc/dpos-go-ethereum
https://github.com/TTCECO/gttc
https://github.com/linapex/ethereum-dpos-chinese

参考文档

https://zhuanlan.zhihu.com/p/38013479
https://www.jianshu.com/p/d99c0a5afbe8

让区块链浏览器收录你的 ERC20 代币

如果想让其他浏览器显示新发的代币,需要主动提交代币信息,对方审核通过后,即可显示。

打开网址https://etherscan.io,在此处输入 token 的智能合约地址,如下图:

搜索后,如下图:

按下图指示,点击“verify and publish”来发布代码,

由于读者已经发布了代码,这里就找了几张图贴出来,以供参考。

步骤一:

步骤二:

步骤三:

若出现如下图,即表示收录成功。

转载:https://my.oschina.net/u/3050295/blog/1982504