Blockchain/Ethereum

Geth 계정 생성과 채굴 (PoW버전의 geth)

Yongari 2023. 2. 4. 17:26

 

 

1. 로컬 테스트넷에서 Geth 실행하기

 

로컬 테스트넷에서 Geth를 실행하기 위해서 데이터 디렉토리와 genesis.json파일이 필요합니다.

 

데이터 디렉토리 : 송수신한 블록 데이터와 계정 정보를 저장함
genesis.json : 블록체인의 Genesis 블록(블록체인의 첫번째 블록)의  정보가 담긴 json 형태의 파일

 

 

1-1 먼저 docker에 다시 접속하겠습니다.

#docker가 다운되어 있을 경우

docker ps -a #docker 컨테이너 실행여부 확인


docker start con_ubnutu #도커 con_ubuntu를 실행하기


docker exec -it conubunt bash #도커 con_ubuntu로 접속하기

 

 

1-2 test_data와 genesis.json 만들기

mkdir -p /go-ethereum/test_data #test_data 만들기

touch /go-ethereum/test_data/genesis.json #genesis.json 만들기

 

 

1-3 geth를 실행하면 다음과 같은 로그가 출력됩니다. 

geth
INFO [02-04|10:49:44.058] Starting Geth on Ethereum mainnet... 
INFO [02-04|10:49:44.099] Bumping default cache on mainnet         provided=1024 updated=4096
INFO [02-04|10:49:44.102] Maximum peer count                       ETH=50 LES=0 total=50
INFO [02-04|10:49:44.104] Smartcard socket not found, disabling    err="stat /run/pcscd/pcscd.comm: no such file or directory"
INFO [02-04|10:49:44.163] Set global gas cap                       cap=50,000,000
INFO [02-04|10:49:44.166] Allocated trie memory caches             clean=614.00MiB dirty=1024.00MiB
INFO [02-04|10:49:44.166] Allocated cache and file handles         database=/root/.ethereum/geth/chaindata cache=2.00GiB handles=524,288
INFO [02-04|10:49:44.735] Opened ancient database                  database=/root/.ethereum/geth/chaindata/ancient/chain readonly=false
INFO [02-04|10:49:44.749]  
INFO [02-04|10:49:44.749] --------------------------------------------------------------------------------------------------------------------------------------------------------- 
INFO [02-04|10:49:44.749] Chain ID:  1 (mainnet) 
INFO [02-04|10:49:44.749] Consensus: Beacon (proof-of-stake), merged from Ethash (proof-of-work) 
INFO [02-04|10:49:44.749]  
INFO [02-04|10:49:44.749] Pre-Merge hard forks: 
INFO [02-04|10:49:44.750]  - Homestead:                   1150000  (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/homestead.md) 
INFO [02-04|10:49:44.750]  - DAO Fork:                    1920000  (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/dao-fork.md) 
INFO [02-04|10:49:44.750]  - Tangerine Whistle (EIP 150): 2463000  (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/tangerine-whistle.md) 
INFO [02-04|10:49:44.750]  - Spurious Dragon/1 (EIP 155): 2675000  (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/spurious-dragon.md) 
INFO [02-04|10:49:44.750]  - Spurious Dragon/2 (EIP 158): 2675000  (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/spurious-dragon.md) 
INFO [02-04|10:49:44.750]  - Byzantium:                   4370000  (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/byzantium.md) 
INFO [02-04|10:49:44.750]  - Constantinople:              7280000  (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/constantinople.md) 
INFO [02-04|10:49:44.750]  - Petersburg:                  7280000  (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/petersburg.md) 
INFO [02-04|10:49:44.750]  - Istanbul:                    9069000  (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/istanbul.md) 
INFO [02-04|10:49:44.750]  - Muir Glacier:                9200000  (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/muir-glacier.md) 
INFO [02-04|10:49:44.750]  - Berlin:                      12244000 (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/berlin.md) 
INFO [02-04|10:49:44.750]  - London:                      12965000 (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/london.md) 
INFO [02-04|10:49:44.750]  - Arrow Glacier:               13773000 (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/arrow-glacier.md) 
INFO [02-04|10:49:44.750]  - Gray Glacier:                15050000 (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/gray-glacier.md) 
INFO [02-04|10:49:44.750]  
INFO [02-04|10:49:44.750] Merge configured: 
INFO [02-04|10:49:44.750]  - Hard-fork specification:    https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/paris.md 
INFO [02-04|10:49:44.750]  - Network known to be merged: true 
INFO [02-04|10:49:44.750]  - Total terminal difficulty:  58750000000000000000000 
INFO [02-04|10:49:44.750]  - Merge netsplit block:       <nil> 
INFO [02-04|10:49:44.750] --------------------------------------------------------------------------------------------------------------------------------------------------------- 
INFO [02-04|10:49:44.750]  
INFO [02-04|10:49:44.751] Disk storage enabled for ethash caches   dir=/root/.ethereum/geth/ethash count=3
INFO [02-04|10:49:44.751] Disk storage enabled for ethash DAGs     dir=/root/.ethash               count=2
INFO [02-04|10:49:44.758] Initialising Ethereum protocol           network=1 dbversion=8
INFO [02-04|10:49:45.010] Loaded most recent local header          number=0 hash=d4e567..cb8fa3 td=17,179,869,184 age=53y10mo1w
INFO [02-04|10:49:45.028] Loaded most recent local full block      number=0 hash=d4e567..cb8fa3 td=17,179,869,184 age=53y10mo1w
INFO [02-04|10:49:45.028] Loaded most recent local fast block      number=0 hash=d4e567..cb8fa3 td=17,179,869,184 age=53y10mo1w
INFO [02-04|10:49:45.033] Loaded local transaction journal         transactions=0 dropped=0
INFO [02-04|10:49:45.033] Regenerated local transaction journal    transactions=0 accounts=0
INFO [02-04|10:49:45.046] Chain post-merge, sync via beacon client 
INFO [02-04|10:49:45.047] Gasprice oracle is ignoring threshold set threshold=2
WARN [02-04|10:49:45.047] Engine API enabled                       protocol=eth
INFO [02-04|10:49:45.055] Starting peer-to-peer node               instance=Geth/v1.10.26-stable-e5eb32ac/linux-amd64/go1.18.5
INFO [02-04|10:49:45.645] New local node record                    seq=1,674,811,378,579 id=293d0a3572605a69 ip=127.0.0.1 udp=30303 tcp=30303
INFO [02-04|10:49:45.647] IPC endpoint opened                      url=/root/.ethereum/geth.ipc
INFO [02-04|10:49:45.655] Started P2P networking                   self=enode://e120c0d6ac8996a085a2f1888923dee3ed5a4a5bca9394ce8e8de11633d1a8ba3aac831ba0b039be61a13944a896521e82eef6c9404ab73b168c3e23f81d2118@127.0.0.1:30303
INFO [02-04|10:49:45.647] Loaded JWT secret file                   path=/root/.ethereum/geth/jwtsecret crc32=0x9daa6731
INFO [02-04|10:49:45.687] WebSocket enabled                        url=ws://127.0.0.1:8551
INFO [02-04|10:49:45.687] HTTP server started                      endpoint=127.0.0.1:8551 auth=true prefix= cors=localhost vhosts=localhost
INFO [02-04|10:49:48.697] New local node record                    seq=1,674,811,378,580 id=293d0a3572605a69 ip=49.165.9.63 udp=30303 tcp=30303

 

 

