실제로 블록은 어떻게 구성돼 있을까?
블록은 블록의 정체성을 띠는 데이터를 가진 블록헤더, 해당 블록에 거래의 개수를 알려주는 거래 카운터, 그리고 가장 많은 공간을 차지하는 거래목록들이 있다.
또 블록헤더를 3가지 구성으로 나눠보면 이렇게 된다.
현재 블록이 이전(previous) 블록과 연결 되어 있음을 나타내는 이전 블록의 해시값을 포함한다는 부분.
난이도, 타임스탬프, 난스. 이전 포스팅에 설명했듯 채굴 경쟁과 직접적 연관이 되는 부분.
머클루트(Merkle Root)
1번은 블록이 이전블록과 연결되어있다는 것을 나타내는 것이며 해당 블록을 식별하는 것이고, 2번은 채굴자들이 연산을 통해 블록을 채굴하는데 연관된 것들인데 그렇다면 과연 3번. 머클루트란 무엇일까.
머클루트란 머클트리(쉽게 나무라고 생각하자)에서 뿌리 부분에 해당하는 것으로 해당 블록에 있는 모든 거래내역(수백에서 수천개 가량되는 거래량)을 요약하여 작은 사이즈의 용량으로 블록헤더에 존재하는 데이터이다.
그렇다면 블록 하나에서는 모든 거래내역을 가지고 있으면서도 왜 요약본을 더 가지고 있을까? 이것은 머클트리(Merkle Trees)를 알면 왜 머클루트(Merkle Root)가 헤더에 포함되며 왜 그것이 효율적인지 알 수가 있다.
그런데 머클트리(Merkle Trees)에 대해 찾아보면 다들 이진트리(binary trees)라는 표현을 써서 설명을 하고있고 영문으로 찾아봐도 비슷한 내용들 뿐인데 여기서 '이진트리'는 쉽게 말해서 거래를 두개씩 묶는다는 말이다.
이 그림이 머클트리(Merkle Trees)이다. 나무를 뒤집어 놓은 모양이라고 생각하자.
그림은 가장 단순하게 8개의 거래로 묶어 예를 든것인데, 8개 뿐만 아니라 몇 개의 거래 데이터가 있든 하나의 뿌리(루트)로 만들어 준다.
이 과정은 그림처럼 두 개씩 거래를 묶은 다음 SHA256 알고리즘을 통해 해시값으로 나타내고 또 그렇게 묶은 값들을 다시 두 개씩 묶어서 해싱하여 수 백개의 거래 값들을 그림의 가장 꼭대기에 위치한 하나의 데이터로 만들어주는 것이다. (거래가 몇 십개든 몇 백개든 몇 천개든 뭉쳐서 요약된 머클 루트의 용량은 32바이트로 항상 같다.)
이렇게 두개씩 묶어서 올라가면 좋은점이 거래량이 기하급수적으로 늘어나도 특정 거래를 찾는 경로는 단순하다는 것이다. 거래의 건수인 N이 증가할 때마다 특정 거래의 경로를 찾는 경우의 수는 log2(N)으로 늘어나기 때문이다. (여기서 log 스케일이 2인것은 거래를 두 개씩 묶어서 올라가기 때문.)
갑자기 로그가 나온다고 어렵게 생각하지말고 밑의 그림을 보자.
만약 <거래 5>를 찾으려고 할때 위 그림을 보면 해싱이 되는 과정이 세 번이 었으므로 세 번의 경로만 찾아가는 연산을 하면 <거래 5>를 빠르게 찾을 수 있고, 그림처럼 8개의 거래가 아닌 1024개의 거래라고 해도 거래량이 대폭 는 반면 경로는 열 번(log2[1024]=10)으로 찾아가는 연산으로 특정 거래 데이터를 쉽게 찾을 수 있다.
그렇기에 거래 내역을 위조하려는 시도가 있어도 머클트리의 경로를 따라가면 해시값이 다른 것이 나오게 되어 금방 거래의 위변조도 알 수있게 되고 이를 방지할 수 있다.
블록체인의 용량은 시간이 지날수록 지속적으로 늘어가기 때문에 이제는 성능이 좋은 컴퓨터만 모든 블록체인을 다운받는 '풀노드(full node)'가 될 수 있는데 이 머클트리의 이진트리 방식은 우리가 가지고 다니는 모바일로도 블록데이터의 일부만 다운받는 '라이트 노드(light node)'로서 쉽고 빠르게 특정 거래를 찾도록 해준다.
이것이 머클트리가 블록에서 맡은 역할이다.
최대한 쉽게 설명하려고 하지만 모르시는 분들을 위해 언제든지 댓글로 질문을 받습니다.
질문의 내용이 길 경우는 [email protected]으로 보내주시면 감사하겠습니다.
Cheer Up!
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
블록체인에 대해 개념적으로는 이해하고 있지만 프로그램자체나 알고리즘에 대해서는 잘 몰랐는데 조금이나마 이해할 수 있는 내용이네요 ㅎㅎ
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
알고리즘을 공부해 보니 투자하는데 더 큰 도움이 되는것 같습니다. 그 뿐 아니라 머지 않아 블록체인 기술로 모든 것이 이루어질텐데 더 좋은 위치를 선점하기에 정말 더욱 더 큰 공부이지 않을까 싶네요. 알고리즘을 이해하고 코인들의 백서를 보는것 만큼 가치를 이해하고 투자하는 아주 확실한 재테크가 따로 있을까 싶습니다.
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
오래전 들었던 알고리즘 수업이 새록새록 떠오르네요. ㅎㅎ
재밌게 잘 봤습니다~ : )
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
네~ 찾아주셔서 감사합니다^^
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
좋은 설명 감사합니다.
비트코인 백서를 쉽게 설명하는 내용을 연재하고 있습니다. 시간 나실때 들려 주시고 좋은 글 남겨 주시면 감사하겠습니다.
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
네 감사합니다~
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
https://steemit.com/kr/@segyepark/400#@hyokhyok/re-segyepark-400-20170921t064721606z
@hyokhyok 님의 추천으로 찾아왔습니다. 진짜 엄청난 고급정보를 쉽게 정리해 주시고 계시네요. 이건 개발자인 제가 특히 완전 좋아하는 글입니다 ㅜㅜ
팔로우 했습니다. 앞으로도 자주 뵙겠습니다. 감사합니다 :)
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
도움이 되셨다니 다행입니다~ !!
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
제가 이때까지 읽은 머클트리 해설글 중 최고입니다. 팔로우하고 자주 들리겠습니다!
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
안녕하세요 쉽게 설명하는 블록체인 게시자 jsralph입니다.
계정 비밀번호 분실로 인하여 새로 포스팅을 하게 되었습니다ㅜㅜ
http://steemit.com/@easyblockchain 에서 더 많고 다양한 자료 포스팅하고 있으니 많이 찾아주세요~
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
비트코인 논문을 보다가 갑자기 머클트리가 등장해서 뭔가 궁금했는데
알기 쉽게 잘 설명해주셔서 너무 감사합니다^^
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit