मुख्य सामग्री पर जाएं

वेबसॉकेट का उपयोग करना

Alchemy
वेबसॉकेट्स
क्वेरी करना
JavaScript
शुरआती
एलन हैल्पर्न
1 दिसंबर 2020
7 मिनट का पठन

यह एथेरियम ब्लॉकचेन से अनुरोध करने के लिए वेबसॉकेट और अल्केमी का उपयोग करने के लिए एक एंट्री लेवल गाइड है।

 (opens in a new tab)वेबसॉकेट बनाम HTTP

HTTP के विपरीत, वेबसॉकेट के साथ, जब आप विशिष्ट जानकारी चाहते हैं तो आपको लगातार अनुरोध करने की आवश्यकता नहीं होती है। वेबसॉकेट आपके लिए एक नेटवर्क कनेक्शन बनाए रखते हैं (यदि सही तरीके से किया जाए) और परिवर्तनों को सुनते हैं।

किसी भी नेटवर्क कनेक्शन की तरह, आपको यह नहीं मान लेना चाहिए कि एक वेबसॉकेट बिना किसी रुकावट के हमेशा खुला रहेगा, लेकिन मैन्युअल रूप से ड्रॉप किए गए कनेक्शन और पुन: कनेक्शन को सही ढंग से संभालना चुनौतीपूर्ण हो सकता है। वेबसॉकेट का एक और नुकसान यह है कि आपको प्रतिक्रिया में HTTP स्टेटस कोड नहीं मिलते हैं, बल्कि केवल त्रुटि संदेश मिलता है।

अल्केमी वेब3 (opens in a new tab) बिना किसी कॉन्फ़िगरेशन के WebSocket विफलताओं और पुन: प्रयासों के लिए स्वचालित रूप से हैंडलिंग जोड़ता है।

इसे आज़माएँ

वेबसॉकेट का परीक्षण करने का सबसे आसान तरीका wscat (opens in a new tab) जैसे वेबसॉकेट अनुरोध करने के लिए कमांड लाइन टूल इंस्टॉल करना है। wscat का उपयोग करके, आप इस प्रकार अनुरोध भेज सकते हैं:

नोट: यदि आपके पास अल्केमी खाता है तो आप demo को अपनी API की से बदल सकते हैं। यहां एक मुफ्त अल्केमी खाते के लिए साइन अप करें! (opens in a new tab)_

wscat -c wss://eth-mainnet.ws.alchemyapi.io/ws/demo

>  {"jsonrpc":  "2.0", "id": 0, "method":  "eth_gasPrice"}

<  {"jsonrpc":  "2.0", "result":  "0xb2d05e00", "id": 0}

वेबसॉकेट का उपयोग कैसे करें

शुरू करने के लिए, अपने ऐप के लिए वेबसॉकेट URL का उपयोग करके एक वेबसॉकेट खोलें। आप अपने डैशबोर्ड (opens in a new tab) में ऐप का पेज खोलकर और "की देखें" पर क्लिक करके अपने ऐप का वेबसॉकेट URL पा सकते हैं। ध्यान दें कि वेबसॉकेट के लिए आपके ऐप का URL HTTP अनुरोधों के लिए इसके URL से अलग है, लेकिन दोनों "की देखें" पर क्लिक करके पाए जा सकते हैं।

अपने अल्केमी डैशबोर्ड में अपना वेबसॉकेट URL कहां खोजें

अल्केमी API संदर्भ (opens in a new tab) में सूचीबद्ध किसी भी API का उपयोग वेबसॉकेट के माध्यम से किया जा सकता है। ऐसा करने के लिए, उसी पेलोड का उपयोग करें जिसे HTTP POST अनुरोध के मुख्य भाग के रूप में भेजा जाएगा, लेकिन इसके बजाय उस पेलोड को वेबसॉकेट के माध्यम से भेजें।

वेब3 के साथ

वेब3 जैसी क्लाइंट लाइब्रेरी का उपयोग करते समय वेबसॉकेट में संक्रमण करना सरल है। अपने वेब3 क्लाइंट को इंस्टेंट करते समय बस HTTP वाले के बजाय वेबसॉकेट URL पास करें। उदाहरण के लिए:

const web3 = new Web3("wss://eth-mainnet.ws.alchemyapi.io/ws/your-api-key")

web3.eth.getBlockNumber().then(console.log) // -> 7946893

सब्सक्रिप्शन API

वेबसॉकेट के माध्यम से कनेक्ट होने पर, आप दो अतिरिक्त तरीकों का उपयोग कर सकते हैं: eth_subscribe और eth_unsubscribe। ये तरीके आपको विशेष इवेंट्स को सुनने और तुरंत सूचित होने की अनुमति देंगे।

eth_subscribe

निर्दिष्ट इवेंट्स के लिए एक नई सदस्यता बनाता है। eth_subscribe के बारे में और जानें (opens in a new tab)

पैरामीटर्स

  1. सदस्यता के प्रकार
  2. वैकल्पिक पैरामीटर

पहला तर्क उस इवेंट के प्रकार को निर्दिष्ट करता है जिसे सुनना है। दूसरे तर्क में अतिरिक्त विकल्प होते हैं जो पहले तर्क पर निर्भर करते हैं। विभिन्न विवरण प्रकार, उनके विकल्प, और उनके इवेंट पेलोड नीचे वर्णित हैं।

रिटर्न

सदस्यता आईडी: यह आईडी किसी भी प्राप्त इवेंट से जुड़ी होगी, और इसका उपयोग eth_unsubscribe का उपयोग करके सदस्यता को रद्द करने के लिए भी किया जा सकता है।