2. Geth 콘솔을 사용하여 계정 생성



2-1 다음 명령어를 입력해서 계정을 생성합니다.

cd /go-ethereum
geth --datadir test_data account new

 

2-2 비밀번호는 편한걸로 입력해주시고 그러면 다음과 같은 로그가 출력됩니다.

여기서 "0xD7970Ee529e0780e79BB4a5f4EdfEfE621c4EF6c"은 genesis.json파일에서 사용하기 때문에 꼭 기억해야합니다. 

/go-ethereum# geth --datadir test_data account new
INFO [02-04|10:50:52.419] Maximum peer count                       ETH=50 LES=0 total=50
INFO [02-04|10:50:52.419] Smartcard socket not found, disabling    err="stat /run/pcscd/pcscd.comm: no such file or directory"
Your new account is locked with a password. Please give a password. Do not forget this password.
Password: 
Repeat password: 

Your new key was generated

Public address of the key:   0xD7970Ee529e0780e79BB4a5f4EdfEfE621c4EF6c
Path of the secret key file: test_data/keystore/UTC--2023-02-04T01-50-54.223602729Z--d7970ee529e0780e79bb4a5f4edfefe621c4ef6c

- You can share your public address with anyone. Others need it to interact with you.
- You must NEVER share the secret key with anyone! The key controls access to your funds!
- You must BACKUP your key file! Without the key, it's impossible to access account funds!
- You must REMEMBER your password! Without the password, it's impossible to decrypt the key!

 

