본 포스팅 자료는 Keepit 저널의 콘텐츠이며, 직접 저자로 참여하여 작성된 콘텐츠 자료입니다. 해당 콘텐츠는 비트코인의 전반적인 내용을 담을 예정이며, 이전의 작성했던 비트코인 관련 콘텐츠를 보강해줄 수 있다고 생각하며, 블로거 여러분들에게 공유를 하기 위한 목적으로 옮겨왔습니다.

원본 게시글




KEEP!T Column


안녕하세요! KEEP!T입니다. 지난 '비트코인 뽀개기 1편'에 이어서 비트코인에서 데이터를 저장하기 위한 수단으로 왜 블록체인 기술을 활용했는지에 관한 관점으로 포스팅을 진행하도록 하겠습니다. 혹시 비트코인 뽀개기 시리즈 읽지 않으셨다면 아래의 링크를 통해 읽어보시면 좋을것 같습니다.



데이터 베이스


데이터 베이이스는 체계화된 데이터를 저장, 조작 관리하는 방법을 의미하며 사용하는 방법에 따라, 계층형, 관계형, NoSQL 데이터 베이스등이 있습니다. 비트코인에서는 데이터를 저장하기 위한 수단으로 기존에 사용되어왔던 데이터 베이스 기술 방식이 아닌 블록체인 기술을 활용하였습니다.

중앙 집중형 시스템에서 자주 사용되어왔던 데이터베이스는 수정, 삭제하기 매우 쉬웠기 때문에 일부 권한을 가지고 있는 사용자들만이 데이터를 관리해야했습니다. 하지만 탈 중앙화된 금융 시스템을 만들기 위해서는 누구나 네트워크에 참여할 수 있으며, 모든 참여자가 데이터 베이스에 접근할 수 있고 데이터를 기록할 권한을 가지고 있어야 합니다. 그렇기때문에 기존의 중앙 집중형 시스템에서 자주 사용되어왔던 데이터 베이스의 형태가 아닌 새로운 데이터 베이스가 필요했습니다.

관계형 데이터 베이스 : 키(key)와 값(value)들의 간단한 관계를 테이블화 시킨 매우 간단한 언칙의 전산 정보 데이터베이스다. 1970년 에드거 F. 커드가 제안한 관계형 모델에 기초하는 디지털 데이터베이스이다.

NoSQL 데이터 베이스 : 전통적인 관계형 데이터베이스 보다 덜 제한적인 일관성 모델을 이용하는 데이터의 저장 및 검색을 위한 메커니즘을 제공하며, 단순 검색 및 추가 작업을 위한 매우 최적화된 키 값 저장 공간으로 높은 성능 이익을 내는 것이 목적이다. NoSQL 데이터베이스는 빅데이터와 실시간 웹 애플리케이션의 상업적 이용에 널리 쓰이고 있다.


블록체인


블록체인 기술은 분산 컴퓨팅 기술 기반의 데이터 위변조 방지 기술로써, 데이터를 '블록' 단위로 관리하며, 시간의 흐름순으로 블록을 체인(링크드 리스트)형태로 연결한 분산되고, 독립적인 공통 장부(원장, Ledger) 관리 기술입니다. 블록체인은 별도의 중앙 서버 없이 P2P 네트워크 환경에서의 비가역적 공유 데이터 베이스 역할을 수행합니다.

블록체인 기술은 분산되고, 독립적인 데이터 관리를 가능하도록 도와주며, 네트워크에 연결된 모든 사용자들이 블록체인 데이터의 변경 결과를 열람할수 있으며, 합의 알고리즘에 의해 새롭게 추가되는 블록의 검증이 이루어지고, 검증된 블록만을 기존의 블록체인에 연결하여 데이터 위변조를 방지할수 있게됩니다. 이러한 블록체인 기술을 통해 중앙권력 없이 순수하게 사용자들로만 이루어진, 그러나 조작이나 통제가 불가능한 금융 시스템을 만들수 있게되었습니다.