सब्सक्रिप्शन इवेंट्स

जब तक सदस्यता सक्रिय है, तब तक आपको इवेंट्स प्राप्त होंगे जो निम्नलिखित फ़ील्ड वाले ऑब्जेक्ट हैं:

  • jsonrpc: हमेशा "2.0"
  • method: हमेशा "eth_subscription"
  • params: निम्नलिखित फ़ील्ड वाला एक ऑब्जेक्ट:
    • subscription: eth_subscribe कॉल द्वारा लौटाई गई सदस्यता आईडी जिसने यह सदस्यता बनाई है।
    • result: एक ऑब्जेक्ट जिसकी सामग्री सदस्यता के प्रकार के आधार पर भिन्न होती है।

सदस्यता के प्रकार

  1. alchemy_newFullPendingTransactions

लंबित स्थिति में जोड़े गए सभी लेन-देनों के लिए लेनदेन की जानकारी लौटाता है। यह सदस्यता प्रकार लंबित लेन-देन की सदस्यता लेता है, जो मानक वेब3 कॉल web3.eth.subscribe("pendingTransactions") के समान है, लेकिन इसमें यह भिन्न है कि यह केवल लेनदेन हैश के बजाय पूर्ण लेनदेन जानकारी उत्सर्जित करता है।

उदाहरण:

  1. newHeads

चेन पुनर्गठन के दौरान सहित, किसी भी समय चेन में एक नया हेडर जोड़े जाने पर एक इवेंट उत्सर्जित करता है।

जब एक चेन पुनर्गठन होता है, तो यह सदस्यता एक इवेंट उत्सर्जित करेगी जिसमें नई चेन के लिए सभी नए हेडर शामिल होंगे। विशेष रूप से, इसका मतलब है कि आप एक ही ऊंचाई के साथ कई हेडर उत्सर्जित देख सकते हैं, और जब ऐसा होता है तो बाद के हेडर को पुनर्गठन के बाद सही माना जाना चाहिए।

उदाहरण:

  1. logs

नए जोड़े गए ब्लॉक के हिस्से के रूप में लॉग उत्सर्जित करता है जो निर्दिष्ट फ़िल्टर मानदंडों से मेल खाते हैं।

जब एक चेन पुनर्गठन होता है, तो पुरानी चेन पर ब्लॉक के हिस्से के रूप में लॉग removed प्रॉपर्टी को true पर सेट करके फिर से उत्सर्जित किए जाएंगे। इसके अलावा, नई चेन पर ब्लॉक के हिस्से के रूप में लॉग उत्सर्जित होते हैं, जिसका अर्थ है कि पुनर्गठन के मामले में एक ही लेनदेन के लिए कई बार लॉग देखना संभव है।

पैरामीटर

  1. निम्नलिखित फ़ील्ड वाला एक ऑब्जेक्ट:
    • address (वैकल्पिक): या तो एक पता दर्शाने वाला स्ट्रिंग या ऐसे स्ट्रिंग्स का एक ऐरे।
      • इनमें से केवल एक पते से बनाए गए लॉग ही उत्सर्जित किए जाएंगे।
    • topics: विषय विनिर्देशक का एक ऐरे।
      • प्रत्येक विषय विनिर्देशक या तो null है, किसी विषय को दर्शाने वाला एक स्ट्रिंग, या स्ट्रिंग्स का एक ऐरे है।
      • ऐरे में प्रत्येक स्थिति जो null नहीं है, उत्सर्जित लॉग को केवल उन लोगों तक सीमित करती है जिनके पास उस स्थिति में दिए गए विषयों में से एक है।

विषय विनिर्देशों के कुछ उदाहरण:

  • []: किसी भी विषय की अनुमति है।
  • [A]: पहली स्थिति में A (और बाद में कुछ भी)।
  • [null, B]: पहली स्थिति में कुछ भी और दूसरी स्थिति में B (और बाद में कुछ भी)।
  • [A, B]: पहली स्थिति में A और दूसरी स्थिति में B (और बाद में कुछ भी)।
  • [[A, B], [A, B]]: पहली स्थिति में (A या B) और दूसरी स्थिति में (A या B) (और बाद में कुछ भी)।

उदाहरण:

eth_unsubscribe

एक मौजूदा सदस्यता को रद्द करता है ताकि आगे कोई इवेंट न भेजे जाएं।

पैरामीटर

  1. सदस्यता आईडी, जैसा कि पहले eth_subscribe कॉल से वापस आया था।

देता

true यदि सदस्यता सफलतापूर्वक रद्द कर दी गई थी, या false यदि दी गई आईडी के साथ कोई सदस्यता मौजूद नहीं थी।

उदाहरण:

अनुरोध

curl https://eth-mainnet.alchemyapi.io/v2/your-api-key
-X POST
-H "Content-Type: application/json"
-d '{"id": 1, "method": "eth_unsubscribe", "params": ["0x9cef478923ff08bf67fde6c64013158d"]}'


परिणाम

{
  "jsonrpc": "2.0",
  "id": 1,
  "result": true
}

मुफ्त में अल्केमी के साथ साइन अप करें (opens in a new tab), हमारे प्रलेखन (opens in a new tab) देखें, और नवीनतम समाचारों के लिए, हमें ट्विटर (opens in a new tab) पर फ़ॉलो करें।

पेज का अंतिम अपडेट: 3 मार्च 2026

क्या यह ट्यूटोरियल उपयोगी था?