EOS区块链的开发并非立竿见影的,由于须要一些非显而易见的组件,须要对它们进行配置和协同工做。前端
要学习本教程,你须要使用下面的软件:node
你能够直接在Linux操做系统上安装如下组件,但这样可使你的开发环境更加干净,更易于维护和测试。git
如下全部文件均为官方文件,并由EOSIO发布:github
FROM ubuntu:18.04 RUN apt-get update && apt-get install -y curl libicu60 libusb-1.0-0 libcurl3-gnutls RUN curl -LO https://github.com/EOSIO/eos/releases/download/v1.7.0/eosio_1.7.0-1-ubuntu-18.04_amd64.deb \ && dpkg -i eosio_1.7.0-1-ubuntu-18.04_amd64.deb RUN curl -LO https://github.com/EOSIO/eosio.cdt/releases/download/v1.6.1/eosio.cdt_1.6.1-1_amd64.deb \ && dpkg -i eosio.cdt_1.6.1-1_amd64.deb RUN curl -LO https://github.com/EOSIO/eosio.cdt/archive/v1.6.1.tar.gz && tar -xvzf v1.6.1.tar.gz --one-top-level=eosio.cdt --strip-components 1 RUN cd /eosio.cdt/ && curl -LO https://github.com/EOSIO/eosio.contracts/archive/v1.6.0-rc3.tar.gz && tar -xvzf v1.6.0-rc3.tar.gz --one-top-level=eosio.contracts --strip-components 1
你可使用如下命令生成打包的镜像沙箱:docker
docker build -t my/eos .
正如我所说,须要一些配置来互相讨论所需的全部部分。编程
default.wallet
是一个预配置的钱包,带有用于测试的私钥。config.ini
是Block Producer(BP)的文件,在EOS Mainnet中你不会/不能改变它。version: '3' services: nodeos: container_name: nodeos image: my/eos command: nodeos -e -p eosio --plugin eosio::producer_plugin --plugin eosio::history_plugin --plugin eosio::chain_api_plugin --plugin eosio::history_api_plugin --plugin eosio::http_plugin --http-server-address=0.0.0.0:8888 --access-control-allow-origin=* --contracts-console --http-validate-host=false --filter-on="*" stop_grace_period: 3m0s volumes: - ./:/eosio.cdt/contract - ./config.ini:/root/.local/share/eosio/nodeos/config/config.ini ports: - '8888:8888' - '9830:9876' depends_on: - keosd keosd: container_name: keosd hostname: keosd image: my/eos command: keosd --http-server-address=0.0.0.0:8901 --http-validate-host 0 --verbose-http-errors --unlock-timeout=9999999 volumes: - ./default.wallet:/root/eosio-wallet/default.wallet expose: - 8901 ports: - '8901:8901'
在新终端中运行如下命令:bootstrap
docker-compose up
恭喜!你正在EOS Localnet中生成块!ubuntu
初始化的乐趣还没有结束,由于你仍须要部署智能合约以得到EOS token货币!api
好的,EOS区块链正在运行,但如今咱们须要另外一个终端与它进行交互。bash
alias cleos="docker exec -it nodeos cleos --url http://127.0.0.1:8888 --wallet-url http://keosd:8901" cleos get info
{ "server_version": "686f0deb", "chain_id": "cf057bbfb72640471fd910bcb67639c22df9f92470936cddc1ade0e2f2e7dc4f", "head_block_num": 85, "last_irreversible_block_num": 84, "last_irreversible_block_id": "000000541c75df656485edb9fb71e898db933c78f685fc7a8d883544d141350d", "head_block_id": "0000005580f8983a211e4dcddbb783d6bc962726ef271beeee54b63bd906b5a0", "head_block_time": "2019-03-30T09:37:33.500", "head_block_producer": "eosio", "virtual_block_cpu_limit": 217493, "virtual_block_net_limit": 1140464, "block_cpu_limit": 199900, "block_net_limit": 1048576, "server_version_string": "v1.7.0" }
正如你在输出中看到的,最新的块是85,而chain_is是testnet中使用的块。
目前没有EOS token,因此让咱们添加它们,
编译它们:
docker exec -it nodeos bash -c "cd /eosio.cdt/eosio.contracts/contracts/ && eosio-cpp -I eosio.token/include/ -abigen -o eosio.token/src/eosio.token.wasm eosio.token/src/eosio.token.cpp"
建立eosio.token
账户并发布智能合约:
cleos create account eosio eosio.token EOS6MRyAjQq8ud7hVNYcfnVPJqcVpscN5So8BhtHuGYqET5GDW5CV EOS6MRyAjQq8ud7hVNYcfnVPJqcVpscN5So8BhtHuGYqET5GDW5CV executed transaction: d196c673f38085e34815900dd47de8ba030d14ed9d7311a1a173df131281e66a 200 bytes 2568 us # eosio <= eosio::newaccount {"creator":"eosio","name":"eosio.token","owner":{"threshold":1,"keys":[{"key":"EOS6MRyAjQq8ud7hVNYcf... warning: transaction executed locally, but may not be confirmed by the network yet ] cleos set contract eosio.token /eosio.cdt/eosio.contracts/contracts/eosio.token/src eosio.token.wasm eosio.token.abi -p eosio.token@active Reading WASM from /eosio.cdt/eosio.contracts/contracts/eosio.token/src/eosio.token.wasm... Publishing contract... executed transaction: 1b4b532337035ad4cd985d1cb63c844b84671ed574251a85519fc51c8fb4f290 9592 bytes 10523 us # eosio <= eosio::setcode {"account":"eosio.token","vmtype":0,"vmversion":0,"code":"0061736d0100000001bb011f60000060037f7e7f00... # eosio <= eosio::setabi {"account":"eosio.token","abi":"0e656f73696f3a3a6162692f312e310008076163636f756e7400010762616c616e63... warning: transaction executed locally, but may not be confirmed by the network yet ]
建立你的testuser账户,并给本身一些免费的钱!:D
cleos create account eosio testuser EOS6K42yrrMETmx2rXFJeKtaGrQAwgCDBYUVY7PGCVfhWFykqvhVR EOS6K42yrrMETmx2rXFJeKtaGrQAwgCDBYUVY7PGCVfhWFykqvhVR cleos push action eosio.token create '[ "eosio", "1000000000.0000 EOS"]' -p eosio.token@active cleos push action eosio.token issue '[ "testuser", "100000.0000 EOS", "m" ]' -p eosio@active
恭喜你,如今你是富翁了!
cleos get currency balance eosio.token testuser 100000.0000 EOS cleos get table eosio.token testuser accounts { "rows": [{ "balance": "100000.0000 EOS" } ], "more": false }
你的第一笔交易:
cleos push action eosio.token transfer '["testuser","eosio.token","10.0000 EOS", "BUY LAMBOOO!!!"]' -p testuser@active cleos get currency balance eosio.token testuser 99990.0000 EOS
正如你在购买lambo后所看到的那样,EOS余额已经减小了,你使用了testuser权限来实现它。
每次初始化EOS区块链时,全部这些清除步骤均可以自动,分组和顺序执行。
咱们已经简要介绍了如何使用docker和一些基本测试来设置本地EOS Testnet。cleos
和docker
的美妙之处在于咱们能够在几分钟内自动化AD,拥有一个干净的新工做EOS环境。全部命令都不须要手动执行,咱们能够将它们放在自定义bootstrap.sh
中,以便在须要时从新建立所需的环境。
======================================================================
分享一些EOS区块链相关的交互式在线编程实战教程:
- EOS入门教程,本课程帮助你快速入门EOS区块链去中心化应用的开发,内容涵盖EOS工具链、帐户与钱包、发行代币、智能合约开发与部署、使用代码与智能合约交互等核心知识点,最后综合运用各知识点完成一个便签DApp的开发。
- 深刻浅出玩转EOS钱包开发,本课程以手机EOS钱包的完整开发过程为主线,深刻学习EOS区块链应用开发,课程内容即涵盖帐户、计算资源、智能合约、动做与交易等EOS区块链的核心概念,同时也讲解如何使用eosjs和eosjs-ecc开发包访问EOS区块链,以及如何在React前端应用中集成对EOS区块链的支持。课程内容深刻浅出,很是适合前端工程师深刻学习EOS区块链应用开发。
汇智网原创翻译,转载请标明出处。这里是如何使用docker和docker-compose在EOS本地Testnet上开发