비가역성 : 변화를 일으킨 물질이 본디의 상태로 돌아오지 아니하는 성질, 즉 블록체인에서 비가역적 공유 데이터베이스의 의미는 이미 저장된 데이터를 수정하거나, 삭제할 수 없는 상태를 의미함.


비트코인의 블록체인


탈 중앙화된 금융시스템을 꿈꾸던 비트코인은 앞서 언급한 기존의 데이터 베이스 시스템이 아닌 블록체인 기술을 도입하여 탈 중앙화된 금융 시스템을 만들수 있게 되었습니다. 비트코인 시스템에 적용된 블록체인의 '블록'은 평균 10분에 한번식 생성될 수 있도록 설게되었으며, 블록의 크기는 1MB로 약 1800 - 4200건의 거래내역을 담을 수 있습니다. 비트코인의 블록체인에 저장되는 '블록'은 크게 블록 헤더정보와, 블록 바디정보로 구분할수있습니다.

블록 헤더 : 블록 헤더는 전반적인 블록의 상태 정보를 나타내며, 버전(Version), 이전 블록 해시(Previous block hash), 머클 루트(Merkle Root), 타임(Time), 난이도 목표(bits), 논스(Nonce) 정보로 구성됩니다.

블록 바디 : 블록 바디에는 다수의 거래 정보(트랜잭션)로 구성됩니다.





비트코인에 적용된 블록체인 기술에 대한 이해와, 블록 구성요소의 역할에 대한 명확한 이해를 위해서는 먼저 '해시 함수'에 대한 개념정리가 필요합니다.


해시함수


해시함수는 메시지의 오류나 변조를 쉽고 빠르게 탐지할 수 있습니다. 또한, 데이터의 무결성을 제공하기 위해 사용되며, 매우 빠른 데이터 검색을 위한 소프트웨어에서도 널리 사용됩니다. 비트코인에서는 SHA-256 방식의 해시 함수를 사용하고 있습니다. 해시함수는 아래와 같은 특징을 가지고 있습니다.


  1. 어떤 입력 값에도 항상 고정된 길이의 해시 값을 출력한다.

  2. 입력 값의 아주 일부만 변경되어도 전혀 다른 결과 값을 출력한다.(눈사태 효과)

  3. 출력된 결과 값을 토대로 입력 값을 유추할 수 없다.

  4. 입력 값은 항상 동일한 해시 값을 출력한다.


1번의 특징인 어떤 입력 값에도 항상 고정된 길이의 해시값을 출력하는 특징에 대해서 먼저 살펴보겠습니다. 어떠한 데이터를 입력하여도 항상 고정된 256bit의 결과 값을 출력한다는 의미이며, 이는 방대한 데이터를 256bit로 축약할 수 있다는 의미가됩니다. 2번의 특징인 입력 값의 아주 일부만 변경되어도 전혀 다른 결과 값을 출력한다는 특징을 활용하여 입력값의 위변조를 쉽고 빠르게 확인할 수 있습니다.

SHA 256 해시 함수는 입력 값의 데이터가 아무리 길어도 항상 고정된 길이의 256bit의 결과 값으로 변환해주며, 입력된 결과 값 중 일부만 변경되어도 전혀 다른 결과 값을 출력하기 때문에 256bit의 데이터 비교만을 통해 데이터의 위변조 사실을 알아낼 수 있습니다. 즉 메시지의 오류나 변조를 아주 빠르게 탐지할 수 있는 무결성을 제공할 수 있다는 의미입니다.

만약 책 한 권의 데이터를 한 글자씩 비교하여 변조되었는지 확인한다면 아주 오랜 시간이 소요될 것입니다, 하지만 해시함수의 2가지 특징으로 인하여 방대한 데이터를 256bit로 축약하고, 축약된 데이터가 서로 같은지 비교할 경우 아주 빠르게 원본 데이터의 변조 사실을 탐지할 수 있게 됩니다.


