這篇文章主要介紹“EOS開發(fā)環(huán)境的搭建”,在日常操作中,相信很多人在EOS開發(fā)環(huán)境的搭建問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”EOS開發(fā)環(huán)境的搭建”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
創(chuàng)新互聯(lián)建站是少有的成都做網(wǎng)站、網(wǎng)站制作、營銷型企業(yè)網(wǎng)站、微信小程序定制開發(fā)、手機(jī)APP,開發(fā)、制作、設(shè)計、買友情鏈接、推廣優(yōu)化一站式服務(wù)網(wǎng)絡(luò)公司,自2013年創(chuàng)立以來,堅持透明化,價格低,無套路經(jīng)營理念。讓網(wǎng)頁驚喜每一位訪客多年來深受用戶好評
下載所有的EOSIO代碼,clone eos
庫和所有的子模塊。
shell 命令如下:
git clone https://github.com/EOSIO/eos --recursive
如果忘記加 --recursive
參數(shù)也沒關(guān)系,隨后也可以用命令 clone 所有子模塊。
git submodule update --init --recursive
EOSIO可以在多個平臺上安裝構(gòu)建,并有各種路徑進(jìn)行安裝構(gòu)建。大多數(shù)用戶更喜歡使用自動化腳本或docker,而更高級的用戶或希望部署公共節(jié)點(diǎn)的用戶可能需要手動方法。構(gòu)建內(nèi)容生成在eos/build
文件夾中。可執(zhí)行文件可以在eos/build/programs
文件夾的子文件夾中找到。
自動化腳本 :適合于大多數(shù)開發(fā)人員,這個腳本是基于Mac OS和許多Linux版本的。
docker-compose方式 :到目前為止最快的安裝方法,可以在兩分鐘內(nèi)啟動并運(yùn)行一個節(jié)點(diǎn)。也就是說,它需要一些額外的本地配置來進(jìn)行開發(fā),以便順利運(yùn)行并遵循我們提供的教程。
手動安裝構(gòu)建:適用于那些可能對自動化腳本有沖突的環(huán)境,或者希望對其構(gòu)建進(jìn)行更多控制的開發(fā)者。
可執(zhí)行文件安裝構(gòu)建:一個可選的make install
步驟,可以使本地開發(fā)更加友好。
如果你是新手,建議直接看通過docker快速構(gòu)建安裝EOSIO。
有一個自動化的構(gòu)建腳本,可以安裝所有依賴項(xiàng)并構(gòu)建EOSIO。腳本支持以下操作系統(tǒng)。
我們正在支持和將來發(fā)布會支持的Linux/UNIX發(fā)行版。
Amazon 2017.09 和更高版本。
Centos 7。
Fedora 25和更高版本(推薦 Fedora 27)。
Mint 18。
Ubuntu 16.04(推薦 Ubuntu 16.10)。
MacOS Darwin 10.12和更高版本(推薦 MacOS 10.13.x)。
從eos
目錄運(yùn)行安裝構(gòu)建腳本:
cd eos ./eosio_build.sh
如果你只是想跑起來,可能通過docker快速構(gòu)建安裝EOSIO更適合。否則你想了解更高級的構(gòu)建,那么繼續(xù)。
Docker:Docker 17.05或更高版本
docker-compose :版本>= 1.10.0
至少7GB RAM(DOCK->首選項(xiàng)->高級->內(nèi)存->7GB或以上)
如果安裝構(gòu)建失敗,請確保你已經(jīng)調(diào)整了Docker內(nèi)存設(shè)置,然后再試一次。
git clone https://github.com/EOSIO/eos.git --recursive --depth 1 cd eos/Docker docker build . -t eosio/eos
以上將在默認(rèn)情況下構(gòu)建對主分支的最新提交。如果想針對特定的分支/tag,可以使用生成參數(shù)。例如,如果希望根據(jù)v1.0.0 tag生成Docker鏡像,可以執(zhí)行以下操作:
docker build -t eosio/eos:v1.0.0 --build-arg branch=v1.0.0 .
默認(rèn)情況下,eosio.system的 symbol 設(shè)置為SYS
。在構(gòu)建Docker鏡像時,可以使用 symbol 參數(shù)來做到這一點(diǎn)。
docker build -t eosio/eos --build-arg symbol=ABC.
docker run --name nodeos -p 8888:8888 -p 9876:9876 -t eosio/eos nodeosd.sh -e arg1 arg2
默認(rèn)情況下,所有數(shù)據(jù)都保存在docker卷中。如果數(shù)據(jù)過時或損壞,則可以刪除它:
$ docker inspect --format '{{ range .Mounts }}{{ .Name }} {{ end }}' nodeos fdc265730a4f697346fa8b078c176e315b959e79365fc9cbd11f090ea0cb5cbc $ docker volume rm fdc265730a4f697346fa8b078c176e315b959e79365fc9cbd11f090ea0cb5cbc
或者,可以直接將宿主目錄安裝到docker中。
docker run --name nodeos -v /path-to-data-dir:/opt/eosio/bin/data-dir -p 8888:8888 -p 9876:9876 -t eosio/eos nodeosd.sh -e arg1 arg2
curl http://127.0.0.1:8888/v1/chain/get_info
docker volume create --name=nodeos-data-volume docker volume create --name=keosd-data-volume docker-compose up -d
在docker-compose -d
之后,將啟動nodeos
和keosd
兩個服務(wù)。nodeos服務(wù)會將端口8888和9876提供給主機(jī)。kesod服務(wù)不向主機(jī)公開任何端口,只有當(dāng)在cleos容器中運(yùn)行cleos時,cleos才可以訪問它。
你可以運(yùn)行cloes
通過bash別名
alias cleos='docker-compose exec keosd /opt/eosio/bin/cleos -u http://nodeosd:8888 --wallet-url http://localhost:8900' cleos get info cleos get account inita
如果你想在任何地方使用cleos
命令,你可以在docker-compose.yml
指定路徑:
alias cleos='docker-compose -f path-to-eos-dir/Docker/docker-compose.yml exec keosd /opt/eosio/bin/cleos -u http://nodeosd:8888 --wallet-url http://localhost:8900'
提交exchange示例合約:
cleos set contract exchange contracts/exchange/
如果你不需要keosd
,可以停止使用keosd
服務(wù):
docker-compose stop keosd
由于eosio/eos鏡像不包含合約開發(fā)所需的依賴關(guān)系(這樣設(shè)計是為了保持較小鏡像尺寸),所以需要使用 eosio/eos-dev鏡像。此鏡像包含使用eosiocpp構(gòu)建合約的所需二進(jìn)制文件和依賴項(xiàng)。
可以使用Docker Hub上可用的鏡像或進(jìn)入到dev文件夾并手動構(gòu)建鏡像。
cd dev docker build -t eosio/eos-dev .
可以使用docker compose更改默認(rèn)配置。例如,創(chuàng)建一個備用配置文件config2.ini
和docker-compose.override.yml
,內(nèi)容如下:
version: "2" services: nodeos: volumes: - nodeos-data-volume:/opt/eosio/bin/data-dir - ./config2.ini:/opt/eosio/bin/data-dir/config.ini
然后重啟docker:
docker-compose down docker-compose up
docker-compose創(chuàng)建的data卷可以被刪除:
docker volume rm nodeos-data-volume docker volume rm keosd-data-volume
Docker Hub 鏡像來自docker hub
建立一個新的docker-compose.yaml
文件內(nèi)容如下:
version: "3" services: nodeosd: image: eosio/eos:latest command: /opt/eosio/bin/nodeosd.sh --data-dir /opt/eosio/bin/data-dir -e hostname: nodeosd ports: - 8888:8888 - 9876:9876 expose: - "8888" volumes: - nodeos-data-volume:/opt/eosio/bin/data-dir keosd: image: eosio/eos:latest command: /opt/eosio/bin/keosd --wallet-dir /opt/eosio/bin/data-dir --http-server-address=127.0.0.1:8900 hostname: keosd links: - nodeosd volumes: - keosd-data-volume:/opt/eosio/bin/data-dir volumes: nodeos-data-volume: keosd-data-volume:
注意:默認(rèn)版本是最新版本,可以將其更改為你想要的版本。
運(yùn)行: docker pull eosio/eos:latest
運(yùn)行: docker-compose up
我們可以很容易地建立一個EOSIO 1.0本地Testnet測試鏈,使用docker鏡像。只需運(yùn)行以下命令:
注意:如果你想使用mongo db插件,你必須首先在data-dir/config.ini
啟用它。
# pull images docker pull eosio/eos:v1.0.0 # create volume docker volume create --name=nodeos-data-volume docker volume create --name=keosd-data-volume # start containers docker-compose -f docker-compose-eosio1.0.yaml up -d # get chain info curl http://127.0.0.1:8888/v1/chain/get_info # get logs docker-compose logs -f nodeosd # stop containers docker-compose -f docker-compose-eosio1.0.yaml down
默認(rèn)情況下,blocks
數(shù)據(jù)存儲在--data-dir
下,默認(rèn)情況下錢包文件存儲在--wallet-dir
下,當(dāng)然,你可以根據(jù)需要更改這些文件路徑。
目前,MongoDB插件在config.ini
中被禁用,默認(rèn)情況下,必須在config.ini
中手動更改它,或者可以在docker-compose文件中將config.ini
文件mount到/opt/eosio/bin/data-dir/config.ini
。
若要手動生成,請使用以下步驟在eos
文件夾中創(chuàng)建build
文件夾,然后執(zhí)行build。下面的步驟假設(shè)eos
存儲庫被clone到home(即,~)文件夾中。還假定已經(jīng)安裝了必要的依賴項(xiàng)。請參見手動安裝依賴項(xiàng)。
cd ~ mkdir -p ~/eos/build && cd ~/eos/build
在Linux平臺上,使用這個cmake
命令:
cmake -DBINARYEN_BIN=~/binaryen/bin -DWASM_ROOT=~/wasm-compiler/llvm -DOPENSSL_ROOT_DIR=/usr/local/opt/openssl -DOPENSSL_LIBRARIES=/usr/local/opt/openssl/lib -DBUILD_MONGO_DB_PLUGIN=true ..
在MacOS上,使用這個cmake
命令:
cmake -DBINARYEN_BIN=~/binaryen/bin -DWASM_ROOT=/usr/local/wasm -DOPENSSL_ROOT_DIR=/usr/local/opt/openssl -DOPENSSL_LIBRARIES=/usr/local/opt/openssl/lib -DBUILD_MONGO_DB_PLUGIN=true ..
然后在所在平臺上執(zhí)行:
make -j$( nproc )
也支持Out-of-source安裝構(gòu)建。若要在編譯器中重寫默認(rèn)選擇,請將這些標(biāo)志添加到CMake命令:
-DCMAKE_CXX_COMPILER=/path/to/c++ -DCMAKE_C_COMPILER=/path/to/cc
對于調(diào)試模式的安裝構(gòu)建,添加-DCMAKE_BUILD_TYPE=Debug
。其他常見的構(gòu)建類型包括Release
和RelWithDebInfo
。
為了便于智能合約開發(fā),可以使用make install
將目標(biāo)內(nèi)容安裝到/usr/local
中。此步驟要從build
目錄下運(yùn)行的。需要適當(dāng)?shù)陌惭b權(quán)限。
cd build sudo make install
內(nèi)存 7GB
硬盤 20GB
可選地,可以對我們的構(gòu)建運(yùn)行一組測試,以執(zhí)行一些基本驗(yàn)證。要在構(gòu)建后運(yùn)行測試套件,啟動mongod
然后運(yùn)行make test
。
在 Linux 平臺上:
~/opt/mongodb/bin/mongod -f ~/opt/mongodb/mongod.conf &
在 MacOS 平臺上:
/usr/local/bin/mongod -f /usr/local/etc/mongod.conf &
然后執(zhí)行下面的操作:
cd build make test
到此,關(guān)于“EOS開發(fā)環(huán)境的搭建”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!