Gas optimization in Solidity, Ethereum
I’m sorry but my English is terrible. I hope you understand that generously.Recently, I was developing a toy project named Blind Market. It’s a simple P2P trading application using smart contract. I was making a contract using Solidity, and the trade stage proceeded in the order of pending, shipping, and done. The problem was appeared in done phase. The problem was that when I tried to close the transaction by paying the price raised by the seller in msg.value, the following error occurred.Pe...
Uvicorn & Gunicorn
Uvicorn and GunicornUvicorn and Gunicorn are important concepts when developing applications in Python. However, there are many concepts to be aware of in order to fully understand Uvicorn and Gunicorn. The following is a brief summary of the necessary concepts, and the details will be dealt with separately later.Necessary ConceptsStarletteStarlette is a Web application server that can run asynchronously. Starlette runs on top of Uvicorn.FastAPIFastAPI provides many features on top of Starlet...
P2WPKH
P2WPKHP2WPKH란 비트코인 내에서 가장 일반적인 스크립트 형식으로 비트코인 프로토콜에 대한 지불 거래 유형이다. 주소는 1로 시작하는데, 세그윗을 지원하는 새로운 주소 3 또는 bc1로 시작하는 주소보다 훨씬 비싸다. https://mirror.xyz/0xA1d9f681B25C14C1eE7B87f1CF102E73cA3ad4d9/egjhNVklgy_LgZmcTXXAOTBa6ePBqO3Ja9ZSoDIad-8 즉, 비트코인 주소가 1로 시작하면 P2PKH 주소를 사용하고 있는 것이다. 공개키의 간단한 해시이며, 이 해시를 주소로 사용하는 것이다. 이것은 원래 비트코인 주소 형식이었으며 오늘까지도 충실히 작동한다. 레거시 주소는 세그윗과 호환되지 않지만, 여전히 문제없이 P2PKH 주소에서 세그윗 주소로 BTC를 보낼 수 있다. 그러나 레거시 주소 트랜잭션이 더 크기 때문에 P2PKH 주소에서 전송하는 평균 속도는 세그윗 주소에서 전송할 때보다 더 높은 요금이 발생할 수 있다....
Smart Contract Developer, Web3 Backend Developer
Gas optimization in Solidity, Ethereum
I’m sorry but my English is terrible. I hope you understand that generously.Recently, I was developing a toy project named Blind Market. It’s a simple P2P trading application using smart contract. I was making a contract using Solidity, and the trade stage proceeded in the order of pending, shipping, and done. The problem was appeared in done phase. The problem was that when I tried to close the transaction by paying the price raised by the seller in msg.value, the following error occurred.Pe...
Uvicorn & Gunicorn
Uvicorn and GunicornUvicorn and Gunicorn are important concepts when developing applications in Python. However, there are many concepts to be aware of in order to fully understand Uvicorn and Gunicorn. The following is a brief summary of the necessary concepts, and the details will be dealt with separately later.Necessary ConceptsStarletteStarlette is a Web application server that can run asynchronously. Starlette runs on top of Uvicorn.FastAPIFastAPI provides many features on top of Starlet...
P2WPKH
P2WPKHP2WPKH란 비트코인 내에서 가장 일반적인 스크립트 형식으로 비트코인 프로토콜에 대한 지불 거래 유형이다. 주소는 1로 시작하는데, 세그윗을 지원하는 새로운 주소 3 또는 bc1로 시작하는 주소보다 훨씬 비싸다. https://mirror.xyz/0xA1d9f681B25C14C1eE7B87f1CF102E73cA3ad4d9/egjhNVklgy_LgZmcTXXAOTBa6ePBqO3Ja9ZSoDIad-8 즉, 비트코인 주소가 1로 시작하면 P2PKH 주소를 사용하고 있는 것이다. 공개키의 간단한 해시이며, 이 해시를 주소로 사용하는 것이다. 이것은 원래 비트코인 주소 형식이었으며 오늘까지도 충실히 작동한다. 레거시 주소는 세그윗과 호환되지 않지만, 여전히 문제없이 P2PKH 주소에서 세그윗 주소로 BTC를 보낼 수 있다. 그러나 레거시 주소 트랜잭션이 더 크기 때문에 P2PKH 주소에서 전송하는 평균 속도는 세그윗 주소에서 전송할 때보다 더 높은 요금이 발생할 수 있다....
Share Dialog
Share Dialog
Smart Contract Developer, Web3 Backend Developer

