सॉकेट और उसके तरीके

सॉकेट्स एक द्विदिश संचार चैनल के समापन बिंदु हैं। वे एक प्रक्रिया के भीतर, एक ही मशीन पर प्रक्रियाओं के बीच या विभिन्न मशीनों पर प्रक्रियाओं के बीच संवाद कर सकते हैं। इसी तरह के एक नोट पर, एक नेटवर्क सॉकेट एक संचार प्रवाह में दो कार्यक्रमों के बीच एक इंटरनेट नेटवर्क जैसे कि इंटरनेट नेटवर्क पर चल रहा है। यह विशुद्ध रूप से एक आभासी चीज़ है और इसका मतलब कोई हार्डवेयर नहीं है। नेटवर्क सॉकेट को आईपी पते और पोर्ट नंबर के एक अद्वितीय संयोजन द्वारा पहचाना जा सकता है। नेटवर्क सॉकेट को कई अलग-अलग चैनल प्रकारों जैसे टीसीपी, यूडीपी और इतने पर लागू किया जा सकता है।

नेटवर्क प्रोग्रामिंग में प्रयुक्त सॉकेट से संबंधित विभिन्न शब्द इस प्रकार हैं -

डोमेन

डोमेन प्रोटोकॉल का परिवार है जो परिवहन तंत्र के रूप में उपयोग किया जाता है। ये मान AF_INET, PF_INET, PF_UNIX, PF_X25, और इतने पर जैसे स्थिरांक हैं।

प्रकार

प्रकार का अर्थ है दो अंत बिंदुओं के बीच संचार का प्रकार, आमतौर पर कनेक्शन-उन्मुख प्रोटोकॉल के लिए SOCK_STREAM और कनेक्शन रहित प्रोटोकॉल के लिए SOCK_DGRAM।

मसविदा बनाना

इसका उपयोग किसी डोमेन और प्रकार के प्रोटोकॉल के एक प्रकार की पहचान करने के लिए किया जा सकता है। इसका डिफ़ॉल्ट मान 0. है। इसे आमतौर पर छोड़ दिया जाता है।

होस्ट का नाम

यह नेटवर्क इंटरफ़ेस के पहचानकर्ता के रूप में काम करता है। होस्टनाम नाय एक स्ट्रिंग, डॉटेड-क्वाड एड्रेस या कोलोन (और संभवतः डॉट) नोटेशन में एक आईपीवी 6 एड्रेस हो।

बंदरगाह

प्रत्येक सर्वर एक या अधिक पोर्ट पर कॉल करने वाले क्लाइंट के लिए सुनता है। एक पोर्ट एक Fixnum पोर्ट नंबर, एक स्ट्रिंग जिसमें पोर्ट नंबर या सेवा का नाम हो सकता है।

सॉकेट प्रोग्रामिंग के लिए पायथन का सॉकेट मॉड्यूल

अजगर में सॉकेट प्रोग्रामिंग को लागू करने के लिए, हमें सॉकेट मॉड्यूल का उपयोग करने की आवश्यकता है। सॉकेट बनाने के लिए एक सरल वाक्यविन्यास निम्नलिखित है -

import socket
s = socket.socket (socket_family, socket_type, protocol = 0)

यहां, हमें सॉकेट लाइब्रेरी को आयात करने और फिर एक साधारण सॉकेट बनाने की आवश्यकता है। सॉकेट बनाते समय उपयोग किए जाने वाले विभिन्न पैरामीटर निम्नलिखित हैं -

  • socket_family - यह या तो AF_UNIX या AF_INET है, जैसा कि पहले बताया गया है।

  • socket_type - यह या तो SOCK_STREAM है या SOCK_DGRAM।

  • protocol - इसे आमतौर पर 0 से चूककर छोड़ दिया जाता है।

सॉकेट के तरीके

इस खंड में, हम विभिन्न सॉकेट विधियों के बारे में जानेंगे। सॉकेट विधियों के तीन अलग-अलग सेट नीचे वर्णित हैं -

  • सर्वर सॉकेट विधियाँ
  • ग्राहक सॉकेट तरीके
  • सामान्य सॉकेट विधि

सर्वर सॉकेट विधियाँ