대다수의 웹사이트에서는 데이터 저장 시 보안의 요소로 해시함수를 많이 사용하고 있습니다. 그 이유는 해시 함수의 3번째 특징인 출력된 결과 값을 토대로 입력 값을 유추할 수 없다는 점, 4번째 특징인 입력 값은 항상 동일한 해시 값을 출력한다는 점을 활용하여 데이터 암호화에 많이 사용되고 있습니다.

예를 들어 우리가 어떤 특정 사이트에 회원 가입을 했다고 가정해보겠습니다. 가입 시 입력한 패스워드가 데이터 베이스에 그대로 저장된다면 관리자들은 사용자의 패스워드 정보를 확인할 수 있고, 해킹을 당했을 경우에는 모든 패스워드 정보를 분실할 수 있습니다. 그렇기 때문에 패스워드는 반드시 암호화되어 데이터 베이스에 저장되어야 합니다. 또한 암호화 방식에 규칙이 있고 관리자가 알 수 있다면 해커 또한 해킹을 통해 암호화 방식을 탈취하여 데이터 베이스에 저장된 암호화된 패스워드를 해독할 수 있다는 의미가 됩니다. 그렇기 때문에 암호화 방식은 그 누구도 알 수 없는 방식으로 데이터 베이스에 저장되어야 합니다.

웹 사이트 가입 시 패스워드를 abc라고 입력했고, 입력 값을 해시함수를 통해 해시 결과 값으로 0xfx...와 같은 256bit의 해시 결과 값을 데이터 베이스의 패스워드로 저장하게된다면, 해시함수의 특징중 하나인 결과 값을 토대로 입력 값을 유추할 수 없다는 특징으로인하여 관리자는 저장된 패스워드 0xfx...을 토대로 사용자가 어떤 입력 값을 넣었는지 알 방법이 없으며, 해커 또한 탈취한 패스워드의 해시 결과 값을 토대로 사용자가 입력한 원본 패스워드를 알 수 없게 됩니다.

또한, 동일한 입력값엔 항상 같은 결과 값을 출력하는 해시 함수의 특징을 활용하여 사용자는 웹사이트 로그인 시 로그인 창에 자신의 패스워드를 입력하고, 로그인을 요청하게됩니다.

사용자가 로그인을 위해 로그인 창에 자신의 원본 패스워드 데이터를 입력하고, 로그인을 요청하게 되면 시스템 내부에서는 입력한 패스워드를 해시 함수를 통해 해시 결과 값으로 변경 후 데이터 베이스에 저장된 패스워드와 해시 결과 값이 같은지 비교하여 같을 경우 로그인을 정상적으로 처리하게 됩니다. (동일한 입력 값엔 항상 같은 해시 결과 값을 출력하는 특징때문에 사용자가 동일한 패스워드를 입력하게되면 항상 같은 해시 결과 값이 출력됩니다.)


요약 정리


탈 중앙화된 금융 시스템을 유지하기 위해서는 모든 네트워크 구성원들에게 분산되고, 독립적인, 데이터 저장 기술이 필요했으며, 비트코인 네트워크는 블록체인 기술을 활용하여 분산되고, 독립적인 데이터 관리가 가능해졌습니다.

해시 함수의 특징을 활용하여 블록의 위변조를 쉽고 빠르게 확인할 수 있었으며, 다양한 암호학 알고리즘, 작업 증명 방식의 합의 알고리즘 등을 통하여 네트워크의 신뢰도를 향상시킬 수 있었습니다. 다음 비트코인 뽀개기 시간에는 이러한 블록체인의 구성요소에 대하여 자세히 알아보도록 하겠습니다.


yahweh87


참고자료


https://ko.wikipedia.org/wiki/NoSQL

https://ko.wikipedia.org/wiki/%EA%B4%80%EA%B3%84%ED%98%95_%EB%8D%B0%EC%9D%B4%ED%84%B0%EB%B2%A0%EC%9D%B4%EC%8A%A4

https://ko.wikipedia.org/wiki/%EB%8D%B0%EC%9D%B4%ED%84%B0%EB%B2%A0%EC%9D%B4%EC%8A%A4




