자료구조로써의 블록체인(Blockchain)

taeheeyoon·2022년 6월 22일
3

Blockchain 이론

목록 보기
3/14
post-thumbnail

시작하며

안녕하세요.
본격적으로 비트코인을 소개하기 전, 비트코인의 핵심 기술인 블록체인이 무엇인지 알아봅시다.

블록체인이란?

블록체인의 핵심은 인터넷 상에 있는 사람들과 동일한 데이터를 가지는 것입니다. 블록체인은 다음과 같은 방식으로 데이터를 저장하고 공유합니다.

  • 누구나 데이터를 추가할 수 있다.
  • 데이터는 한 번 추가되면, 수정하거나 삭제할 수 없다.
  • 개인이나 단체가 데이터를 관리하는 것이 아니라, 블록체인 네트워크에 있는 모든 사람들이 함께 관리한다.

그렇다면 블록체인에서 블록(Block)체인(Chain)은 각각 무엇을 의미하는 것일까요?

블록(Block)


블록 예시

블록은 데이터를 저장하는 공간입니다. 블록에는 자산에 대한 정보를 담거나, 개인 정보를 암호화해서 담는 등 다양한 유형의 정보를 담을 수 있습니다. 따라서 블록의 구성은 어떤 종류의 데이터를 저장하느냐에 따라 결정됩니다.

비트코인과 같은 일반적인 암호화폐에서는 블록에 거래기록을 저장합니다. 블록체인에서는 이 거래기록을 트랜잭션(Transaction)이라고 합니다. 가령 A가 B에게 0.01 비트코인을 이체했다면, "A가 B에게 0.01 비트코인을 전송했음"이라는 이체 내역이 바로 트랜잭션입니다.
우리가 은행에서 송금을 하고 나면 이체 내역에는 송금자의 정보, 계좌 잔액, 보내려는 금액, 수신자의 계좌, 보낸 시각 등이 기록됩니다. 마찬가지로 블록에 들어가는 트랜잭션에도 송금자에 대한 정보, 송금자의 잔액, 보내려는 금액, 수신자에 대한 정보가 들어갑니다. 또한 블록체인에서는 사용자가 직접 자신의 자산에 대한 소유권을 증명하기 위한 디지털 서명을 추가합니다.

블록은 이러한 트랜잭션들을 담은 거래 기록의 집합입니다.

체인(Chain)

블록 하나에 전세계의 모든 거래 기록을 담는다면 블록의 크기가 너무 커질 것입니다. 또한 네트워크에 있는 사람들이 동시에 하나의 블록에 거래를 기록하려고 하면 편의성도 떨어질 것입니다.

예를 들어 봅시다. 블록에는 특정 기간(10분, 1시간 등) 동안 발생한 거래 내역이 기록되어 있습니다. 만약 블록 하나에 10분간의 거래 내역이 기록된다면, 블록 6개에는 한 시간 동안의 거래 내역들을 볼 수 있습니다. 만약 블록 하나에 들어있는 기간이 너무 짧거나, 너무 길면 불편할 것입니다.

한편, 이 블록들은 인터넷을 통해 많은 사람들에게 공유될 것입니다. 블록에 담기는 트랜잭션 기간이 짧다면 블록의 크기는 줄고 블록이 더 자주 생성될 것입니다. 그러면 블록을 공유받는 사용자는 더 많은 블록을 공유받아야 하기 때문에 불편할 것입니다. 반대로, 블록에 담기는 트랜잭션의 기간이 너무 길면 블록의 크기가 커질 것입니다. 블록의 크기가 커지면 대역폭의 한계로 인터넷에 공유되는 속도가 느려질 것입니다.

그래서 네트워크에 참여한 사용자가 하나의 블록에 일정한 갯수의 트랜잭션을 넣어 네트워크에 공유하면, 새로운 블록을 만들어 새롭게 생긴 트랜잭션들을 담습니다. 그리고 이 새로운 블록에는 이전 블록을 지칭하는 데이터를 함께 넣어, 직전 블록이 어떤 블록인지 지정합니다.


블록체인 연결 예시

이후 일정량의 트랜잭션이 생길 때마다 해당 트랜잭션들을 블록에 넣고, 이전 블록을 가리키는 주소값을 함께 넣습니다. 이러한 모양이 꼭 체인처럼 연결되어 있다고 해서 이러한 데이터 구조를 블록체인이라고 부릅니다.

블록 생성

블록체인 네트워크에서 거래가 발생하여 새로운 트랜잭션이 생기면, 이 트랜잭션은 네트워크 내에 있는 모든 노드들에게 공유됩니다. 따라서 블록체인에서는 다양한 검증(Verification)절차를 수행합니다. 노드들은 공유받은 트랜잭션이 실제 송금자가 만든 트랜잭션이 맞는지, 악의적인 사용자가 타인을 사칭하는 것은 아닌지, 트랜잭션이 만들어지고 난 후 수정되지는 않았는지 검사합니다.

노드: 네트워크에 장치 또는 데이터 지점을 의미한다. 쉽게 말해 네트워크에 접속해 있어서 연결될 수 있는 컴퓨터를 지칭한다.

트랜잭션에 대한 유효성 검사가 끝났다고 해서 해당 트랜잭션에 대한 처리가 완료되는 것은 아닙니다. 트랜잭션이 블록에 담기고, 해당 블록이 체인에 추가되어 블록체인의 일부가 될 때 트랜잭션에 대한 처리가 완료됩니다.
여기서 트랜잭션을 모아서 하나의 블록으로 만드는 과정을 채굴(Mining)이라고 합니다.