Subscribe to Primrose

Subscribe to Primrose
<100 subscribers
<100 subscribers
P2WPKH는 SegWit 주소 유형으로, 비트코인 트랜잭션의 효율성과 확장성을 개선하기 위해 2017년에 도입된 최신 트랜잭션 형식을 사용한다.
반면에 P2SH는 SegWit 이전의 오래된 주소 유형이다.
P2WPKH 트랜잭션은 SegWit 트랜잭션이기 때문에 일반적으로 P2SH 트랜잭션보다 크기가 작아 트랜잭션 수수료가 낮을 수 있다.
그러나 P2WPKH 주소는 SegWit 지원 지갑 및 노드와만 호환되는 반면, P2SH 주소는 SegWit 및 비 SegWit 지갑 및 노드 모두에서 사용할 수 있다.
P2WPKH 주소는 공개 키의 해시를 주소의 기초로 사용하는 반면 P2SH 주소는 주소의 기초로 사용 스크립트(비트코인 사용 조건을 정의하는 스크립트)의 해시를 사용한다.
요약하면 다음과 같다.
P2WPKH는 Segwit 주소 유형. P2SH는 아님
P2WPKH는 트랜잭션 크기가 작아서(P2SH에 비해서) 수수료 낮음.
P2WPKH는 Segwit과만 호환됨. P2SH는 Segwit이건 아니건 호환됨.
P2WPKH는 공개키의 해시를 주소의 기초로 사용, P2SH는 스크립트의 해시를 사용.
전반적으로 P2WPKH는 보다 현대적이고 효율적인 주소 유형으로 간주되는 반면, P2SH는 더 광범위하게 호환되며 여전히 많은 비트코인 트랜잭션에 사용된다.
그렇다면, P2SH 주소를 사용하면서 트랜잭션 사인과 전송에는 P2WPKH를 사용할 수는 없을까?
물론 가능하다. P2SH 주소를 중개자로 사용하면서, Bitcoin을 P2WPKH 주소로 보낼 수 있다.
이것을 일반적으로 P2SH-P2WPKH 트랜잭션이라고 한다.
P2SH-P2WPKH 트랜잭션을 생성하려면 P2WPKH output script를 포함하는 상환 스크립트와 연결된 P2SH 주소를 사용한다.
트랜잭션이 네트워크에 브로드캐스팅되면 노드와 채굴자는 P2SH 주소와 P2WPKH output script를 포함하는 redeem script를 보게 된다.
Redeem script는 트랜잭션이 스크립트에 정의된 지출 조건을 충족하는지 확인하는 데 사용된다.
P2SH-P2WPKH 거래의 경우 redeem script에는 P2WPKH output script가 포함되어 있으며 P2WPKH 주소의 공개 키 해시와 연결된 개인 키의 유효한 서명이 필요하다.
요약하면 P2SH-P2WPKH 트랜잭션을 사용하면 이전 P2SH 주소 형식을 사용하면서 비트코인을 P2WPKH 주소로 보낼 수 있다.
이는 최신 P2WPKH 주소 형식을 지원하지 않는 지갑이나 노드와 상호 작용해야 하는 상황에서 유용할 수 있다.
Redeem은 트랜잭션이 output script에 정의된 지출 조건을 충족하는지 확인하는데 사용되는 스크립트이다.
P2SH 트랜잭션에 사용되며, 잠금 해제 스크립트의 일부로 트랜잭션에 포함된다.
정리하면, Redeem 스크립트는 비트코인을 사용하기 위해 충족해야 하는 조건을 지정한다.
여기에는 특정 수의 서명 요구, 트랜잭션 생성 이후 시간 확인 또는 특정 스크립트 실행 요구 등이 포함될 수 있다.
스크립트는 원하는 지출 조건을 적용하는데 필요한 만큼 간단하거나 복잡할 수 있다.
Output script는 출력 스크립트라고 보통 부르는데, scriptPubKey라고도 한다.
출력 스크립트 또한 비트코인을 사용하기 위해 충족해야 하는 조건을 정의한다.
주로 트랜잭션 출력에 포함되며, 비트코인이 전송되는 비트코인 주소를 지정한다.
알아야 할 것은 출력 스크립트에는 비트코인을 할당하기 위해 실행해야 하는 스크립트가 포함되어 있다는 것이다.
예를 들어, P2PKH(Pay-to-Public-Key-Hash) 트랜잭션에서 출력 스크립트는 수신자의 공개 키의 해시를 포함하며, 지출 조건은 해당 개인 키의 서명을 제공하는 것이다.
반면에 P2WPKH(Pay-to-Witness-Public-Key-Hash) 트랜잭션에서 출력 스크립트는 수신자의 공개 키의 해시를 포함하지만, 지출 조건은 트랜잭션의 증인 데이터 필드에 유효한 증인 데이터(서명 및 공개 키)를 제공하는 것이다.
P2PKH와 P2WPKH 둘 다 출력스크립트에서 수신자의 공개 키 해시를 사용.
그러나 지출 조건이 다름. (개인 키의 서명 vs 증인 데이터)
결국 비트코인 트랜잭션에서 redeem과 output 스크립트는 둘 다 전송되는 비트코인의 지출 조건을 정의하는데 사용된다.
P2SH-P2WPKH 트랜잭션에서 살펴보자.
Redeem 스크립트는 P2WPKH output 스크립트를 조건으로 포함하며, output 스크립트는 redeem 스크립트에 해당하는 P2SH 주소를 지정한다.
트랜잭션이 네트워크로 브로드캐스트되면 노드와 Miner는 P2SH 주소와 P2WPKH 출력 스크립트를 포함하는 redeem 스크립트를 볼 수 있다.
redeem 스크립트는 트랜잭션이 스크립트에 의해 정의된 지출 조건을 충족하는지 확인하는 데 사용되며, output 스크립트는 비트코인이 전송되는 비트코인 주소를 지정한다.
P2WPKH는 SegWit 주소 유형으로, 비트코인 트랜잭션의 효율성과 확장성을 개선하기 위해 2017년에 도입된 최신 트랜잭션 형식을 사용한다.
반면에 P2SH는 SegWit 이전의 오래된 주소 유형이다.
P2WPKH 트랜잭션은 SegWit 트랜잭션이기 때문에 일반적으로 P2SH 트랜잭션보다 크기가 작아 트랜잭션 수수료가 낮을 수 있다.
그러나 P2WPKH 주소는 SegWit 지원 지갑 및 노드와만 호환되는 반면, P2SH 주소는 SegWit 및 비 SegWit 지갑 및 노드 모두에서 사용할 수 있다.
P2WPKH 주소는 공개 키의 해시를 주소의 기초로 사용하는 반면 P2SH 주소는 주소의 기초로 사용 스크립트(비트코인 사용 조건을 정의하는 스크립트)의 해시를 사용한다.
요약하면 다음과 같다.
P2WPKH는 Segwit 주소 유형. P2SH는 아님
P2WPKH는 트랜잭션 크기가 작아서(P2SH에 비해서) 수수료 낮음.
P2WPKH는 Segwit과만 호환됨. P2SH는 Segwit이건 아니건 호환됨.
P2WPKH는 공개키의 해시를 주소의 기초로 사용, P2SH는 스크립트의 해시를 사용.
전반적으로 P2WPKH는 보다 현대적이고 효율적인 주소 유형으로 간주되는 반면, P2SH는 더 광범위하게 호환되며 여전히 많은 비트코인 트랜잭션에 사용된다.
그렇다면, P2SH 주소를 사용하면서 트랜잭션 사인과 전송에는 P2WPKH를 사용할 수는 없을까?
물론 가능하다. P2SH 주소를 중개자로 사용하면서, Bitcoin을 P2WPKH 주소로 보낼 수 있다.
이것을 일반적으로 P2SH-P2WPKH 트랜잭션이라고 한다.
P2SH-P2WPKH 트랜잭션을 생성하려면 P2WPKH output script를 포함하는 상환 스크립트와 연결된 P2SH 주소를 사용한다.
트랜잭션이 네트워크에 브로드캐스팅되면 노드와 채굴자는 P2SH 주소와 P2WPKH output script를 포함하는 redeem script를 보게 된다.
Redeem script는 트랜잭션이 스크립트에 정의된 지출 조건을 충족하는지 확인하는 데 사용된다.
P2SH-P2WPKH 거래의 경우 redeem script에는 P2WPKH output script가 포함되어 있으며 P2WPKH 주소의 공개 키 해시와 연결된 개인 키의 유효한 서명이 필요하다.
요약하면 P2SH-P2WPKH 트랜잭션을 사용하면 이전 P2SH 주소 형식을 사용하면서 비트코인을 P2WPKH 주소로 보낼 수 있다.
이는 최신 P2WPKH 주소 형식을 지원하지 않는 지갑이나 노드와 상호 작용해야 하는 상황에서 유용할 수 있다.
Redeem은 트랜잭션이 output script에 정의된 지출 조건을 충족하는지 확인하는데 사용되는 스크립트이다.
P2SH 트랜잭션에 사용되며, 잠금 해제 스크립트의 일부로 트랜잭션에 포함된다.
정리하면, Redeem 스크립트는 비트코인을 사용하기 위해 충족해야 하는 조건을 지정한다.
여기에는 특정 수의 서명 요구, 트랜잭션 생성 이후 시간 확인 또는 특정 스크립트 실행 요구 등이 포함될 수 있다.
스크립트는 원하는 지출 조건을 적용하는데 필요한 만큼 간단하거나 복잡할 수 있다.
Output script는 출력 스크립트라고 보통 부르는데, scriptPubKey라고도 한다.
출력 스크립트 또한 비트코인을 사용하기 위해 충족해야 하는 조건을 정의한다.
주로 트랜잭션 출력에 포함되며, 비트코인이 전송되는 비트코인 주소를 지정한다.
알아야 할 것은 출력 스크립트에는 비트코인을 할당하기 위해 실행해야 하는 스크립트가 포함되어 있다는 것이다.
예를 들어, P2PKH(Pay-to-Public-Key-Hash) 트랜잭션에서 출력 스크립트는 수신자의 공개 키의 해시를 포함하며, 지출 조건은 해당 개인 키의 서명을 제공하는 것이다.
반면에 P2WPKH(Pay-to-Witness-Public-Key-Hash) 트랜잭션에서 출력 스크립트는 수신자의 공개 키의 해시를 포함하지만, 지출 조건은 트랜잭션의 증인 데이터 필드에 유효한 증인 데이터(서명 및 공개 키)를 제공하는 것이다.
P2PKH와 P2WPKH 둘 다 출력스크립트에서 수신자의 공개 키 해시를 사용.
그러나 지출 조건이 다름. (개인 키의 서명 vs 증인 데이터)
결국 비트코인 트랜잭션에서 redeem과 output 스크립트는 둘 다 전송되는 비트코인의 지출 조건을 정의하는데 사용된다.
P2SH-P2WPKH 트랜잭션에서 살펴보자.
Redeem 스크립트는 P2WPKH output 스크립트를 조건으로 포함하며, output 스크립트는 redeem 스크립트에 해당하는 P2SH 주소를 지정한다.
트랜잭션이 네트워크로 브로드캐스트되면 노드와 Miner는 P2SH 주소와 P2WPKH 출력 스크립트를 포함하는 redeem 스크립트를 볼 수 있다.
redeem 스크립트는 트랜잭션이 스크립트에 의해 정의된 지출 조건을 충족하는지 확인하는 데 사용되며, output 스크립트는 비트코인이 전송되는 비트코인 주소를 지정한다.
No activity yet