2-3 계정이 잘 생성되었는지 확인합니다.

geth -datadir test_data account list
INFO [02-04|10:53:28.680] Maximum peer count                       ETH=50 LES=0 total=50
INFO [02-04|10:53:28.680] Smartcard socket not found, disabling    err="stat /run/pcscd/pcscd.comm: no such file or directory"
INFO [02-04|10:53:28.681] Set global gas cap                       cap=50,000,000
Account #0: {d7970ee529e0780e79bb4a5f4edfefe621c4ef6c} keystore:///go-ethereum/test_data/keystore/UTC--2023-02-04T01-50-54.223602729Z--d7970ee529e0780e79bb4a5f4edfefe621c4ef6c

 

 

 

3. GenesisBlock 만들기

 

3-1. genesis.json 파일을 편집하기 

vim /go-ethereum/test_data/genesis.json

 

3-2. 파일에 다음 내용을 붙여넣기 

{
 "config" : {
     "chainId" : 8484,
     "homesteadBlock": 0,
     "eip150Block":0,
     "eip155Block":0,
     "eip158Block":0
 },
 "difficulty":"20",
 "gasLimit":"2100000",
 "alloc":{
 "0x99e75dEf2b565D7f462cd92B4718516C68939F4A" : {"balance":"300000"}
 }
}

 

3-3 genesis.json 속성값

 

config : 이더리움 관련 설정

config.chainId : chainid는 현재 chain을 구별하는 값이고 replay  attack로부터 보호해주는 역할
(replay attack은 유효한 데이터 전송을 악의적으로 반복시키거나 지연시키는 공격의 일종)

config.homesteadBlock : 이더리움의 4단계 로드맵 중 두 번째 메이저 단계 속성이 0이면 true

config.eip155Block: EIP는 Ethereum Improvement Proposal의  약자로 개발자들이 이더리움을 업그레이드하기 위해 제안된 아이디어 이것도 chainId와 마찬가지로 replay attack을 막기위한 설정

config.eip150Block: IO가 많은 작업에 대한 가스 변경비용을 위한 설정

config.eip158Block: EIP158은 계정의 상태가 변경되고 변경된 결과값으로 인해 계정의 nonce와 balance 값이 0이 되고 code와 storage가 빈 값이 되는 경우 해당 계정을 삭제함

 

4가지 설정 ( config.homesteadBlock, config.eip155Block, config.eip150Block, config.eip158Block)은 사설 블록체인을 만들 때 기본적으로 동일한 설정

 

difficulty : 채굴 난이도

gasLimit : 블록당 담을 수 있는 가스(수수료)의 한도를 설정함 하나의 블록 안에 담을 트랜잭션 개수를 결정하는 데 사용하는 옵션
alloc : 제네시스 블록이 생성됨과 동시에 alloc에 등록된 주소로 이더를 전송합니다. (alloc에 있는 금액의 단위는 wei입니다.)

parentHash : 부모 블록의 해시값을 넣는다. 제네시스는 부모블록이 없어서 사용안함

coinbase: 제네시스 블록 채굴시 주어지는 보상

nonce, mixhash : nonce와 mixhash는 블록이 올바르게 채굴되었는지 증명함 블록체인 작업증명을 위해서 가장 최근에 추가된 블록의 해시값과 블록 헤더의 다양한 값, 임의의 값 nonce의 조합으로 특정범위에 있는 수를 찾습니다. 
mixhash는 nonce를 찾기위한 중간 값입니다. nonce와 mixhash는 "블록을 제대로 만들었는지 증명하는 용도"입니다.
timestamp : 해당블록이 취득된 시점을 의미하는 값으로 유닉스 타임스탬프가 들어감

 

 

Fatal : Failed to write genesis block 에러가 발생할 경우 geth 서버 데이터가 이미 존재해서 발생하는 에러로 geth 서버 데이터를 전부 삭제하고 새로 생성하면 에러를 해결할 수 있음

 

 

4. Genesis Block을 생성 및 초기화 

4-1 제네시스 블록을 생성 및 초기화

geth --datadir test_data init test_data/genesis.json

출력값에 "Successfully wrote genesis state"문구가 보이면 성공

 

 

5. Geth 실행

1. 다음 명령어로 geth를 실행합니다.