채굴은 트랜잭션을 처리하는 작업이므로 암호화폐 시스템에서는 송금 처리를 뜻합니다. 따라서 채굴은 암호화폐 송금 서비스를 운영하는 핵심 역할을 하기 때문에 채굴 노드에게는 보상이 주어집니다. 이 보상을 얻기 위해 채굴은 경쟁적으로 이루어집니다. 경쟁에 참여한 노드들은 저마다 블록을 만들어 네트워크에 전파하며, 이 경쟁에서 승리한 노드가 생성한 블록이 채택됩니다. 블록을 받은 노드들은 해당 블록이 유효한지 확인하고, 해당 블록이 유효하다면 체인에 추가합니다.
채굴 노드는 블록 생성에 대한 보상으로 코인을 받으며, 발행된 코인은 블록체인 네트워크 내에서 화폐의 역할을 하게 됩니다.

분산원장과 블록체인

원장은 거래 내역의 집합이며, 앞서 살펴본 블록체인은 원장을 저장하는 데이터베이스 유형 중 하나입니다.

원장을 가지고 있는 사용자들이 원장에 대해 동등한 권한을 가지고 있는 경우를 생각해 볼 수 있으며, 가장 극단적인 형태로는 모든 권한이 모두에게 동등한 P2P(Peer-to-Peer) 분산 원장 시스템을 떠올릴 수 있습니다.
중앙 집중식 데이터베이스와 달리 분산 원장(Distributed Ledger)은 분산되어 있으며, 데이터를 여러 위치에 두거나, 여러 사용자들이 나눠서 가지고 있는 데이터베이스 유형입니다.
분산 원장 시스템에서 데이터를 저장하기 위해서는 데이터를 공유하고 있는 당사자들이 합의해야 하며, 당사자들의 합의를 통해 분산되어 있는 데이터베이스들이 하나의 일관된 데이터를 가질 수 있습니다.

블록체인은 특정 기술들이 추가된 분산 원장의 한 종류입니다. 블록체인은 네트워크 내 모든 노드들이 새로운 블록에 대한 유효성을 검증하고 난 후에, 블록을 체인에 추가할 수 있기 때문입니다.

일반적인 분산 원장과 블록체인의 차이점은 다음과 같습니다.

  1. 블록 구조
    블록체인은 일반적으로 블록 형태로 데이터가 저장됩니다. 그러나 모든 분산 원장이 블록 형식으로 데이터를 저장하지는 않습니다. 분산 원장은 여러 노드에 데이터를 분산시켜 저장하는 데이터베이스이며, 블록 형식이 아닌 다른 다양한 방식으로 데이터를 저장할 수 있습니다.
  2. 순서
    블록체인 기술은 모든 블록이 직전 블록을 가리킴으로써 순서대로 배열되어 있습니다. 그러나 모든 분산 원장에서 데이터를 꼭 순서대로 저장하지는 않습니다.
  3. 블록 생성 메커니즘
    블록체인에서는 블록을 생성할 노드를 정하기 위해 PoW, PoS 와 같은 메커니즘을 사용합니다. 이러한 메커니즘은 보통 자원을 소모하게 합니다. 그러나 일반적인 분산 원장에서는 블록을 경쟁적으로 생성하지 않는 메커니즘을 사용하는 경우도 있습니다.
  4. 토큰
    블록체인에서는 블록을 생성하기 위해 자원을 소모한 노드에게 보상을 주기 위해 코인을 제공하며, 이 코인은 화폐의 역할을 합니다. 만약 자원을 소모해 블록을 생성했는데 아무런 보상도 주어지지 않는다면 아무도 블록을 만들려 하지 않을 것입니다. 따라서 블록체인에는 코인이 필수적입니다.

요약

자료구조로써의 블록체인

  • 블록체인: 인터넷 상에 있는 사람들과 동일한 데이터를 가지는 것.
    • 블록: 트랜잭션을 담은 거래 기록의 집합.
    • 체인: 블록을 만들어진 순서대로 연결한 블록의 집합.
  • 블록 생성: 블록체인 네트워크 내의 사용자들은 트랜잭션을 검증한다. 채굴 노드는 트랜잭션들을 블록에 넣어 체인에 올리고, 채굴에 대한 보상으로 코인을 받는다.
  • 분산 원장과 블록체인의 차이
분산 원장블록체인
블록구조여러 노드에 데이터를 분산시켜 저장하기만 하면 되기 때문에 블록 외에 다양한 방식으로 데이터를 저장함블록 형태로 데이터를 저장함
순서데이터를 꼭 순서대로 저장하지는 않는다.모든 블록은 자신의 직전 블록을 가리킴으로써 순서대로 배열되어 있다
블록 생성 메커니즘누가 데이터를 데이터베이스에 올릴지 정할 필요가 없다.블록을 생성할 노드를 정하기 위해 자원을 소모하는 메커니즘을 사용한다.
토큰토큰이나 화폐가 필요하지 않다.자원을 소모해 블록을 만든 노드에게 보상을 주기 위해 코인을 제공한다.

마치며

자료구조로써의 블록체인에 대해 알아보았습니다. 다음 글에서는 블록체인을 대표하는 비트코인과 이더리움에 대하여 간략하게 알아보겠습니다. 감사합니다.

profile
생각하는 대로 살지 않으면, 사는 대로 생각하게 된다.

0개의 댓글