EOS 로컬 개발 환경 구성

in #coinkorea7 years ago (edited)

EOS 로컬 개발 환경 구성

EOSIO 1.0.0이 출시되었다.

공식 문서인 https://github.com/EOSIO/eos/wiki/Local-Environment 를 기준으로 약간의 커스터마이징과 과도한 친절함을 가미했다.

참고로 이 글은 EOSIO 1.0.0의 바로 앞 버전인 EOSIO Dawn 4.2를 기준으로 작성되었으나 EOSIO 1.0.0 에서도 그대로 적용할 수 있다.

EOSIO 아키텍처

EOSIO는 여러개의 컴포넌트로 구성되어 있다. 가장 중요한 3가지는 다음과 같다.

  • nodeos: 서버 사이드 블록체인 노드
  • cleos: 블록체인과의 상호작용 및 지갑 관리 컴포넌트인 keosd에 대한 CLI(명령행 인터페이스)
  • keosd: EOSIO 지갑 관리 컴포넌트

위 3가지 컴포넌트의 관계는 다음 그림과 같다.

Imgur

사전 조건

OS

공식 문서에 아래와 같이 안내 되어 있다. 이 문서는 Linux Mint 18.3에서 빌드하고 작성했다.

  1. Amazon 2017.09 and higher.
  2. Centos 7.
  3. Fedora 25 and higher (Fedora 27 recommended).
  4. Mint 18.
  5. Ubuntu 16.04 (Ubuntu 16.10 recommended).
  6. MacOS Darwin 10.12 and higher (MacOS 10.13.x recommended).

용량

  • RAM: 8G 이상
  • Disk: 20G 이상

소스 가져오기

문서에는 EOSIO의 리포지토리를 직접 clone하도록 안내하고 있지만, Pull Request도 보내면서 개발하려면 각자 fork 뜬 리포지토리를 clone하는 것이 좋다.

각자 fork 뜬 리포지토리의 URL을 https://github.com/YOUR_USERNAME/eos라고 하면, 다음과 같이 clone 하면 된다.

$ git clone https://github.com/YOUR_USERNAME/eos --recursive

빌드

EOSIO 에서 제공하는 빌드 스크립트를 실행하면 된다.

$ cd eos

$ ./eosio_build.sh

자잘한 버그 수정

아래 기술한 빌드 스크립트 에러는 이미 Pull Request가 받아들여져서 현재 릴리스 버전인 EOSIO 1.0.1 에서는 발생하지 않으나, 참고로 내용만 남겨둔다.

그런데 우분투 용 빌드 스크립트에는 의존 관계 구성 관련 사소한 버그가 있어서, 빌드 스크립트를 살짝 고치고 Pull Request를 날려두었다.

https://github.com/EOSIO/eos/pull/2979/files

이 글을 보는 시점에 Pull Request가 반영되어있다면 아래 내용은 무시하고 다음 단원으로 건너뛰면 된다.

원본 그대로 실행하면 먼저 다음과 같이 라이브러리를 설치해야 한다는 안내가 나온다.

Imgur

메시지가 살짝 깨져 나오지만 일단 넘어가고, 1 을 입력하고 엔터를 치면 설치가 안 되고 다음과 같은 에러가 난다.

Imgur

위의 Pull Request 링크를 참고해서 scripts/eosio_build_ubuntu.sh파일을 수정하고 다시 ./eosio_build.sh를 실행해서, 라이브러리 설치 문의 시 1을 입력하고 엔터를 치면 다음과 같이 라이브러리 설치가 정상적으로 진행된다.

Imgur

기다림

라이브러리 설치 후 Boost, mongoDB, LLVM 등도 빌드하는데 넉넉 잡아 120분 정도 소요되었다. 느긋한 기다림이 필요하다. 생산 되는 로그량도 20,000라인을 넘는다.

몇 가지 화면 캡처를 떠놨으니 미리 구경해보자.

Boost

별 문제없이 설치된다.

Imgur

mongoDB

별 문제없이 설치된다.

Imgur

Imgur

Imgur

secp256k1-zkp

mongoDB 설치까지 완료된 후 지루할만 하니 에러가 나준다(이것도 Pull Request가 받아들여져서 더는 발생하지 않을 것이다).

Imgur

aclocal이 없다는 얘긴데 automake를 설치하면 해결된다.

$ sudo apt install automake

Imgur

automake 설치 완료 되면 다시 ./eosio_build.sh를 실행한다.

Imgur

아까 받아둔 파일이 있어서 문제라고 하니 개뿐하게 지워주고, 다시 ./eosio_build.sh를 실행한다.