이 저작물은 크리에이티브 커먼즈 저작자표시-비영리-변경금지 4.0 국제 라이선스에 따라 이용할 수 있습니다.


'비트코인(keepit)' 카테고리의 다른 글

KEEP!T Column 비트코인 뽀개기(1편)  (0) 2018.04.05

아래의 자료는 Keepit 저널에서 게시된 콘텐츠이며, 제가 저자로 참여하여 작성된 콘텐츠입니다. 
비트코인의 전반적인 내용을 담을 예정이기에 게시물을 따로 분류하여 블로거 여러분들에게 공유하기 위한 목적으로 옮겨왔습니다. 

[ 원본 게시글 ]

KEEP!T Column

안녕하세요! KEEP!T입니다. 최초의 암호화폐인 비트코인을 누구나 쉽게 이해할 수 있도록 '비트코인 뽀개기'라는 주제로 새로운 콘텐츠를 제작하게 되었습니다. 다소 부족한 부분이 있다면 지금까지 그래왔던 것처럼 독자분들께서 적극적인 코멘트 해주셨으면 좋겠습니다, 앞으로 많은 관심 부탁드립니다.

탈 중앙화된 금융 시스템의 필요성

서브프라임 모기지 사태 : 2000년대 초반 IT 버블이 붕괴되고 911 테러, 아프간/이라크 전쟁 등으로, 미국 경기가 악화되자 미국 정부는 경기부양책으로 저금리 정책을 펼쳤습니다. 주택융자 금리가 인하되자, 많은 사람들은 대출을 받아 주택을 구매하였고, 부동산 가격은 상승하기 시작했습니다.
경기가 좋아지자 미국 정부는 2004년 저금리 정책을 종료하였고, 주택융자 금리 또한 인상되었습니다. 금리가 인상되자 저 소득층 대출자들은 원리금을 갚지 못하는 상황이 발생하였고 담보로 잡혀있던 주택 가격들은 하락 하기 시작하였습니다. 서브 프라임 모기지론을 구매한 금융기관들은 대출금을 회수할 수 없는 상태에 빠졌고, 이 과정에서 여러 기업들이 부실화되면서 미국의 대형 금융사 및 증권회사들의 파산으로 이어졌으며, 결국 2008년 세계 금융 위기까지 이어지게 됩니다.
세계 금융위기가 발생하자 주요 국가의 중앙은행에서는 양적 완화를 통해 위기를 극복하고자 하였고, 무분별한 화폐의 발행으로 화폐의 가치가 하락하자 모든 경제 구성원들에게 피해가 이어졌습니다. 일부 기업의 실패로 시작된 금융위기를 양적 완화를 통해 극복하는 모습에 많은 사람들이 글로벌 금융 시스템에 대한 불신이 생겼으며 누구나 신뢰할 수 있는 탈 중앙화된 금융 시스템의 필요성이 부각되기 시작하였습니다.
양적 완화 :  중앙은행이 발권력을 동원해 화폐를 발행한 후, 그 화폐로 국채나 민간이 가지고 있는 일정 신용등급 이상의 채권을 매입하여 통화량을 늘리는 정책입니다.


탈 중앙화된 금융 시스템 도입의 어려움
전자화폐

전자화폐는 전자적으로만 교환되는 돈이나 증서를 뜻하며, 컴퓨터 네트워크, 인터넷, 디지털 선불 카드시스템에서 통용되어 사용되고 있습니다. 페이팔(PayPal), 웹머니 등과 같은 중앙 집권적 체계의 전자화폐 시스템은 오래전부터 개발되어 상용화되었지만, 개인과 개인이 거래를 할 수 있는 탈 집권적 체계의 전자 화폐 상용화에는 기술적, 제도적 문제점들이 있었습니다.

'기술적' 문제

