[연재글] BlockChain - 05. Block, Chain
1편 : https://orbi.kr/00012313138
2편 : https://orbi.kr/00012318427
3편 : https://orbi.kr/00012334500
4편 : https://orbi.kr/00012341994
이 글은 암호화폐와 그 근간을 이루고 있는 블록체인에 대해 살펴보는 글이지 비트코인과 이더리움 시장을 예측해 투자 타이밍을 조언하는 글이 아님을 알려드립니다. 이걸 본다고 투자하는데 도움이 되지 않습니다. 기술은 개발자에게 투자는 주갤러에게.
안녕하세요 벌써 다섯번째 글이네요. 처음 시작할때는 글 다섯개정도면 끝날 줄 알았는데 아직도 못 쓴 내용이 너무 많네요. 10편까지는 써야 할 것 같기도 하고... 여튼 완결까지 열심히 달려보도록 하겠습니다. 이번 글은 쓰다보니 내용이 자꾸 깊어지는 것 같아서 어떻게 조절해야하나 고민하다 보니 텀이 길어졌습니다. 앞으로 계속 어려워질 것 같은게 함정...
저번 글에서는 블록체인을 만들어내는 노드에 대해 설명을 드렸는데, 이번 글에서는 그렇게 노드에서 만들어내는 블록이 어떻게 해서 체인을 이루고 있는지, 그렇게 체인을 이루고 있음으로 해서 어떤 특징들이 또 있는지 알아보도록 하겠습니다.
1. Block
일단 블록이 어떻게 생겼는지 그 구조를 알아보도록 하겠습니다. 이전 글에서 봤던 그림에 보면 블록이 가진 정보는 다음과 같습니다.
Prev. Hash / Nonce / Timestamp / Difficulty / Merkle Root // Tx. Infos
// 를 기준으로 앞에 있는 녀석들을 묶어서 Block Header 라고 하고 뒤에 있는 것을 Block Body 라고 합니다. 간단하니 Body를 먼저 설명 드릴게요. 여기에는 지난 글에서도 설명드렸듯 Tx. Pool에서 고른 거래들이 들어갑니다. 거래를 고르는 기준은 각 노드가 자기 맘대로 설정할 수 있는데, 보통은 풀에 들어와 머무른 시간과 거래에 딸린 수수료 등을 기준으로 합니다. 1편인가 2편에서 어떤 거래는 검증되기까지 한시간씩 걸리기도 한다는 말씀을 드렸었는데요, 이게 바로 그 이유에요. 수수료를 낮게 책정하면 새 블록 안에 포함될 확률이 낮아지기 때문에 오랜 시간 블록에 들어가지 못하고 계속 풀에서 기다려야 하죠. 그러다보면 검증을 받을 때까지 오래걸리는거에요. 뭐 이 안에 거래정보만 들어가는게 아니라 그걸로 만든 거래 해시값이라거나 하는 것들도 들어가기는 하는데, 그건 나중에 머클트리에 대해 설명할 때가 되면 다시 짚도록 하고, 블록 헤더가 중요하니 그걸 쭉 훑어보겠습니다.
2. Block Header
블록 헤더에 든 것들을 한개씩 살펴보죠.
1. Prev Hash : 이건 이전 블록의 해시값을 말하는거에요. 이전 블록의 해시가 다음 블록에 포함되기 때문에 블록이 체인을 이룬다고 하는거에요. 이전블록의 해시를 가지고 있기 때문에 어떤 블록 하나를 알면 그것보다 과거의 블록은 전부(그러니까 0번 블록까지) 거슬러 올라갈 수 있어요.
2. Timestamp : 이 블록이 언제 생성됐는지를 알려주는 타임스탬프입니다. 보통 시차랑 블록이 전파되는데 걸리는 시간을 고려해 두시간정도까지 오차를 허용하고 있다고 해요. 이 이상 타임스탬프가 멀리 차이나면 다른 노드에서 이 블록을 검증할 때 유효하지 않다고 판단하고 거절해버립니다.
3. Nonce : 한번 쓰인 숫자(Number + Once) 의 줄임말이라고 합니다. 블록 해시를 찾는데 쓰이는 부분이에요. 정확히 어떻게 쓰는지는 밑에서 설명드릴게요.
4. Difficulty : 문제의 난이도를 뜻합니다. 비트코인은 평균 10분에 한번씩 새 블록이 채굴되는 것을 목표로 하고 있어요. 그래서 대략 4년(21만블록정도)에 한번씩 그간 생성된 블록들의 생성시간을 살펴보고 난이도를 조절합니다. 이 난이도 조절은 모든 Full Node에서 같은 수식에 따라 독립적으로 적용돼요. 요것도 아래에서 블록을 생성하는 과정을 설명드리면서 한번 더 등장할겁니다.
5. Merkle Root : 되게 처음보는 이름이죠? 머클 루트라고 읽는데, 이건 Lightweight Node에서 거래 검증을 하는데 쓰기 위해 있는 녀석이에요. Block Body 안에 있는 Tx. 정보를 압축한 해시값이라고 보시면 됩니다.
3. Hash? HASH?
자꾸 1편부터? 여튼 해시라는 말이 자꾸 나오는데 이게 글을 쓰다 보니 당연히 알 거라고 생각하고 자연스레 넘어갔던 것 같네요. HASH 라는건 쉽게 설명하면 어떤 입력값이든 고정 길이의 결과값으로 바꿔주는 함수에요. 보통 비트코인에서는 SHA256이라는 해시함수를 쓰는데, 뭐든지 여기에 통과시키면 길이가 256인 결과값이 나옵니다. 같은 입력값을 넣으면 항상 같은 출력값이 나와요. 그런데 해시값을 안다고 원래 입력값을 알아낼 수는 없어요. 왜냐하면 가능한 입력값의 갯수보다 출력값의 갯수가 적기 때문이죠. 뭐 이런걸 두고 전문용어(?)로는 단사함수가 아니라고 한다네요. 어쩔 수 없이 같은 해시값을 가지는 둘 이상의 입력값이 존재할 수밖에 없어요. 하지만 그건 매우매우매우매우 드물게 일어나는 일이기 때문에 보통은 입력값이 다르면 출력값도 다르다고 할 수 있죠. 해시암호의 큰 이슈중 하나가 Collision인데, 아직까지 그런 면에서 SHA256은 안전하다고 평가받고 있어요. 그리고 복잡한 함수를 통과하기 때문에 입력값이 약간만 변해도 결과 해시는 크게 변해요. 그래서 해시값은 예측이 불가능하다고도 합니다. 간단하게 정리하자면 해시는 입력값에 1:1로 대응되는 함수 결과값이고, 예측가능성이나 규칙이 존재하지 않는다고 할 수 있겠네요.
4. Find Block Hash
블록을 만드는 과정은 블록 해시를 찾는 과정이라고 저번에 말씀드린 적이 있을 거에요. 위에서 말씀드렸던 해시함수를 이용해 특정 조건을 만족하는 해시값을 찾는 작업이 바로 블록 해시를 찾는 과정입니다. 그 조건이 바로 Difficulty인데, 이것보다 작은 해시값을 찾으면 블록 생성에 성공하는거에요. 물론 답은 하나가 아니겠죠? Difficulty보다 작은 해시는 많이 있을테니까요. 앞에서 말씀드렸듯 해시값은 규칙이나 예측가능성이 없기 때문에 일일이 대입해보면서 확인하는 것밖에 방법이 없어요. 그런데 이전 헤더, 타임스탬프, 머클트리같은 것들은 값을 변경할 수가 없거나 한계가 있죠? 그래서 있는게 Nonce 라는 값이에요. 이걸 바꿔가면서 조건에 맞는 해시값을 찾아가는거죠. 난이도 조절은 Difficulty 값을 변경하는 것으로 이루어지는데, 난이도를 올리려면 Difficulty 안에 담긴 값을 작게 만들고(이것보다 작은 해시를 찾아야 하니까요) 내리려면 숫자를 크게 만듭니다. 보통 어려운 수학문제를 푸는 과정이라고 블록을 만드는 과정을 설명하는데, 사실 그게 아니라 그냥 열심히 대입해가면서 무작위로 찾아보는거... Brute Force 라고 합니다 저런걸........... 뭐 되게 별거 아닙니다. 그냥 대입해봐야 될 경우의 수가 너무 많을 뿐...
그렇게 Nonce를 막 바꿔가면서 해시값을 뒤적여봅니다. 전 세계의 Full Node 또는 Miner가 이런 걸 열심히 찾겠죠? 그러다가 누군가가 조건에 맞는 해시를 찾아내면 Nonce 자리에 자신이 답을 찾는데 사용한 Nonce를 박아서 블록을 완성하고 이 블록+찾아낸 해시 정보를 주변 노드에 전파합니다. 그리고 블록을 만들어낸 보상으로 일정량의 비트코인을 받게 되구요(보상은 초기에는 블록당 50BTC에서 시작해서 2016년에는 12.5BTC가 되었습니다. 일정 주기로 절반씩 줄어들어 2140년경에 2100만BTC가 모두 채굴된다고 하네요). 주변 노드에서는 새 블록이 생겼다는 정보를 받으면 그 블록 헤더와 전달받은 해시를 가지고 답이 맞는지 검증합니다. 이 과정은 답을 찾아내는게 아니라 이미 찾은 답을 확인하는 것이기 때문에 HASH 연산을 한번만 해보면 돼요. 그렇게 검증을 통과한 블록은 블록체인에 연결되게 되고, 노드들은 다시 이 블록 해시와 Tx. Pool에서 건진 거래를 가지고 다음 블록을 생성합니다. 이렇게 블록이 영원히 체인이 되어 이어집니다.
이번 글에서는 블록의 구성과 그 블록을 어떻게 생성하고, 어떻게 체인에 연결되는지를 살펴보았습니다. 사실 이게 블록체인의 핵심이에요. 거래를 담은 블록을 만들어내서 체이닝한다. 이 글까지 읽으신 분들께서는 이 그림을 다시 보시면 한눈에 어떻게 돌아가는지 이해가 가실거라 생각합니다.
아직 이해가 잘 가지 않는 부분이 있으신가요? 그렇다면 이전 글을 다시 한번 읽어보시고, 그래도 이해가 잘 안가신다면 글을 쉽게 못쓴 제 탓을 하시며 댓글/쪽지로 질문을 주심 성심성의껏 설명해드리도록 하겠습니다.
다음 글부터는 이 기본 구조에 살을 붙여보도록 하겠습니다. 동시에 여러 곳에서 블록을 만들어내면 어떻게 되는지, 블록체인이 뭐때문에 안전하다고 하는건지, 저걸 깰 방법은 없는지, 마이닝풀이라는게 있다는데 그건 어떻게 작동하는건지 등등에 대한 것들이 되겠네요. 그럼 다음 글에서 뵙겠습니다.
작성자 아들딸 까까사주기:
BTC 14eM4cd28q77Q4AujrV6jGBDH9unX3zD3f
ETH 0xf05C7196CF4e3494023aeABB6053d053ecB3937A
0 XDK (+0)
유익한 글을 읽었다면 작성자에게 XDK를 선물하세요.
-
안녕하세요. CIFA입니다. 10월 14일 진행했던 오프라인 멘토링과, 메일로 주신...
-
혹시 덕코인은 어떻게 얻을수 있는건가요?ㅠㅠㅠㅠ 사야하나요?..
-
메르스 사태 때문에 관심 있게 봤던 메르스 증상들.. 0
메르스 때문에 전국이 시끄럽습니다. 그래서 메르스 증상 관련해서 사람들에게 쉽게...
-
안녕하세요 저희는 이번에 사회문화 현상 관련 설문조사를 실시하고자 합니다. 한번씩...
-
아침에 날씨 보셨어요? 뿌연 안개때문에 진짜 당황함.. ㅋㅋ 몇 미터 앞도 잘...
-
학생부 날조 관련 16
저는 1년동안 학교생활도 열심히하고 담임이 원하는대로 야자도 하고 공부도 꾸준히...
-
여러분들께서 동아리와 더불어 많이 질문을 하신 부분이 밥약이더라구요. 그래서...
-
내 말이 힘을 가질 수 있게 하려고,, 일류 학벌까진 아닐지 몰라도 단국대생으로서의...
-
DDoS 에 대해 28
안녕하세요 옛날에 블록체인 어쩌고 하는 글을 썼던 개발자입니다. 오늘 보니 오르비에...
-
[연재글] BlockChain - 08. Mining Pool, Summary - (完) 4
1편 : https://orbi.kr/00012313138 2편 :...
-
[연재글] BlockChain - 07. UTXO와 거래 검증 4
1편 : https://orbi.kr/00012313138 2편 :...
-
[연재글] BlockChain - 06. Security 13
1편 : https://orbi.kr/00012313138 2편 :...
-
[연재글] BlockChain - 05. Block, Chain 13
1편 : https://orbi.kr/00012313138 2편 :...
-
1편 : https://orbi.kr/00012313138 2편 :...
-
[연재글] BlockChain - 01. 이게 뭔가여 14
안녕하세요 예에에엣날에 컴퓨터 관련 글을 좀 끼적였던 개발자입니다. 이거저거...
-
안녕하세요. Snu Roman.입니다. 머리 식히러 인터넷에 들어왔는데 또 머리...
-
[Snu Roman.] 진보언론에 대하여 알아보자. Araboja. 3
[Snu Roman.] 진보언론에 대하여 알아보자. Araboja 시리즈 2편...
-
입시로 입씨름 할 분! 26
안녕하세요. 오르비학원의 King이사입니다. 오늘은 오르비에서 많은 활동을 하고...
-
제목 : 외교통상부 순혈주의, 외무고시의 문제인가 외무고시를 대체할 외교 아카데미의...
-
일단 저는 학교장 추천을 받고 시험을 봤지만 수시전형은 광탈하고 정시전형으로...
-
최보식 기자와 김도연 총장 특징.fact(반박불가) 0
국어789등급 쩌리들임 ㅋ
-
전 강대를 무려 2년씩이나 다녔던 사람이기도 하고 이번에 다행히도 원하던 학과에...
-
[에라둔] 물리1 역학을 위한 해법 - 3편 (일과 에너지 기본) 5
물리1 돌림힘 정말로 어렵고 힘든 유형일까?? (1~4편 통합)...
-
꽤 자주 술자리에서 과외로 먹고 살아가는 삶은 어떠냐고 자주 묻곤 하십니다....
-
현역인데 아랍어는 언제부터 시작하는게 좋을까요?? 지금부터 조금씩 조금씩 하는게...
-
!!!!![알바]하시는 분들 진짜 꼭 이 글 보고 가시기 바랍니다!!!! 8
요즘에 수능 끝나고 알바 많이들 하시죠? 저도 알바를 하고 있는데 임금을 받는...
-
http://orbi.kr/00010060632 준비편1...
-
http://orbi.kr/bbs/board.php?bo_table=united&wr...
-
0. 들어가기에 앞서 글의 특성상 객관성을 띄기 위해 딱딱한 분위기로 글이...
-
물수능에는 여자가 유리하고, 불수능에는 남자가 유리하다? (남녀 상위권 성적비교) 52
우선, 남녀갈등을 조장하는 글이 아니라는 것을 알아주셨으면 합니다. 통계자료 위주의...
-
안녕하세요! 올해 수능 역시 화학1에서의 기출 분석의 중요성을 깨닫게 해주네요....
-
[퓨에르] 수학 4~5등급대를 위한 간단한 이야기 12
안녕하세요. 퓨에르 (박성현) 입니다. 저번에 말씀드렸던 것처럼, 수학 공부법에...
-
피델 카스트로(1926~2016) 갔습니다...... 향년 91세 올해는 세계사의...
-
그냥 밤에 할 짓 없어서 쓰는 반수생 반수 후기(긴글주의) 12
수능 끝나고 이런 글 꼭 오르비에 올려보고 싶었어요! 오르비에 계신 에피,센추님들에...
-
실증에 얽매여 여러분의 실존을 잃지는 마세요.여러분은 당신들의 실존에 부끄럽지 않을...
-
제목이도 나와있지만 메가에서 법정가르치는 이용재쌤이 강의듣다가 썰 몇개만...
-
안녕하세요!!이제 진짜 수능이 얼마 남지 않았네요 ㅋㅋㅋ..4월에 반수 시작했을때가...
-
※지극히 당연하고 뻔한 이야기입니다※ 1. 식사 -아침 : 수능날이라고 특별하게...
-
허읍!
-
이번에 저희학교에서 저와 친구들이 이대회에 참가하게 되었는데요 ㅎㅎ...
-
돌마바흐체 궁전(이스탄불, 오스만 제국의 정궁) *터키어 각 단어에 대한 번역은...
-
교재 불법 복제애 대한 이야기나 나와서 한마디... 39
저는 만화책을 좋아합니다. 어려서부터 만화책을 많이 읽었죠. 부모님께 용돈을 받으면...
-
어제 아프리카 방송했습니다..ㅋㅋ그 느낌을 적어보면..모든 사람이 행복해지려면그...
-
사랑을 망설이는 이유ver.1 모르겠어요. 침대 밖을 벗어날 이유를 찾지 못해...
-
오랜만입니다. 퓨에르입니다. 요즘은 수학 질의응답을 받는 옐로아이디 친구분이...
-
1. 분석자 기본 정보 - 해당 학년 : 고3 - 희망 대학 계열(자연계, 인문계)...
-
[현대사] 삼성과 현대를 접수한 두 여자의 인연... 14
조선 말 전남 영암에 현기봉이라는 거부가 있었다. 그는 만석꾼 집안에서 자라...
-
8번 문제의 기막힌 우연 2008년~2012년 무려 5년 동안 수능 국어 8번의...
-
6평 41313, 수능 11112 연세대 경제학부 합격 수기 33
오르비 회원 여러분, 안녕하세요! 작년 한 해 동안 강남대성에서 공부했고, 올해...
모아놓고나중에봐야지
꼭 봐주세요 ㅋㅋ 보통 모아놓고 나중에 봐야지 한건 안보던데 ㅋㅋㅋ
오.. 이 글로 전 글들에서 이해가 되지 않은 부분들이 하나로 이어지는 듯한 느낌이네요..
그런데 2140년이 되면 진짜로 비트코인은 채굴이 불가능하게 되는 건가요?
채굴 보상으로는 얻는 것이 없고, 거기 담긴 거래들의 수수료를 보상으로 가져가게 됩니다. 지금도 기본보상 + 수수료를 받아가고 있는 거구요. 수수료 수준도 적정 수준을 Node가 계산하게 됩니다. 아마 기본 보상이 줄어들면 수수료가 조금씩 상승하겠죠?
비트코인의 총량이 정해져 있는 이유는 무엇인가요? 결국 무한정 채굴이 가능한 구조라면 애초부터 총량이 정해지지 않아도 무방한 것 아닌가요?
화폐의 총량이 정해져있지 않다는 말은 시장에 화폐가 지속적으로 공급되면서 인플레이션을 유발할 수 있다는 말이 됩니다. 그리고 총량이 정해져있음으로서 스스로의 가치를 올릴 수도 있죠. 금처럼요.
페페캐시라는 종류의 알트코인이 있는데, 얘들은 일정 주기마다 시총의 일정량을 태워서(영구적으로 없애서) 인플레이션을 막는 방법을 씁니다.
결국 화폐의 가치를 유지하기 위해 총량이 정해져 있는거네요..
나중엔 진짜 금처럼 취급할수도 있을듯
요새 근데 비트코인이 뭐 하드포크를 하네 뭐가 어쩌네 하는 말이 많아서.. 뭔가 암호화폐 Gen.2 같은게 나와서 자리를 잡기 전까지의 암호화폐는 수많은 공격과 시험의 대상일거라... 이더리움도 한때 해킹 이슈로 갈라졌고 뭐 그렇습니다.
아 역시 건드리면 안될듯합니다 ㅎㅎ
국어기출에 해시함수 논스~~등등에대한 간략한 지문이 나온적이있어서 잘이해될거라생각했지만.. 컴맹으로써 계속 머리속에서 음미해야겠군요ㅋㅋ
이거랑 이 이전 글 두개만 보시면 핵심 내용은 다 보셨다고 하실 수 있을거에요
잘 읽었습니다^^