비트코인 스크립트는 비트코인 스크립팅 프로그래밍 언어로 작성되었습니다. 튜링 완전하지 않은 상당히 간단한 언어로, 루프를 포함한 일부 논리적 기능이 부족합니다.
이는 단일 비트코인 스크립트가 많은 컴퓨팅 파워를 소모하여 비트코인 네트워크 노드를 손상시키지 않도록 하기 위해 특별히 수행되었습니다.
이 스크립트는 비트코인을 잠금 및 잠금 해제하는 데만 거의 독점적으로 사용되며, 애플리케이션을 만들거나 프로그램을 실행하는 데 사용할 수 없습니다.
Coinmarketrate.com 에 따르면 , 스크립트가 제공하는 단순성은 비트코인의 보안을 강화하고 개발자의 작업을 보다 쉽게 만들어 네트워크와 작동하는 지갑이나 애플리케이션이 제대로 설계되지 않은 경우 돈이 사라지는 것을 방지합니다.
모든 비트코인 거래는 자금을 어떻게 사용할지 결정하는 스크립트를 사용합니다. 즉, 비트코인 거래 스크립트는 BTC가 누구에게 전송되는지를 결정합니다.
비트코인에는 여러 유형의 암호화폐가 있지만, 그 중 가장 인기 있는 것은 P2PKH(Pay to Public Key Hash)입니다. 이는 공개 키의 해시인 주소로 BTC를 지불하는 간단한 스크립트입니다.
다른 스크립트는 다중 서명 주소 생성 등 매우 복잡한 구성을 수행할 수 있습니다. 이러한 주소로 보낸 비트코인을 사용할 수 있으려면 여러 개인 키의 여러 서명이 필요합니다.
SegWit 암호화폐인 P2WPKH와 P2WSH는 거래 수수료를 절감할 수 있지만, 아직 도입률이 높지 않습니다. 이 개선 사항이 출시된 지 4년이 넘었지만 P2PKH는 여전히 대부분의 UTXO에서 사용되고 있습니다.
중요한 비트코인 개념
스크립트는 Forth 프로그래밍 언어와 비슷하며, 스택 기반이며 역 표기법을 사용합니다. 튜링 불완전한 프로그래밍 언어입니다.
물론, 프로그래밍을 해본 적이 없다면 이 모든 것이 중국어처럼 들릴 수 있겠지만, 핵심은 매우 간단한 개념입니다. 나중에 이것들을 자세히 설명하여 이것들이 어떻게 작동하는지, 왜 중요한지 이해하도록 하겠습니다.
하지만 그 전에, 공식 비트코인 소프트웨어(비트코인 코어라고도 함)는 비트코인 스크립트로 작성되지 않았다는 점을 말씀드리는 것이 중요합니다.
하지만 비트코인 스크립트를 가능하게 하는 것은 비트코인의 소프트웨어 구현입니다. C++로 작성된 것이거나 적어도 원래 구현된 것이었습니다. 이 프로그램의 첫 번째 버전이 출시된 이후 Python, Java, Go로 다양한 버전이 만들어졌습니다.
Python 구현의 경우 이 언어 덕분에 Bitcoin Script가 가능합니다. 이는 다른 사람들이 사용하는 다양한 비트코인 구현에도 해당됩니다.
비트코인 스크립트는 비트코인 소프트웨어와 상호작용하는 데 사용되는 프로그래밍 언어입니다. 구체적으로, 스크립트는 비트코인 소프트웨어에 UTXO(사용되지 않은 거래 출력)에 있는 코인을 어떻게 사용해야 하는지 알려줍니다.
물론, 대부분 사용자는 이 언어를 사용하는 방법을 배울 필요가 없습니다. 오직 비트코인과 상호작용하는 지갑이나 다른 애플리케이션만이 이를 이해해야 하며, 사용자는 이를 알지 못합니다.
이 스크립트는 사토시 나카모토가 비트코인 버전 0.1에서 구현했습니다. 하지만 당시 공개 당시 몇 가지 오류가 있었습니다.
일부 사용자는 비트코인 스크립트가 마지막 순간에 구현된 것으로 보이며 실제 거래에는 충분하지 않다는 의견을 표명했습니다. 다행히도 최신 버전에서는 코드를 다듬는 데 많은 개선 사항이 도입되었습니다.
- 스택의 바닥에서
비트코인 스크립트는 스택으로 물리적으로 표현하여 가장 잘 이해되는 데이터 구조를 사용합니다. 새로운 요소가 추가(푸시)되거나 제거(팝)되면, 이는 스택의 마지막 요소에서 수행됩니다.
예를 들어 책 3권이 위에 또 놓여 있다고 가정해 보겠습니다.
- 책(A) : 상단 부분
- 책(B) : 보통
- 책 ©: 바텀
비트코인 스크립트를 사용하면, 먼저 스택에서 책 A를 뽑고, 그 다음에 책 B, 마지막으로 책 C를 뽑습니다.
새로운 책을 추가하고 싶은 경우, 마지막 책, 즉 책 A에서 작업을 수행합니다.
비트코인 스크립트는 거래가 순차적으로 추가되고 역순으로 제거되는 방식으로 작동합니다.
- Forth와 유사
스크립트는 Forth 프로그래밍 언어와 매우 유사합니다. 이 작품은 1970년에 처음 등장했으며, 적어도 꽤 잘 알려져 있었습니다.
포스는 오픈 펌웨어 부트 로더, 항공우주 애플리케이션 및 하드웨어와 상호 작용해야 하는 다양한 임베디드 시스템에서 사용됩니다.
- 역 표기법
후위 표기법이라고도 불리는 RPN(역 폴란드 표기법)은 명령문의 끝에 함수의 연산을 배치하는 방법입니다.
예를 들어, 1 + 2를 더하고 싶다면, 평소의 “1 + 2” 대신 “1 2 +”라고 쓰면 됩니다.
- 불완전한 튜링
불완전한 튜링은 스크립트가 무한 루프를 허용하지 않는다는 것을 의미합니다. 장점과 단점이 있는 것이죠.
이 기능을 사용하면 설계가 형편없는 스크립트를 실행해서 무한 루프에 빠지는 일이 없어집니다. 이는 프로그래밍 오류나 공격으로 인해 발생할 수 있습니다.
더 기술적인 용어로 말하면, 스크립트는 정지 문제라고 알려진 문제를 피합니다.
다른 암호화폐는 튜링 완전성, 또는 적어도 높은 수준의 무결성을 갖춘 프로그래밍 언어를 구현하는 데 성공했습니다. 물론, 여기에는 중단 문제가 따르는데, 그들은 완료해야 할 제안의 수에 비례하는 수수료를 부과함으로써 이 문제를 해결합니다.
튜링 완전한 언어가 아닌 것의 단점은, 예를 들어 스마트 계약을 가능하게 하는 더 복잡한 알고리즘을 개발하는 것이 불가능하다는 것입니다.
BTC 거래는 어떻게 진행되나요?
매우 단순한 관점에서 보면, 비트코인 스크립트는 거래 수신자가 자금을 사용하는 방법을 설명하는 지침 목록으로 생각할 수 있습니다.
대부분의 비트코인 거래에는 간단한 스크립트만 필요하지만, 더 복잡한 스크립트도 구현할 수 있습니다.
이 모든 것이 어떻게 작동하는지 이해하기 위해 P2PKH(공개 키 해시 지불) 거래가 어떻게 작동하는지 살펴보겠습니다.
순수 비트코인 스크립트
실제로, 트랜잭션에서 Pay To Publish Key Hash(P2PKH) PubKey 스크립트가 어떻게 보이는지 살펴보면 다음과 같습니다.
BTC 암호화폐는 무엇에 사용할 수 있나요?
이미 그 모습과 작동 방식을 살펴보았지만, 거래 출력을 사용하는 방법을 지정하는 스크립트를 만드는 것 외에도 여러 가지 유용한 용도가 있습니다.
- 에스크로 운영
첫 번째 응용 프로그램은 에스크로 거래와 관련이 있으며, 특정 상황에서 매우 유용합니다.
새로운 판매자에게서 뭔가를 사고 싶다고 가정해 보겠습니다. 우리는 BTC 로 지불 하고, 판매자는 실제 제품을 우리 집으로 보내줄 것입니다. 우리는 그들이 물건을 받기 전에 대금을 지불할 것이라고 믿지 못할 수도 있지만, 판매자는 그들이 먼저 대금을 받지 않는 한 물건을 배송하고 싶어하지 않습니다.
해결책은 다중 서명 거래를 만드는 것인데, 이를 위해서는 암호화폐를 사용하려면 2~3명의 서명이 필요합니다. 이 경우에 동일한 사람은 판매자인 우리와, 분쟁 발생 시 판사 역할을 할 또 다른 사람이 됩니다.
이들 중 2명만 동의하면 다른 주소로 암호화폐를 보낼 수 있습니다. 이를 통해 판매자는 상품을 안전하게 배송하고 우리는 대금을 지불할 수 있습니다.
우리가 상품을 받고 모든 것이 괜찮다면, 판매자와 다중 서명 계약을 체결하고 판매자에게 돈을 줄 수 있습니다. 여기에는 제3자의 개입이 필요하지 않습니다.
판매자가 우리를 속이려 하거나 우리가 상품에 대한 대금을 지불하고 싶지 않을 경우, 당사자 중 한 쪽이 중개자로 제3자를 사용하여 자금을 해제할 수 있습니다.
- 효율적인 소액결제
예를 들어, 귀하가 매우 적은 금액으로 제공되는 서비스의 소비자라고 가정해 보겠습니다. 예를 들어, 공항에서는 인터넷을 사용하면 1분마다 요금을 내야 합니다.
사용된 매 분마다 거래를 생성하는 것은 매우 비효율적일 것입니다. 가치가 거의 없는 거래가 너무 많아지고 수수료가 빠르게 누적될 것입니다.
해결책은 우리가 이 서비스에 결코 지출하지 않을 매우 높은 비용을 들여 다중 서명 거래를 만드는 것이며, 이를 위해서는 우리 측과 제공자 측 모두의 서명이 필요합니다. 서비스를 이용하려면 먼저 온라인에서 검증을 받아야 합니다.
1분이 지나면 우리는 새로운 거래에 서명하고, 그 시간에 대한 요금을 지불하고 나머지는 우리 주소로 보냅니다. 이 거래는 첫 번째 거래에서 발생한 자금을 사용합니다.
2분 후에 또 다른 거래가 생성되고 당사에서 서명하게 되며, 이를 통해 귀하는 2분 이내에 결제를 받으시고 나머지는 당사에서 받게 됩니다. 또한 첫 번째 거래에서 발생한 자금을 입력으로 사용합니다.
이 시점에서는 제공자가 아무것에도 서명하지 않았으므로 최근 거래는 비트코인 네트워크에 게시되지 않습니다.
공급업체가 현금화할 준비가 되면 최종 거래에 서명하기만 하면 됩니다. 그는 자기에게 지불해야 할 금액만 받고 나머지는 우리 주소로 반환할 것입니다. 이전 거래는 결코 공개되지 않으며, 만약 공개되었다 하더라도 이중 지출 문제로 인해 무효화됩니다.
당연히 이 과정은 좀 더 복잡할 것입니다. 두 당사자 중 한 쪽이 이점을 취하지 못하도록 몇 가지 조치를 취해야 하기 때문입니다. 예를 들어, 작업을 시작하는 거래에서 공급자가 통화 시간을 지불하는 거래를 결코 보내지 않는다면, 우리는 결코 자금을 돌려받을 수 없고, 이는 예를 들어 강탈로 이어집니다.
그러나 Lightning Network에서도 꽤 유사한 시스템을 사용하는데, 이 경우에는 특정 요구 사항 때문에 이러한 일이 발생하지 않습니다. 예를 들어, 자금이 출금되는 시간 제한을 설정합니다. 그 사이 공급자는 다른 거래를 보내서 대금을 지불받을 수 있습니다.
- 시간 차단
위에서 살펴본 문제에서 우리는 시간 잠금을 사용하는 예를 찾아볼 수 있습니다. 이를 통해 특정 날짜와 시간 또는 블록 수로 측정하여 일정 시간이 지날 때까지 거래가 실행되지 않도록 차단할 수 있습니다.
이는 LOCK_TIME이라는 거래 매개변수를 통해 달성되는데, 이 매개변수는 Lightning Network를 운영하는 데 사용되는 HTLC 계약을 만드는 등 여러 용도로 사용됩니다.
위에서 살펴본 보다 일반적인 예 외에도 Bitcoin Script에는 다른 특정 용도도 있습니다. 다음은 몇 가지 예입니다.
- 사람들이 BTC를 섞어서 제3자가 누가 소유하고 얼마나 보유하고 있는지 추적하기 어렵게 만들기 위해서입니다. 이러한 서비스는 익명성을 높이는 데 도움이 됩니다.
- 지금까지 살펴본 것과 같이 매우 흥미로운 솔루션을 생성하는 데 도움이 될 수 있는, 똑똑하지는 않지만 계약입니다.
결론
비트코인은 비트코인 스크립팅 언어를 기반으로 합니다. 튜링 완전하지 않은 프로그래밍 언어로, 사용하기 매우 쉽고 보안을 강화할 수 있습니다.
이는 거래 출력이 어떻게 사용되는지, 즉 누가 UTXO 자금에 접근할 수 있는지를 결정합니다. 스택과 역표기법에 적용됩니다.
이것이 아마도 초보자가 Bitcoin Script에 대한 전반적인 개념을 알기 위해 알아야 할 모든 내용일 것입니다.