Imgur

LLVM

이제 secp256k1-zkp도 깔끔하게 설치되고 다음 단계인 LLVM으로 넘어간다. LLVM은 별 문제없이 설치된다.

Imgur

Imgur

EOSIO

이제 드디어 EOSIO 설치로 넘어간다. EOSIO는 별 문제없이 설치된다.

Imgur

Imgur

드디어 빌드가 완성 되었다. 총 90분 정도 걸렸다고 나오는데, 중간에 오류 나기 전에 설치되는 것들까지 감안하면 CPU i5-2500 3.3GHz, RAM 8G 정도로 넉넉잡아 2시간은 걸린 것 같다.

테스트

위 빌드 결과에 안내해준 대로 테스트를 수행해보자.

export PATH=${HOME}/opt/mongodb/bin:$PATH

/home/hanmomhanda/opt/mongodb/bin/mongod -f /home/hanmomhanda/opt/mongodb/mongod.conf &

cd /home/hanmomhanda/gitRepo/crypto/eos/build

make test

Imgur

Imgur

테스트도 시간은 10여분 정도 걸렸지만 문제없이 모두 통과한다.

설치

/eos/build 디렉터리에서 sudo make install을 실행해서 설치하면 실행 파일이 /usr/local/bin에 설치된다.

Imgur

Imgur

Imgur

원본 리포지토리(upstream)와 Fork 리포지토리 Sync

upstream remote 추가

https://help.github.com/articles/configuring-a-remote-for-a-fork/ 를 참고해서 다음을 실행한다.

  1. 현재 remote 확인

    $ git remote -v

    origin  https://github.com/YOUR_USERNAME/eos.git (fetch)
    origin  https://github.com/YOUR_USERNAME/eos.git (push)
    
  2. 원본 리포지토리를 가리키는 upstream 추가

    $ git remote add upstream https://github.com/EOSIO/eos.git

  3. upstream 확인

    $ git remote -v

    origin    https://github.com/YOUR_USERNAME/eos.git (fetch)
    origin    https://github.com/YOUR_USERNAME/eos.git (push)
    upstream  https://github.com/EOSIO/eos.git (fetch)
    upstream  https://github.com/EOSIO/eos.git (push)
    

원본 리포지토리와 Sync

EOSIO 프로젝트가 진행되면서 버전이 올라가면 로컬 개발 환경의 버전도 맞춰줘야 한다.

그냥 일반적인 remote 리포지토리와 Sync하는 것과 다르지 않다.

https://help.github.com/articles/syncing-a-fork/ 를 참고하되, git merge 뿐아니라 git rebase도 물론 쓸 수 있다.

로컬의 master 브랜치에서 다음과 같이 git fetch upstream으로 EOSIO 의 최신 내용을 가져온다.

git fetch upstream

Imgur

rebase로 EOSIO의 최신 버전을 베이스로 설정한다(merge도 가능).

git rebase upstream/master

Imgur

다음 명령으로 submodule도 업데이트한다.

git submodule update --init --recursive

Imgur

추적하지 않는 파일이라고 표시된 파일은 IDE(Clion)과 테스트 설정 파일로 무시하거나 .gitignore에 추가해서 버전관리 대상에서 제외하면 된다.

Fork 리포지토리 Sync

원본 리포지토리와 Sync를 완료한 로컬 리포지토리에서 다음 명령으로 Fork 리포지토리로 강제 푸쉬를 날리면 된다.

git push -f origin master

새 버전으로 다시 빌드

빌드 스크립트로 새 버전을 다시 빌드한다.

./eosio_build.sh

boost 등 의존 라이브러리 버전이 변경된 경우 재설치하므로 20분 가량 소요되며, boost 버전 관련 다음과 같은 에러가 발생한다(발생하지 않으면 boost 버전 변경 작업 불필요).

Imgur

~/.bashrc에 지정해둔 boost 관련 버전을 1.67로 변경해준다.

export BOOST_ROOT=~/opt/boost_1_67_0
export BOOST_INCLUDEDIR=~/opt/boost_1_67_0/include

이전 버전의 빌드 캐시가 남아있는 build 디렉터리를 삭제하고 다시 빌드 스크립트를 실행하면 약 15분 후 빌드가 성공적으로 마무리 된다.

rm -rf build/

./eosio_build.sh

Imgur

빌드 후 테스트는 앞에서 서술한 테스트 과정을 그대로 반복하면 된다.

이것으로 로컬 환경에서 EOSIO 소스를 빌드하는 작업을 마쳤다. 다음에는 EOS Single Node Testnet을 실행해보자.