क्लाइंट-सर्वर आर्किटेक्चर में, एक केंद्रीयकृत सर्वर होता है जो सेवा प्रदान करता है और कई ग्राहक उस केंद्रीकृत सर्वर से सेवा प्राप्त करते हैं। क्लाइंट भी सर्वर से रिक्वेस्ट करते हैं। इस आर्किटेक्चर में कुछ महत्वपूर्ण सर्वर सॉकेट विधियाँ निम्नानुसार हैं -

  • socket.bind() - यह विधि एड्रेस (होस्टनाम, पोर्ट नंबर) को सॉकेट से बांधती है।

  • socket.listen()- यह विधि मूल रूप से सॉकेट से बने कनेक्शनों को सुनती है। यह टीसीपी श्रोता शुरू करता है। बैकलॉग इस पद्धति का एक तर्क है जो अधिकतम पंक्तिबद्ध कनेक्शन निर्दिष्ट करता है। इसका न्यूनतम मूल्य 0 है और अधिकतम मूल्य 5 है।

  • socket.accept()- यह टीसीपी क्लाइंट कनेक्शन को स्वीकार करेगा। जोड़ी (कोन, एड्रेस) इस विधि का रिटर्न वैल्यू पेयर है। यहां, कॉन एक नया सॉकेट ऑब्जेक्ट है जिसका उपयोग कनेक्शन पर डेटा भेजने और प्राप्त करने के लिए किया जाता है और पता सॉकेट से जुड़ा हुआ पता है। इस विधि का उपयोग करने से पहले, socket.bind () और socket.listen () विधि का उपयोग किया जाना चाहिए।

ग्राहक सॉकेट तरीके

क्लाइंट-सर्वर आर्किटेक्चर में क्लाइंट सर्वर का अनुरोध करता है और सर्वर से सेवाएं प्राप्त करता है। इसके लिए, ग्राहकों के लिए केवल एक ही तरीका समर्पित है -

  • socket.connect(address)- यह विधि सक्रिय रूप से सर्वर कनेक्शन को अंतरंग करती है या सरल शब्दों में यह विधि क्लाइंट को सर्वर से जोड़ती है। तर्क पता सर्वर के पते को दर्शाता है।

सामान्य सॉकेट विधि

क्लाइंट और सर्वर सॉकेट विधियों के अलावा, कुछ सामान्य सॉकेट विधियां हैं, जो सॉकेट प्रोग्रामिंग में बहुत उपयोगी हैं। सामान्य सॉकेट विधि इस प्रकार हैं -

  • socket.recv(bufsize)- जैसा कि नाम से ही स्पष्ट है, यह विधि सॉकेट से टीसीपी संदेश प्राप्त करती है। तर्क bufsize बफर आकार के लिए खड़ा है और अधिकतम डेटा को परिभाषित करता है जो यह विधि किसी भी समय प्राप्त कर सकती है।

  • socket.send(bytes)- इस विधि का उपयोग सॉकेट में डेटा भेजने के लिए किया जाता है जो रिमोट मशीन से जुड़ा होता है। तर्क बाइट्स सॉकेट को भेजे गए बाइट्स की संख्या देगा।

  • socket.recvfrom(data, address)- यह विधि सॉकेट से डेटा प्राप्त करती है। इस विधि द्वारा दो जोड़ी (डेटा, पता) मान लौटाया जाता है। डेटा प्राप्त डेटा को परिभाषित करता है और पता डेटा भेजने वाले सॉकेट के पते को निर्दिष्ट करता है।

  • socket.sendto(data, address)- जैसा कि नाम से ही स्पष्ट है, इस पद्धति का उपयोग सॉकेट से डेटा भेजने के लिए किया जाता है। इस विधि द्वारा दो जोड़ी (डेटा, पता) मान लौटाया जाता है। डेटा भेजे गए बाइट्स की संख्या को परिभाषित करता है और पता रिमोट मशीन के पते को निर्दिष्ट करता है।

  • socket.close() - यह विधि सॉकेट को बंद कर देगी।

  • socket.gethostname() - यह तरीका होस्ट का नाम वापस कर देगा।

  • socket.sendall(data)- यह विधि सॉकेट को सभी डेटा भेजता है जो एक रिमोट मशीन से जुड़ा होता है। यह त्रुटि रहित होने तक डेटा को लापरवाही से स्थानांतरित करता है और यदि ऐसा होता है, तो यह सॉकेट बंद करने के लिए socket.close () विधि का उपयोग करता है।

सर्वर और क्लाइंट के बीच संबंध स्थापित करने का कार्यक्रम

सर्वर और क्लाइंट के बीच संबंध स्थापित करने के लिए, हमें दो अलग-अलग पायथन प्रोग्राम लिखने होंगे, एक सर्वर के लिए और दूसरा क्लाइंट के लिए।

सर्वर-साइड प्रोग्राम

