ప్రధాన కంటెంట్‌కు దాటవేయి

వెబ్ సాకెట్‌లను ఉపయోగించడం

alchemy
వెబ్‌సాకెట్‌లు
ప్రశ్నించడం
జావాస్క్రిప్ట్
ప్రారంభ
Elan Halpern
1 డిసెంబర్, 2020
5 నిమిషం పఠనం

ఇది ఇతీరియము బ్లాక్ చైనుకు అభ్యర్థనలు చేయడానికి వెబ్‌సాకెట్‌లు మరియు Alchemyను ఉపయోగించడానికి ఒక ఎంట్రీ లెవల్ గైడ్.

 (opens in a new tab)వెబ్ సాకెట్‌లు వర్సెస్ HTTP

HTTP వలె కాకుండా, వెబ్‌సాకెట్‌లతో, మీకు నిర్దిష్ట సమాచారం కావాలనుకున్నప్పుడు మీరు నిరంతరం అభ్యర్థనలు చేయనవసరం లేదు. వెబ్ సాకెట్‌లు మీ కోసం నెట్‌వర్క్ కనెక్షన్‌ను (సరిగ్గా చేస్తే) నిర్వహిస్తాయి మరియు మార్పుల కోసం వేచి ఉంటాయి.

ఏదైనా నెట్‌వర్క్ కనెక్షన్‌తో వలె, ఒక వెబ్‌సాకెట్ అంతరాయం లేకుండా ఎప్పటికీ తెరిచి ఉంటుందని మీరు భావించకూడదు, కానీ డ్రాప్ చేయబడిన కనెక్షన్‌లను మరియు పునఃకనెక్షన్‌ను సరిగ్గా చేతితో నిర్వహించడం సరిగ్గా పొందడం సవాలుగా ఉంటుంది. వెబ్‌సాకెట్‌ల యొక్క మరో ప్రతికూలత ఏమిటంటే, మీరు ప్రతిస్పందనలో HTTP స్థితి కోడ్‌లను పొందరు, కానీ కేవలం దోష సందేశాన్ని మాత్రమే పొందుతారు.

Alchemy Web3 (opens in a new tab) ఎటువంటి కాన్ఫిగరేషన్ అవసరం లేకుండా వెబ్‌సాకెట్ వైఫల్యాలు మరియు పునఃప్రయత్నాల కోసం హ్యాండ్లింగ్‌ను స్వయంచాలకంగా జోడిస్తుంది.

దీన్ని ప్రయత్నించండి

వెబ్‌సాకెట్‌లను పరీక్షించడానికి సులభమైన మార్గం wscat (opens in a new tab) వంటి వెబ్‌సాకెట్ అభ్యర్థనలు చేయడానికి కమాండ్ లైన్ సాధనాన్ని ఇన్‌స్టాల్ చేయడం. wscat ఉపయోగించి, మీరు ఈ క్రింది విధంగా అభ్యర్థనలను పంపవచ్చు:

గమనిక: మీకు Alchemy ఖాతా ఉంటే మీరు demo ను మీ స్వంత API కీతో భర్తీ చేయవచ్చు. ఇక్కడ ఉచిత Alchemy ఖాతా కోసం సైన్ అప్ చేయండి! (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 కంటే భిన్నంగా ఉంటుందని గమనించండి, కానీ రెండింటినీ "కీని వీక్షించు" పై క్లిక్ చేయడం ద్వారా కనుగొనవచ్చు.

మీ Alchemy డ్యాష్‌బోర్డ్‌లో మీ వెబ్‌సాకెట్ URLను ఎక్కడ కనుగొనాలి

Alchemy API Reference (opens in a new tab)లో జాబితా చేయబడిన ఏవైనా APIలను వెబ్‌సాకెట్ ద్వారా ఉపయోగించవచ్చు. అలా చేయడానికి, HTTP POST అభ్యర్థన యొక్క బాడీగా పంపబడే అదే పేలోడ్‌ను ఉపయోగించండి, కానీ బదులుగా ఆ పేలోడ్‌ను వెబ్‌సాకెట్ ద్వారా పంపండి.

Web3తో

Web3 వంటి క్లయింట్ లైబ్రరీని ఉపయోగిస్తున్నప్పుడు వెబ్‌సాకెట్‌లకు మారడం చాలా సులభం. మీ Web3 క్లయింట్‌ను ప్రారంభించేటప్పుడు HTTP URLకు బదులుగా వెబ్‌సాకెట్ 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. ఐచ్ఛిక పారామీటర్లు

మొదటి వాదన వినవలసిన ఈవెంట్ రకాన్ని నిర్దేశిస్తుంది. రెండవ వాదనలో మొదటి వాదనపై ఆధారపడి ఉండే అదనపు ఎంపికలు ఉంటాయి. వివిధ వివరణ రకాలు, వాటి ఎంపికలు, మరియు వాటి ఈవెంట్ పేలోడ్‌లు క్రింద వివరించబడ్డాయి.

తిరిగి వస్తుంది

చందా ID: ఈ ID అందుకున్న ఏవైనా ఈవెంట్‌లకు జోడించబడుతుంది, మరియు eth_unsubscribe ఉపయోగించి చందాను రద్దు చేయడానికి కూడా ఉపయోగించవచ్చు.

చందా ఈవెంట్‌లు

చందా యాక్టివ్‌గా ఉన్నప్పుడు, మీరు ఈ క్రింది ఫీల్డ్‌లతో వస్తువులైన ఈవెంట్‌లను అందుకుంటారు:

  • jsonrpc: ఎల్లప్పుడూ "2.0"
  • విధానం: ఎల్లప్పుడూ "eth_subscription"
  • పారామీటర్లు: కింది ఫీల్డ్‌లతో కూడిన ఒక వస్తువు:
    • subscription: ఈ చందాను సృష్టించిన eth_subscribe కాల్ ద్వారా తిరిగి ఇవ్వబడిన చందా ID.
    • ఫలితం: చందా రకంపై ఆధారపడి కంటెంట్‌లు మారే ఒక వస్తువు.

చందా రకాలు

  1. alchemy_newFullPendingTransactions

పెండింగ్ స్థితికి జోడించబడిన అన్ని లావాదేవీల కోసం లావాదేవీ సమాచారాన్ని తిరిగి ఇస్తుంది. ఈ చందా రకం పెండింగ్‌లో ఉన్న లావాదేవీలకు చందా చేస్తుంది, ఇది ప్రామాణిక Web3 కాల్ web3.eth.subscribe("pendingTransactions") ను పోలి ఉంటుంది, కానీ ఇది లావాదేవీ హాష్‌లకు బదులుగా పూర్తి లావాదేవీ సమాచారాన్ని విడుదల చేస్తుంది.

ఉదాహరణ:

  1. newHeads

చైన్ పునర్వ్యవస్థీకరణ సమయంలో సహా, చైన్‌కు కొత్త హెడర్ జోడించబడిన ఏ సమయంలోనైనా ఒక ఈవెంట్‌ను విడుదల చేస్తుంది.

ఒక చైన్ పునర్వ్యవస్థీకరణ జరిగినప్పుడు, ఈ చందా కొత్త చైన్ కోసం అన్ని కొత్త హెడర్‌లను కలిగి ఉన్న ఒక ఈవెంట్‌ను విడుదల చేస్తుంది. ప్రత్యేకించి, దీని అర్థం మీరు ఒకే ఎత్తుతో బహుళ హెడర్‌లను విడుదల చేయడాన్ని చూడవచ్చు, మరియు ఇది జరిగినప్పుడు పునర్వ్యవస్థీకరణ తర్వాత తర్వాత వచ్చే హెడర్‌ను సరైనదిగా తీసుకోవాలి.

ఉదాహరణ:

  1. logs

పేర్కొన్న ఫిల్టర్ ప్రమాణాలకు సరిపోయే కొత్తగా జోడించిన బ్లాక్‌లలో భాగమైన లాగ్‌లను విడుదల చేస్తుంది.

ఒక చైన్ పునర్వ్యవస్థీకరణ జరిగినప్పుడు, పాత చైన్‌లోని బ్లాక్‌లలో భాగమైన లాగ్‌లు removed ప్రాపర్టీని true కి సెట్ చేసి మళ్లీ విడుదల చేయబడతాయి. ఇంకా, కొత్త చైన్‌లోని బ్లాక్‌లలో భాగమైన లాగ్‌లు విడుదల చేయబడతాయి, దీని అర్థం పునర్వ్యవస్థీకరణ సందర్భంలో ఒకే లావాదేవీ కోసం లాగ్‌లను బహుళ సార్లు చూడటం సాధ్యమవుతుంది.

పరామితులు

  1. ఈ క్రింది ఫీల్డ్‌లతో ఒక వస్తువు:
    • చిరునామా (ఐచ్ఛికం): ఒక చిరునామాను సూచించే స్ట్రింగ్ లేదా అటువంటి స్ట్రింగ్‌ల శ్రేణి.
      • ఈ చిరునామాలలో ఒకదాని నుండి సృష్టించబడిన లాగ్‌లు మాత్రమే విడుదల చేయబడతాయి.
    • topics: టాపిక్ స్పెసిఫైయర్‌ల శ్రేణి.
      • ప్రతి టాపిక్ స్పెసిఫైయర్ null, ఒక టాపిక్‌ను సూచించే స్ట్రింగ్ లేదా స్ట్రింగ్‌ల శ్రేణి.
      • శ్రేణిలో null కాని ప్రతి స్థానం విడుదల చేయబడిన లాగ్‌లను ఆ స్థానంలో ఇచ్చిన టాపిక్‌లలో ఒకటి ఉన్న వాటికి మాత్రమే పరిమితం చేస్తుంది.

టాపిక్ నిర్దేశాలకు కొన్ని ఉదాహరణలు:

  • []: ఏ టాపిక్‌లైనా అనుమతించబడతాయి.
  • [A]: మొదటి స్థానంలో A (మరియు తర్వాత ఏదైనా).
  • [null, B]: మొదటి స్థానంలో ఏదైనా మరియు రెండవ స్థానంలో B (మరియు తర్వాత ఏదైనా).
  • [A, B]: మొదటి స్థానంలో A మరియు రెండవ స్థానంలో B (మరియు తర్వాత ఏదైనా).
  • [[A, B], [A, B]]: మొదటి స్థానంలో (A లేదా B) మరియు రెండవ స్థానంలో (A లేదా B) (మరియు తర్వాత ఏదైనా).

ఉదాహరణ:

eth_unsubscribe

ఇప్పటికే ఉన్న చందాను రద్దు చేస్తుంది, తద్వారా తదుపరి ఈవెంట్‌లు పంపబడవు.

పరామితులు

  1. చందా ID, ఇది గతంలో eth_subscribe కాల్ నుండి తిరిగి ఇవ్వబడింది.

తిరిగి ఇస్తుంది

ఒక చందా విజయవంతంగా రద్దు చేయబడితే true అని లేదా ఇచ్చిన IDతో ఏ చందా లేకపోతే 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
}

Alchemy (opens in a new tab)తో ఉచితంగా సైన్ అప్ చేయండి, మా డాక్యుమెంటేషన్‌ను (opens in a new tab) తనిఖీ చేయండి, మరియు తాజా వార్తల కోసం, మమ్మల్ని Twitter (opens in a new tab)లో అనుసరించండి.

పేజీ చివరి నవీకరణ: 3 మార్చి, 2026

ఈ ట్యుటోరియల్ ఉపయోగకరంగా ఉందా?