[연재글] 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를 선물하세요.
-
ㅋㅋㅋㅋㅋㅋㅋ 이게맞냐
-
차이가 뭔가요???
-
반수해서 옮기는 대학교 합격증 인스타에 올리셨음뇨? 아님 ㄴㄴ?
-
[칼럼] 모집정지? 의대 학교 입장에서 간단히 생각해보자 3
증원을 맞이한 의과대학은 아래의 세 가지 선택지가 있다. 1) 25학번 모집정지...
-
한국이 그렇게 공평한 나라였다면 남자만 독박징병하는것도 나라가 공평해서임?
-
혼자지내면서 알바하고 그 돈으로 혼자 영화보고 공연보러가고 맛있는거 먹는게 인생...
-
변남 어디없나요 0
똥 자주싸는 설사남 어디없나
-
맛점하세요 5
맛점
-
가성비로요!!
-
페미니스트대통령 1
헉
-
프사일러 투척. 1
음 역시귀엽군
-
언제부턴가 우리나라는 상식이란게 통하지 않게 되었네요 3
내일 당장 어떤 일이 일어날지 아무도 알수 없는, 그런 나라가 되어버렸어요 언제부터였을까요
-
준비물:고속, 진학사 계정, 엑셀, 크럭스테이블 진학사는 원점수는 안보여주고...
-
고1,2 모고에서 대부분은 1컷에 걸리는 성적(1,2 왔다 갔다하는 성적)이었음...
-
점심여캐투척 2
으흐흐
-
공부방법을 물어보시는 분도 있고 다짜고짜 말도 안 되는 말을 하지 말라는 분도...
-
학종 열심히 채워놨고 진로는 생명쪽으로 채웠습니다 주요교과 (국수영과사?) 랑....
-
자꾸 재학생들 25학번 불인증 거리면서 겁주고 다니는데 2
-4500시킨다는 사람들이 왜 24학번 -3000시킬수도 있다는 생각은 못해요?...
-
선생님이 갑자기 바지내리면 그것도 생중계로 전국에서 보는거임?
-
꿀잼 두오가실분 구해요...
-
여행일정때문에 고민.. 1/2~1/6 왕복 33 1/21~1/24 왕복 43 둘중하나 택
-
하하
-
일주일을 기념할 수 있군요 ㅋㅋ ㅋ
-
남자가 파데스틱바르고 눈화장이랑 턱쉐딩하면 관리하는거? 9
어제 아는 알바하는형님이 술마시자고해서 급하게 헤어 세팅하고 (가일) 피부 기초로...
-
7일남음 3
카리스미ㅏ스
-
3학년 올라가고 학교에선 미적 선택했는데 수능은 확통으로 보려고 합니다. 이러면...
-
하.. 진짜 괜히 올려봤다… 대체 왜… 3칸뜨는 데가 다 안정이되지..
-
수학 오랜만에 풀어봄ㅋㅋ 과외구해볼까
-
기만하니까 뭔가 기분 좋음(진짜 개지잡임
-
어캐해야함? 진지하게. 수학공부하듯이 시간 때려박아야하나
-
성대 변표 0
제발 당장 좀 내놔 사람 죽는 꼴 보고 싶어?
-
진학사 9칸 6
쓰면 바보임?
-
현강이라 둘다 들어본 사람 없지 싶은데 두 사람 각각 어땠는지 궁금하다
-
숭실대 경영 경제 금융 vs 아주대 산업공핟 근데 문과로 가면 공모전, 대회 이런거...
-
재수생 많은게 문제라면서 수시는 왜 N수도 쓸수있는지 의문이다 고대 최저 충족률...
-
연대 서울대 빼고 또 있나요..?
-
노트북에 바로 붙여넣기하는거 어떻게 하는지 아시는분? 원래됐었는데 노트북 빌려준다고...
-
점심메뉴추천 7
해줭 뭐먹지
-
홍익대 합격생을 위한 노크선배 꿀팁 [홍대25][장학금꿀팁] 0
대학커뮤니티 노크에서 선발한 홍익대 선배가 오르비에 있는 예비 홍익대생, 홍익대...
-
배치표 0
이대랑 외대랑 대학 반영비가 같던데 이투스 배치표상으로 같은선상에 있는 과를 해도...
-
정치인이 힘이 어쩌고 누구를 미워하고 저쩌고 지껄이는데 이건 아주 유아적인 단계의...
-
수학 노베 6등급 공부법(커리 외) 조언부탁드립니다..!! 우선 지금은 개념원리...
-
신천지같이 가자하면 갈거냐
-
색 계 봤눙데 야한것도 야한건데 영화가 예술적이네 밖에서봐서 팬티말리러 집가야겠음요...
-
어제의 친구는 오늘의 경쟁자다...
-
현재 국어 모고 공부 안했고 고1 모고 치면 국어 낮은 4, 높은 5가 뜹니다 이젠...
-
배치표 0
배치표상 이대랑 외대랑 같은 선상에 있는데 칸수가 다른건 반영비의 문제일까요? 연논...
-
이번 수능에서 화작 국어 7이 떴습니다.. 인강을 보는 게 아니고 제 스스로...
-
ㅈㄱㄴ..
모아놓고나중에봐야지
꼭 봐주세요 ㅋㅋ 보통 모아놓고 나중에 봐야지 한건 안보던데 ㅋㅋㅋ
오.. 이 글로 전 글들에서 이해가 되지 않은 부분들이 하나로 이어지는 듯한 느낌이네요..
그런데 2140년이 되면 진짜로 비트코인은 채굴이 불가능하게 되는 건가요?
채굴 보상으로는 얻는 것이 없고, 거기 담긴 거래들의 수수료를 보상으로 가져가게 됩니다. 지금도 기본보상 + 수수료를 받아가고 있는 거구요. 수수료 수준도 적정 수준을 Node가 계산하게 됩니다. 아마 기본 보상이 줄어들면 수수료가 조금씩 상승하겠죠?
비트코인의 총량이 정해져 있는 이유는 무엇인가요? 결국 무한정 채굴이 가능한 구조라면 애초부터 총량이 정해지지 않아도 무방한 것 아닌가요?
화폐의 총량이 정해져있지 않다는 말은 시장에 화폐가 지속적으로 공급되면서 인플레이션을 유발할 수 있다는 말이 됩니다. 그리고 총량이 정해져있음으로서 스스로의 가치를 올릴 수도 있죠. 금처럼요.
페페캐시라는 종류의 알트코인이 있는데, 얘들은 일정 주기마다 시총의 일정량을 태워서(영구적으로 없애서) 인플레이션을 막는 방법을 씁니다.
결국 화폐의 가치를 유지하기 위해 총량이 정해져 있는거네요..
나중엔 진짜 금처럼 취급할수도 있을듯
요새 근데 비트코인이 뭐 하드포크를 하네 뭐가 어쩌네 하는 말이 많아서.. 뭔가 암호화폐 Gen.2 같은게 나와서 자리를 잡기 전까지의 암호화폐는 수많은 공격과 시험의 대상일거라... 이더리움도 한때 해킹 이슈로 갈라졌고 뭐 그렇습니다.
아 역시 건드리면 안될듯합니다 ㅎㅎ
국어기출에 해시함수 논스~~등등에대한 간략한 지문이 나온적이있어서 잘이해될거라생각했지만.. 컴맹으로써 계속 머리속에서 음미해야겠군요ㅋㅋ
이거랑 이 이전 글 두개만 보시면 핵심 내용은 다 보셨다고 하실 수 있을거에요
잘 읽었습니다^^