इस सर्वर साइड सॉकेट प्रोग्राम में, हम इसका उपयोग करेंगे socket.bind()विधि जो इसे एक विशिष्ट आईपी पते और पोर्ट से बांधती है ताकि यह उस आईपी और पोर्ट पर आने वाले अनुरोधों को सुन सके। बाद में, हम उपयोग करते हैंsocket.listen()विधि जो सर्वर को सुन मोड में रखती है। संख्या, 4 कहते हैं, के तर्क के रूप मेंsocket.listen()विधि का अर्थ है कि सर्वर व्यस्त होने पर 4 कनेक्शन प्रतीक्षा कर रहे हैं और यदि 5 वें सॉकेट कनेक्ट करने का प्रयास करता है तो कनेक्शन मना कर दिया जाता है। हम का उपयोग करके ग्राहक को एक संदेश भेज देंगेsocket.send()तरीका। अंत की ओर, हम उपयोग करते हैंsocket.accept() तथा socket.close()क्रमशः कनेक्शन शुरू करने और बंद करने की विधि। निम्नलिखित एक सर्वर साइड प्रोग्राम है -

import socket
def Main():
   host = socket.gethostname()
   port = 12345
   serversocket = socket.socket()
   serversocket.bind((host,port))
   serversocket.listen(1)
   print('socket is listening')
   
   while True:
      conn,addr = serversocket.accept()
      print("Got connection from %s" % str(addr))
      msg = 'Connecting Established'+ "\r\n"
      conn.send(msg.encode('ascii'))
      conn.close()
if __name__ == '__main__':
   Main()

क्लाइंट-साइड प्रोग्राम

क्लाइंट-साइड सॉकेट प्रोग्राम में, हमें सॉकेट ऑब्जेक्ट बनाने की आवश्यकता है। फिर हम उस पोर्ट से कनेक्ट करेंगे जिस पर हमारा सर्वर चल रहा है - हमारे उदाहरण में 12345। उसके बाद हम का उपयोग करके एक कनेक्शन स्थापित करेगाsocket.connect()तरीका। तब का उपयोग करकेsocket.recv()विधि, क्लाइंट को सर्वर से संदेश प्राप्त होगा। आखिर में दsocket.close() विधि ग्राहक को बंद कर देगी।

import socket
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

host = socket.gethostname()
port = 12345

s.connect((host, port))
msg = s.recv(1024)

s.close()
print (msg.decode('ascii'))

अब, सर्वर-साइड प्रोग्राम चलाने के बाद हमें टर्मिनल पर निम्न आउटपुट मिलेंगे -

socket is listening
Got connection from ('192.168.43.75', 49904)

और क्लाइंट-साइड प्रोग्राम चलाने के बाद, हम अन्य टर्मिनल पर निम्न आउटपुट प्राप्त करेंगे -

Connection Established

नेटवर्क सॉकेट अपवादों को हैंडल करना

दो ब्लॉक हैं try तथा exceptजिसका उपयोग नेटवर्क सॉकेट अपवादों को संभालने के लिए किया जा सकता है। अपवाद से निपटने के लिए पायथन लिपि निम्नलिखित है -

import socket
host = "192.168.43.75"
port = 12345
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)

try:
   s.bind((host,port))
   s.settimeout(3)
   data, addr = s.recvfrom(1024)
   print ("recevied from ",addr)
   print ("obtained ", data)
   s.close()
except socket.timeout :
   print ("No connection between client and server")
   s.close()

उत्पादन

उपरोक्त कार्यक्रम निम्नलिखित आउटपुट उत्पन्न करता है -

No connection between client and server

उपरोक्त स्क्रिप्ट में, पहले हमने एक सॉकेट ऑब्जेक्ट बनाया। इसके बाद होस्ट आईपी एड्रेस और पोर्ट नंबर प्रदान किया गया, जिस पर हमारा सर्वर चल रहा है - हमारे उदाहरण में 12345। बाद में, कोशिश ब्लॉक का उपयोग किया जाता है और इसके अंदर का उपयोग करकेsocket.bind()विधि, हम आईपी पते और पोर्ट को बांधने की कोशिश करेंगे। हम प्रयोग कर रहे हैंsocket.settimeout()ग्राहक के लिए प्रतीक्षा समय निर्धारित करने की विधि, हमारे उदाहरण में हम 3 सेकंड सेट कर रहे हैं। अपवाद ब्लॉक का उपयोग किया जाता है जो सर्वर और क्लाइंट के बीच कनेक्शन स्थापित नहीं होने पर एक संदेश प्रिंट करेगा।