네트워크 시뮬레이션
미리 정의된 계정을 사용하여 권한이 부여된 밸리데이터로 개인 블록체인 네트워크를 시작합니다.
이 튜토리얼은 신뢰 기반의 밸리데이터를 사용하여 개인 블록체인 네트워크를 시작하는 방법에 대한 기본 소개를 제공합니다.
Substrate 노드 템플릿은 Aura를 이용하여 라운드 로빈 방식으로 블록을 생성합니다.
이 튜토리얼에서는 사전 정의된 두 개의 밸리데이터 노드를 가지고 시뮬레이션된 네트워크를 시작하는 방법을 살펴보겠습니다. 이 시뮬레이션된 네트워크에서 두 개의 노드는 서로 다른 계정과 키를 사용하여 시작되지만 하나의 컴퓨터에서 실행됩니다.
시작하기 전에
시작하기 전에 다음을 확인하세요:
Rust와 Rust 툴 체인을 설치하여 Substrate 개발을 위한 환경을 구성했는지 확인하세요.
로컬 블록체인 구축을 완료하고 Substrate 노드 템플릿을 로컬에 설치했는지 확인하세요.
소프트웨어 개발과 명령 줄 인터페이스 사용에 대해 일반적으로 알고 있는지 확인하세요.
블록체인과 스마트 컨트랙트 플랫폼에 대해 일반적으로 알고 있는지 확인하세요.
튜토리얼 목표
이 튜토리얼을 완료함으로써 다음 목표를 달성할 수 있습니다:
사전에 정의된 계정을 사용하여 블록체인 노드를 시작합니다.
노드를 시작하는 데 사용되는 주요 커맨드 라인 옵션을 배웁니다.
노드가 실행 중이며 블록을 생성하는지 확인합니다.
실행 중인 네트워크에 두 번째 노드를 연결합니다.
피어 컴퓨터가 블록을 생성하고 확정하는지 확인합니다.
첫 번째 블록체인 노드 시작하기
자체 Substrate 네트워크를 시작하기 전에 사전에 정의된 네트워크 사양인 local
을 사용하고 미리 정의된 사용자 계정에서 실행하여 기본 원리를 배울 수 있습니다.
이 튜토리얼에서는 alice
와 bob
이라는 이름의 미리 정의된 계정을 사용하여 한 대의 로컬 컴퓨터에서 두 개의 Substrate 노드를 실행하여 개인 네트워크를 시뮬레이션합니다.
블록체인을 시작하려면 다음 단계를 따르세요:
컴퓨터에서 터미널 쉘을 엽니다.
Substrate 노드 템플릿을 컴파일한 루트 디렉토리로 이동합니다.
다음 명령을 실행하여 이전 체인 데이터를 제거합니다:
명령은 작업을 확인하도록 요청합니다:
y
를 입력하여 체인 데이터를 제거하려는 것을 확인합니다.새 네트워크를 시작할 때마다 이전 체인 데이터를 항상 제거해야 합니다.
다음 명령을 실행하여
alice
계정을 사용하여 로컬 블록체인 노드를 시작합니다:
커맨드 라인 옵션 검토
계속하기 전에 다음 옵션을 사용하여 노드를 시작하는 방법을 살펴보세요.
노드 템플릿에 대해 사용 가능한 커맨드 라인 옵션에 대한 자세한 내용은 다음 명령을 실행하여 사용법 도움말을 확인하세요:
./target/release/node-template --help
표시된 노드 메시지 검토
노드가 성공적으로 시작되면 터미널에 네트워크 작업에 대한 메시지가 표시됩니다. 예를 들어, 다음과 유사한 출력을 볼 수 있어야 합니다:
특히, 출력에서 다음 메시지를 주목해야 합니다:
🔨 Initializing Genesis block/state (state: 0xea47…9ba8, header-hash: 0x9d07…7cce)
는 노드가 사용하는 초기 또는 제네시스 블록을 식별합니다. 다음 노드를 시작할 때 이 값이 동일한지 확인하세요.🏷 Local node identity is: 12D3KooWEyoppNCUx8Yx66oV9fJnriXwCcXwDDUA2kj6vnc6iDEp
는 이 노드를 고유하게 식별하는 문자열을 지정합니다. 이 문자열은alice
계정을 사용하여 노드를 시작할 때 사용한--node-key
에 의해 결정됩니다. 이 문자열은 두 번째 노드를 시작할 때 노드에 연결하기 위해 사용합니다.2021-03-10 17:34:37 💤 Idle (0 peers), best: #0 (0x9d07…7cce), finalized #0 (0x9d07…7cce), ⬇ 0 ⬆ 0
는 네트워크에 다른 노드가 없고 블록이 생성되지 않고 있다는 것을 나타냅니다. 블록이 생성되기 위해서는 다른 노드가 네트워크에 참여해야 합니다.
블록체인 네트워크에 두 번째 노드 추가하기
alice
계정 키를 사용하여 시작한 노드가 실행 중인 상태에서 bob
계정을 사용하여 네트워크에 다른 노드를 추가할 수 있습니다. 이미 실행 중인 네트워크에 참여하기 때문에 실행 중인 노드를 사용하여 새 노드가 참여할 네트워크를 식별할 수 있습니다. 명령은 이전에 사용한 것과 유사하지만 몇 가지 중요한 차이점이 있습니다.
실행 중인 블록체인에 노드를 추가하려면 다음 단계를 따르세요:
컴퓨터에서 새로운 터미널 쉘을 엽니다.
Substrate 노드 템플릿을 컴파일한 루트 디렉토리로 이동합니다.
다음 명령을 실행하여 이전 체인 데이터를 제거합니다:
-y
를 명령에 추가하여 확인 없이 체인 데이터를 제거할 수 있습니다.다음 명령을 실행하여
bob
계정을 사용하여 두 번째 로컬 블록체인 노드를 시작합니다:이 명령과 이전 명령 사이에 다음과 같은 차이점을 주목하세요:
두 개의 노드가 동일한 컴퓨터에서 실행되므로
--base-path
,--port
,--rpc-port
옵션에 대해 다른 값을 지정해야 합니다.이 명령에는
--bootnodes
옵션이 포함되어 있으며 시작한alice
노드를 단일 부트 노드로 지정합니다.
--bootnodes
옵션은 다음 정보를 지정합니다:ip4
는 노드의 IP 주소가 IPv4 형식을 사용함을 나타냅니다.127.0.0.1
은 실행 중인 노드의 IP 주소를 지정합니다. 이 경우localhost
의 주소입니다.tcp
는 피어 간 통신에 사용되는 프로토콜로 TCP를 지정합니다.30333
은 피어 간 통신에 사용되는 포트 번호를 지정합니다. 이 경우 TCP 트래픽을 위한 포트 번호입니다.12D3KooWEyoppNCUx8Yx66oV9fJnriXwCcXwDDUA2kj6vnc6iDEp
은 이 네트워크에 대해 통신할 실행 중인 노드를 식별합니다. 이 경우alice
계정을 사용하여 시작한 노드의 식별자입니다.
블록 생성 및 확정 확인하기
두 번째 노드를 시작한 후, 노드는 서로 피어로 연결되어 블록을 생성하기 시작해야 합니다.
블록이 확정되고 있는지 확인하려면 다음 단계를 따르세요:
첫 번째 노드를 시작한 터미널에서 다음과 유사한 줄을 확인하세요:
이러한 줄에서 블록체인에 대한 다음 정보를 확인할 수 있습니다:
두 번째 노드 식별자가 네트워크에서 발견되었습니다 (
12D3KooWBCbmQovz78Hq7MzPxdx9d1gZzXMsn6HtWj29bW51YUKB
).노드에는 하나의 피어가 있습니다 (
1 peers
).노드가 일부 블록을 생성했습니다 (
best: #3 (0x0c55…d51b)
).블록이 확정되고 있습니다 (
finalized #1 (0xf086…9847)
).
두 번째 노드를 시작한 터미널에서도 유사한 출력을 확인하세요.
한 노드를 종료하려면 터미널 쉘에서 Control-c를 누릅니다.
노드를 종료한 후, 남아 있는 노드가 피어가 없고 블록 생성을 중지한 것을 확인할 수 있습니다. 예를 들어:
두 번째 노드를 종료하려면 터미널 쉘에서 Control-c를 누릅니다.
시뮬레이션된 네트워크에서 체인 상태를 제거하려면
purge-chain
하위 명령을/tmp/bob
및/tmp/alice
디렉토리에 대한--base-path
명령 줄 옵션과 함께 사용하세요.
다음 단계로 넘어가기
이 튜토리얼에서는 개인 블록체인 네트워크를 시작하는 첫 번째 기본 단계를 소개했습니다. 이 튜토리얼에서는 두 개의 노드를 한 대의 컴퓨터에서 실행하고 사전에 정의된 계정을 참여자로 사용하여 개인 네트워크를 시뮬레이션했습니다.
다음을 배웠습니다:
노드 템플릿 명령과 명령 줄 옵션을 사용하는 방법.
서로 피어로 통신하는 두 개의 블록체인 노드를 시작하는 방법.
개인 블록체인 노드가 블록을 생성하는지 확인하는 방법.
다음 튜토리얼에서는 이 튜토리얼에서 배운 내용을 기반으로 다른 참여자와 별도의 컴퓨터에서 실행되는 노드를 사용하여 개인 네트워크를 시작하는 방법을 설명합니다.
신뢰할 수 있는 노드 추가에서 다음을 배울 수 있습니다:
자체 비밀 키 쌍을 생성하는 방법.
생성한 키를 사용하는 커스텀 체인 스펙을 생성하는 방법.
커스텀 체인 스펙을 사용하는 개인 네트워크에 밸리데이터를 추가하는 방법.
이 튜토리얼에 문제가 있거나 질문이 있거나 피드백을 제공하려면 다음을 이용하세요.
Last updated