비트코인 스크립트: 초보자를 위한 기본 사항

비트코인 스크립트는 비트코인 ​​스크립팅 프로그래밍 언어로 작성되었습니다. 튜링 완전하지 않은 상당히 간단한 언어로, 루프를 포함한 일부 논리적 기능이 부족합니다.

이는 단일 비트코인 ​​스크립트가 많은 컴퓨팅 파워를 소모하여 비트코인 ​​네트워크 노드를 손상시키지 않도록 하기 위해 특별히 수행되었습니다.

이 스크립트는 비트코인을 잠금 및 잠금 해제하는 데만 거의 독점적으로 사용되며, 애플리케이션을 만들거나 프로그램을 실행하는 데 사용할 수 없습니다.

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에서 구현했습니다. 하지만 당시 공개 당시 몇 가지 오류가 있었습니다.

일부 사용자는 비트코인 ​​스크립트가 마지막 순간에 구현된 것으로 보이며 실제 거래에는 충분하지 않다는 의견을 표명했습니다. 다행히도 최신 버전에서는 코드를 다듬는 데 많은 개선 사항이 도입되었습니다.

  1. 스택의 바닥에서

비트코인 스크립트는 스택으로 물리적으로 표현하여 가장 잘 이해되는 데이터 구조를 사용합니다. 새로운 요소가 추가(푸시)되거나 제거(팝)되면, 이는 스택의 마지막 요소에서 수행됩니다.

예를 들어 책 3권이 위에 또 놓여 있다고 가정해 보겠습니다.

  • 책(A) ​​: 상단 부분
  • 책(B) : 보통
  • 책 ©: 바텀

비트코인 스크립트를 사용하면, 먼저 스택에서 책 A를 뽑고, 그 다음에 책 B, 마지막으로 책 C를 뽑습니다.

새로운 책을 추가하고 싶은 경우, 마지막 책, 즉 책 A에서 작업을 수행합니다.

비트코인 스크립트는 거래가 순차적으로 추가되고 역순으로 제거되는 방식으로 작동합니다.

  1. Forth와 유사

스크립트는 Forth 프로그래밍 언어와 매우 유사합니다. 이 작품은 1970년에 처음 등장했으며, 적어도 꽤 잘 알려져 있었습니다.

포스는 오픈 펌웨어 부트 로더, 항공우주 애플리케이션 및 하드웨어와 상호 작용해야 하는 다양한 임베디드 시스템에서 사용됩니다.

  1. 역 표기법

후위 표기법이라고도 불리는 RPN(역 폴란드 표기법)은 명령문의 끝에 함수의 연산을 배치하는 방법입니다.

예를 들어, 1 + 2를 더하고 싶다면, 평소의 “1 + 2” 대신 “1 2 +”라고 쓰면 됩니다.

  1. 불완전한 튜링

불완전한 튜링은 스크립트가 무한 루프를 허용하지 않는다는 것을 의미합니다. 장점과 단점이 있는 것이죠.

이 기능을 사용하면 설계가 형편없는 스크립트를 실행해서 무한 루프에 빠지는 일이 없어집니다. 이는 프로그래밍 오류나 공격으로 인해 발생할 수 있습니다.

더 기술적인 용어로 말하면, 스크립트는 정지 문제라고 알려진 문제를 피합니다.

다른 암호화폐는 튜링 완전성, 또는 적어도 높은 수준의 무결성을 갖춘 프로그래밍 언어를 구현하는 데 성공했습니다. 물론, 여기에는 중단 문제가 따르는데, 그들은 완료해야 할 제안의 수에 비례하는 수수료를 부과함으로써 이 문제를 해결합니다.

튜링 완전한 언어가 아닌 것의 단점은, 예를 들어 스마트 계약을 가능하게 하는 더 복잡한 알고리즘을 개발하는 것이 불가능하다는 것입니다.

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에 대한 전반적인 개념을 알기 위해 알아야 할 모든 내용일 것입니다.

От