디지털 데이터는 무한대로 복제 가능하고, 원본과 복사본의 구별이 어렵기 때문에 이중 지불이라는 문제를 내적으로 안고 있었으며, 분산 컴퓨팅 분야의 오래된 난제 중 하나인 비잔틴 장군 문제와 같은 기술적 어려움이 있었습니다.
이중 지불(Double Spent): 단일 통화 단위가 두번 결제되어 발생하는 문제다. 디지털 데이터는 무한대로 복제가 가능하고 원본과 복사본의 구별이 어렵기 때문에, 디지털 화폐는 이중 지불이란 문제를 내재적으로 안고 있다. 디지털 데이터가 검증받지 못한다면, 그 데이터를 복사해서 동시에 여러 곳에 사용할 수 있는 것이다.
비잔틴 장군 문제(Byzantine General's Problem): 1984년 레슬리 램포트와 쇼스탁, 피스가 공저한 논문 에서 처음 언급된 문제이며, 분산 컴퓨팅 분야에서 오랫동안 풀지 못했던 난제다. 서로를 신뢰할 수 없는 사람들이 참여하는 분산 P2P 네트워크에서 어떻게 합의를 이뤄낼 것인가에 관한 문제이다.

'보상'의 필요성

탈 중앙화된 금융 시스템이 유지되기 위해서는 개인의 '희생'이 필요합니다. 예를 들어 P2P 네트워크 중 하나인 토렌트 프로그램을 생각해보겠습니다. 토렌트에 접속하는 대다수의 구성원들은 자신이 원하는 파일을 다운로드 받기 위해 접속하며, 다운로드가 완료될 경우 해당 프로그램을 종료합니다. 다른 구성원들을 위해 업로드 기능을 활성화하여 자신의 컴퓨터 자원을 '희생'하는 구성원은 극히 소수일 수밖에 없습니다.
탈 중앙화된 금융 시스템이 정상적으로 동작하기 위해서는 시스템을 유지시켜야 하는 '이유'와 '목적'을 구성원들에게 제공해야 합니다.

비트코인

비트코인은 블록체인 기술을 기반으로 만들어진 암호 화폐이며, 중앙은행 없이 P2P 네트워크를 통해 개인들 간에 자유로운 금융 거래를 할 수 있도록 설계된 암호 화폐입니다. 2008년 10월 사토시 나가모토라는 가명을 사용한 프로그래머가 "Bitcoin : A Peer-to-Peer Electronic Cash System"이라는 제목의 9쪽짜리 논문을 공개했고, 3개월 만인 2009년 1월 프로그램 소스를 배포함으로써 세상에 알려지기 시작하였습니다.


비트코인의 화폐 단위는 BTC로 표기하며, 1 BTC 미만의 단위는 비트코인의 창시자 사토시 나가모토의 이름에서 따온 사토시(satoshi)라 부릅니다. 비트코인의 총 발행량은 2140년까지 총 2100만 개로 정해져있으며, 무분별하게 발행될 수 있는 종이화폐와 달리 제한된 양의 화폐를 발행함으로써 더 큰 가치를 얻을 수 있었습니다.
기존의 탈 중앙화 시스템의 기술적 문제점인 이중 지불 및 비잔티움 장군 문제를 합의 알고리즘인 작업 증명(Proof-of-Work)알고리즘을 통해 해결하였으며, 네트워크에 더욱더 많은 기여를한 구성원에게 더 큰 '보상'을 줌으로써 선의의 경쟁을 통해 더 많은 사용자들이 네트워크에 기여하고 일할 수 있는 환경을 제공하였습니다.

비트코인의 등장 이후 이더리움, 스팀과 같은 다양한 암호 화폐와 플랫폼들이 개발되기 시작하였고, 현재에는 많은 기업들이 블록체인 기술을 활용한 서비스 개발에 집중하고 있습니다. 비트코인은 단순히 암호 화폐의 기능만을 제공하는 것이 아니라 새로운 패러다임의 시작을 알린 암호 화폐라고 생각합니다.


yahweh87


[참고자료]


'비트코인(keepit)' 카테고리의 다른 글

KEEP!T Column 비트코인 뽀개기(2편)  (0) 2018.04.12

+ Recent posts