/ home / newsletters /
Bitcoin Optech Newsletter #212
इस सप्ताह का समाचार पत्र Bitcoin Core और अन्य नोड्स में डिफ़ॉल्ट न्यूनतम लेनदेन रिले शुल्क को कम करने के बारे में एक चर्चा को सारांशित करता है। Bitcoin Core PR Review Club के सारांश के साथ हमारे नियमित खंड भी शामिल हैं, नई रिलीज और रिलीज उम्मीदवारों की घोषणा, और लोकप्रिय Bitcoin Infrastructure परियोजनाओं में उल्लेखनीय परिवर्तनों का विवरण।
समाचार
-
● डिफ़ॉल्ट न्यूनतम लेनदेन रिले शुल्क को कम करना: Bitcoin Core केवल व्यक्तिगत अपुष्ट लेनदेन को रिले करता है जो कम से कम एक Satoshi प्रति vbyte का शुल्क (1 sat/vbyte) का भुगतान करता है। यदि एक नोड का mempool कम से कम 1 sat/vbyte का भुगतान करने वाले लेनदेन से भर जाता है, तो एक उच्च शुल्क का भुगतान करने की आवश्यकता होगी। कम शुल्क का भुगतान करने वाले लेनदेन को अभी भी खनिकों द्वारा ब्लॉक में शामिल किया जा सकता है और उन ब्लॉकों को रिले किया जाएगा। अन्य नोड सॉफ़्टवेयर समान नीतियों को लागू करते हैं।
डिफ़ॉल्ट न्यूनतम शुल्क को कम करने पर अतीत में चर्चा की गई है (देखें न्यूज़लेटर #3) लेकिन विलय नहीं किया गया है Bitcoin Core में। पिछले कुछ हफ्तों में इस topic को नए सिरे से देखा गया चर्चा:
-
● व्यक्तिगत परिवर्तन प्रभावशीलता: यह बहस कई लोगों द्वारा किया गया था कि व्यक्तिगत नोड ऑपरेटरों के लिए अपनी नीतियों को बदलने के लिए यह कितना प्रभावी था।
-
● पिछली विफलताएं: यह उल्लेखित था कि डिफ़ॉल्ट शुल्क को कम करने के पिछले प्रयास को कम दर से बाधित किया गया था जिससे कई मामूली इनकार-सेवा (DoS) हमलों की लागत भी कम हो गई थी।
-
● वैकल्पिक रिले मानदंड: यह सुझाया गया था कि कुछ डिफ़ॉल्ट मानदंडों (जैसे कि डिफ़ॉल्ट न्यूनतम शुल्क) का उल्लंघन करने वाले लेनदेन इसके बजाय कुछ अलग मानदंडों को पूरा कर सकते हैं जो DoS हमलों को महंगा बनाते हैं — उदाहरण के लिए, यदि एक मामूली लेन-देन के लिए प्रतिबद्ध कार्य का hashcash-शैली प्रमाण की राशि रिले करने के लिए।
इस लेखन के रूप में चर्चा एक स्पष्ट निष्कर्ष पर नहीं पहुंची।
-
Bitcoin Core PR Review Club
इस मासिक खंड में, हम हाल ही में एक Bitcoin Core PR Review Club बैठक का सारांश प्रस्तुत करते हैं, जिसमें कुछ महत्वपूर्ण प्रश्नों और उत्तरों पर प्रकाश डाला गया है। मीटिंग के उत्तर का सारांश देखने के लिए नीचे दिए गए प्रश्न पर क्लिक करें।
Decouple validation cache initialization from ArgsManager Carl Dong की एक PR है जो नोड कॉन्फ़िगरेशन लॉजिक को सिग्नेचर और स्क्रिप्ट कैश के इनिशियलाइज़ेशन से अलग करता है। यह libbitcoinkernel प्रोजेक्ट का हिस्सा है।
-
ArgsManager
क्या करता है? यहsrc/kernel
बनामsrc/node
में क्यों या क्यों नहीं होना चाहिए?ArgsManager कॉन्फ़िगरेशन विकल्पों (
bitcoin.conf
और कमांड लाइन तर्क) को संभालने के लिए एक वैश्विक डेटा संरचना है। जबकि सर्वसम्मति इंजन में पैरामीटर योग्य मान (अर्थात्, कैश के आकार) हो सकते हैं, एक नोड को इस डेटा संरचना की आवश्यकता नहीं होती है आम सहमति में रहने के लिए। बल्कि, Bitcoin Core-विशिष्ट कार्यक्षमता के रूप में, इन कॉन्फ़िगरेशन विकल्पों को संभालने वाला कोडsrc/node
में है। ➚ -
सत्यापन कैश क्या हैं? वे
src/kernel
बनामsrc/node
में क्यों शामिल होंगे?जब एक नया ब्लॉक आता है, तो सत्यापन का सबसे कम्प्यूटेशनल रूप से महंगा हिस्सा इसके लेनदेन के लिए स्क्रिप्ट (अर्थात हस्ताक्षर) सत्यापन है। चूंकि एक mempool रखने वाले नोड्स ने आमतौर पर इन लेनदेन को पहले ही देखा और मान्य किया होगा, कैशिंग द्वारा ब्लॉक सत्यापन प्रदर्शन में काफी वृद्धि हुई है (सफल) स्क्रिप्ट और हस्ताक्षर सत्यापन। ये कैश तार्किक रूप से सर्वसम्मति इंजन का हिस्सा हैं क्योंकि सर्वसम्मति-महत्वपूर्ण ब्लॉक सत्यापन कोड को उनकी आवश्यकता है। जैसे, ये कैश
src/kernel
में हैं। ➚ -
किसी चीज़ के सर्वसम्मति-महत्वपूर्ण होने का क्या अर्थ है यदि वह सर्वसम्मति का नियम नहीं है? क्या `src/consensus’ में सभी सर्वसम्मति-महत्वपूर्ण कोड शामिल हैं?
प्रतिभागियों ने सहमति व्यक्त की कि हस्ताक्षर सत्यापन सर्वसम्मति नियमों को लागू करता है, जबकि कैशिंग नहीं करता है। हालांकि, यदि कैशिंग कोड में एक बग है जिसके परिणामस्वरूप अमान्य हस्ताक्षर संग्रहीत होते हैं, तो नोड अब आम सहमति नियमों को लागू नहीं करेगा। जैसे, हस्ताक्षर कैशिंग है आम सहमति-महत्वपूर्ण माना जाता है। सर्वसम्मति कोड वास्तव में अभी तक
src/kernel
याsrc/consensus
में नहीं रहता है; सर्वसम्मति के अधिकांश नियम और सर्वसम्मति-महत्वपूर्ण कोडvalidation.cpp
में रहते हैं। ➚ -
“कोड पुरातत्व” के लिए आप कौन से टूल का उपयोग करते हैं, इसकी पृष्ठभूमि को समझने के लिए कि कोई मान क्यों मौजूद है?
प्रतिभागियों ने
git blame
,git log
सहित कई कमांड और उपकरण सूचीबद्ध किए, पुल अनुरोध पृष्ठ में प्रतिबद्ध हैश दर्ज करना, फाइल देखते समय GithubBlame
बटन का उपयोग करना, और Github खोज बार का उपयोग करना। ➚ -
यह PR
signatures_cache_bytes
औरscript_execution_cache_bytes
के प्रकार कोint64_t
सेsize_t
में बदल देता है।int64_t
,uint64_t
औरsize_t
में क्या अंतर है, औरsize_t
क्यों होना चाहिए इन मूल्यों को पकड़ो?int64_t
औरuint64_t
प्रकार सभी प्लेटफार्मों और कंपाइलरों में 64-बिट्स (क्रमशः हस्ताक्षरित और अहस्ताक्षरित) हैं।size_t
प्रकार एक अहस्ताक्षरित पूर्णांक है जो लंबाई (बाइट्स में) धारण करने में सक्षम होने की गारंटी है। स्मृति में किसी भी वस्तु का; इसका आकार सिस्टम पर निर्भर करता है। जैसे,size_t
कैश आकार को कई बाइट्स के रूप में रखने वाले इन चरों के लिए बिल्कुल उपयुक्त है। ➚
रिलीज और रिलीज उम्मीदवार
लोकप्रिय Bitcoin इन्फ्रास्ट्रक्चर परियोजनाओं के लिए नए रिलीज और रिलीज उम्मीदवार। कृपया नई रिलीज़ में अपग्रेड करने या रिलीज़ उम्मीदवारों का परीक्षण करने में मदद करने पर विचार करें।
- ● Core Lightning 0.12.0rc1 इस लोकप्रिय LN नोड कार्यान्वयन के अगले प्रमुख संस्करण के लिए एक रिलीज उम्मीदवार है।
उल्लेखनीय कोड और दस्तावेज़ीकरण परिवर्तन
इस सप्ताह Bitcoin Core, Core Lightning, Eclair, LDK, LND में उल्लेखनीय परिवर्तन। libsecp256k1, Hardware Wallet Interface (HWI), Rust Bitcoin, BTCPay Server, BDK, Bitcoin Improvement Proposals (BIP), और Lightning BOLTs।
-
● Bitcoin Core #25610 डिफ़ॉल्ट रूप से RPCs और
-walletrbf
से RBF में ऑप्ट-इन करता है। यह न्यूज़लेटर #208 में उल्लिखित अपडेट का अनुसरण करता है, नोड ऑपरेटरों को अपने नोड के लेनदेन प्रतिस्थापन व्यवहार को डिफ़ॉल्ट ऑप्ट-इन RBF (BIP125) से पूर्ण RBF में बदलने में सक्षम बनाता है। डिफ़ॉल्ट रूप से RPC ऑप्ट-इन 2017 में Bitcoin Core #9527 में प्रस्तावित किया गया था जब प्राथमिक आपत्तियां उस समय नवीनता थीं, लेनदेन को टक्कर देने में असमर्थता और GUI में RBF को अक्षम करने की कार्यक्षमता नहीं थी — जिनमें से सभी तब से संबोधित किया गया है। -
● Bitcoin Core #24584 coin selection में संशोधन करता है ताकि एकल आउटपुट प्रकार से बने इनपुट सेट को प्राथमिकता दी जा सके। यह उन परिदृश्यों को संबोधित करता है जिनमें मिश्रित-प्रकार के इनपुट सेट पिछले लेनदेन के परिवर्तन आउटपुट को प्रकट करते हैं। यह एक संबंधित गोपनीयता सुधार का अनुसरण करता है हमेशा परिवर्तन प्रकार से मेल खाता है एक प्राप्तकर्ता आउटपुट के लिए (देखें Newsletter #181)।
-
● Core Lightning #5071 एक बुककीपर plugin जोड़ता है जो plugin चलाने वाले नोड द्वारा Bitcoin की गतिविधियों का लेखा रिकॉर्ड प्रदान करता है, जिसमें फीस पर खर्च की गई राशि को ट्रैक करने की क्षमता भी शामिल है। मर्ज किए गए PR में कई नए RPC कमांड शामिल हैं।
-
● BDK #645 यह निर्दिष्ट करने का एक तरीका जोड़ता है कि कौन सा [Taproot]topic Taproot हस्ताक्षर करने के लिए पथ खर्च करता है। पहले, यदि BDK सक्षम होता तो कीपथ व्यय के लिए हस्ताक्षर करता, साथ ही किसी भी स्क्रिप्टपथ के लिए हस्ताक्षर करता जिसके लिए उसके पास कुंजी थी।
-
● BOLTs #911 एक LN नोड के लिए एक DNS होस्टनाम की घोषणा करने की क्षमता जोड़ता है जो उसके आईपी पते को हल करता है। इस विचार के बारे में पिछली चर्चा का उल्लेख न्यूज़लेटर #167 में किया गया था।