geth --networkid 8484 --nodiscover --datadir test_data -allow-insecure-unlock --http --http.port 8545 --http.corsdomain "*" --http.api="db,eth,net,web3,personal,web3,miner,admin" --miner.threads 1 console 2>> test_data/geth.log

 

다음과 같이 커맨드에 ">" 표시가 보이면 성공적으로 geth 콘솔이 실행된 것입니다. 

 

 

 

geth 커맨드에서 각 옵션은 다음을 의미합니다.

 

-datadir test_data 데이터 디렉토리로 "test_data"를 지정합니다.

networkid 8484 : 네트워크 식별자

http : 이전에는 rpc였으나 지금은 http

http.addr "ip" : 현재 사용중인 ip 입력

http.port : "port" 원하는 포트 입력

http.corsdomain "*" : 접속할 수 있는 rpc 클라이언트 url을 지정하는 것인데 "*" 별표는 전체 허용이라는 뜻입니다.

-nodiscover : 생성자 노드를 다른 노드에서 검색할 수 없게 하는 옵션, 같은 제네시스 블록과 네트워크 ID에 있는 블록들이 연결되는 것을 방지함

http.api "db,eth,net,web3,personal" : rpc에 의해 접근할 수 있는 api 

-maxpeers 0 : 생성자의 노드에 연결할 수 있는 노드의 수를 지정 0을 지정하면 다른 노드와 연결하지 않음

console : 대화형 자바스크립트 콘솔을 기동함

2>>test_data/geth.log : 파일의 출력을 test_data/geth.log 경로의 파일로 쌓으라는 뜻입니다. 
">" 이것은 단발성 출력이고 ">>"이 것은 계속해서 파일의 출력을 기록하는 커맨드입니다.
(리눅스 표준출력을 참고하시면 됩니다. / https://webdir.tistory.com/256 )

6. Etherbase 설정하기 

 

이더리움에는 두 가지 종료의 계정이 있음

1. EOA(Externally Owned Account) : 일반 사용자가 사용하는 계정으로 비밀키로 관리됨, Ether를 송금하거나 계약을 실행할 수 있음 

2. CA(Contract Account) : Contract 계정은 컨트랙트를 블록체인에 배포할 때 만들어지는 계정으로 블록체인에 존재함

 

 

1. 처음에 만든 계정이 잘 있는지 확인

 

2. 새로운 계정을 추가함 

 

 

2-1 "eth.accounts"로 새 계정이 잘 생성됐는지 확인해보기

 

 

 

3. 채굴시 보상받을 계정을 생성하기

 

이더리움을 채굴하고 보상받는 계정을 Etherbase라고 함 Etherbase는 eth.coinbase 변수에 저장되지만 기본적으로 eth.accounts[0]이 설정됨

 

새로 만든 계정을 다음과 같은 커맨드로 Etherbase로 설정해보겠습니다.

 

 

 

 

"eth.coinbase" 커맨드를 이용해 새 계정 주소로 Etherbase가 변경된 것을 확인할 수 있음 

 

 

 

 

 

 

 

4. 각 계정의 Lock을 풀고 Mining을 한 뒤 잔고를 확인합니다.

 

4-1 먼저 블록체인의 블록 수와 블록 정보를 다음 커맨드로 확인합니다.

 

eth.blockNumber //생성된 블록 수 조회

eth.getBlock(0) //0번째 블록의 정보 출력

 

 

 

 

4-2 계정의 상태를 확인하고 Lock 상태를 풉니다.

 

 

 

4-3 계정의 상태를 unlock하는 커맨드는 다음과 같습니다.

personal.unlockAccount("eth.accounts의 주소", "비밀번호", 유효기간)

 

 

 

 

1. miner.start(n) n은 스레드의 개수로 채굴을 시작하는 커맨드입니다.

 

2. eth.mining을 통해 현재 마이닝이 진행중인지 알 수 있습니다. 진행중이면 true / 진행중이지 않으면 false입니다.

 

 

3. "eth.blockNumber" 명령어를 통해 최근 추가된 블록의 숫자를 확인할 수 있습니다.

 

 

4. miner.stop()으로 채굴을 종료합니다.
왜 결과값이 null로 나올까요? 잘 돌아가서 저는 그냥 넘어갔습니다.

5. 다음과 같이 커맨드를 이용해서 잔액의 잔고를 확인할 수 있습니다.

 

web.fromWei 커맨드는 wei 단위를 ether 단위로 변환해서 표시해줍니다.