बिल्ट-इन Http सर्वर और आंतरिक इंजन

चेरीपी अपने स्वयं के वेब (HTTP) सर्वर के साथ आता है। यही कारण है कि चेरीपाइ स्व-निहित है और उपयोगकर्ताओं को पुस्तकालय प्राप्त करने के कुछ मिनटों के भीतर चेरीरी आवेदन को चलाने की अनुमति देता है।

web server आवेदन के लिए प्रवेश द्वार के रूप में कार्य करता है जिसकी सहायता से सभी अनुरोधों और प्रतिक्रियाओं को ट्रैक में रखा जाता है।

वेब सर्वर शुरू करने के लिए, एक उपयोगकर्ता को निम्नलिखित कॉल करना होगा -

cherryPy.server.quickstart()

internal engine of CherryPy निम्नलिखित गतिविधियों के लिए जिम्मेदार है -

  • निर्माण और अनुरोध और प्रतिक्रिया वस्तुओं का प्रबंधन।
  • चेरीपसी प्रक्रिया को नियंत्रित और प्रबंधित करना।

चेरीपी - विन्यास

फ्रेमवर्क अपने स्वयं के कॉन्फ़िगरेशन सिस्टम के साथ आता है जो आपको HTTP सर्वर को पैरामीटर करने की अनुमति देता है। कॉन्फ़िगरेशन के लिए सेटिंग्स को या तो पाठ फ़ाइल में सिंटैक्स के साथ INI प्रारूप के करीब या पूर्ण पायथन डिक्शनरी के रूप में संग्रहीत किया जा सकता है।

CherryPy सर्वर आवृत्ति को कॉन्फ़िगर करने के लिए, डेवलपर को सेटिंग्स के वैश्विक अनुभाग का उपयोग करने की आवश्यकता है।

global_conf = {
   'global': {
      'server.socket_host': 'localhost',
      'server.socket_port': 8080,
   },
}

application_conf = {
   '/style.css': {
      'tools.staticfile.on': True,
      'tools.staticfile.filename': os.path.join(_curdir, 'style.css'),
   }
}

This could be represented in a file like this:
[global]
server.socket_host = "localhost"
server.socket_port = 8080
[/style.css]
tools.staticfile.on = True
tools.staticfile.filename = "/full/path/to.style.css"

HTTP अनुपालन

चेरीपी धीरे-धीरे विकसित हो रही है, लेकिन इसमें HTTP / 1.0 के समर्थन के साथ HTTP विनिर्देशों का संकलन / बाद में HTTP / 1.1 के समर्थन से स्थानांतरित करना शामिल है।

चेरीपी को HTTP / 1.1 के साथ सशर्त रूप से अनुपालन करने के लिए कहा जाता है क्योंकि यह सभी आवश्यक और आवश्यक स्तरों को लागू करता है लेकिन विनिर्देश के सभी स्तरों को नहीं होना चाहिए। इसलिए, चेरीपी HTTP / 1.1 की निम्नलिखित विशेषताओं का समर्थन करती है -

  • यदि कोई क्लाइंट HTTP / 1.1 का समर्थन करने का दावा करता है, तो उसे निर्दिष्ट प्रोटोकॉल संस्करण के साथ किए गए किसी भी अनुरोध में एक हेडर फ़ील्ड भेजना होगा। यदि ऐसा नहीं किया जाता है, तो चेरीपी तुरंत अनुरोध के प्रसंस्करण को रोक देगा।

  • CherryPy एक दिनांक हेडर फ़ील्ड बनाता है जो सभी कॉन्फ़िगरेशन में उपयोग किया जाता है।

  • चेरीपी ग्राहकों की सहायता से प्रतिक्रिया स्थिति कोड (100) को संभाल सकता है।

  • CherryPy का अंतर्निहित HTTP सर्वर लगातार कनेक्शन का समर्थन करता है जो HTTP / 1.1 में डिफ़ॉल्ट हैं, कनेक्शन के उपयोग के माध्यम से: Keep-Alive हैडर।

  • CherryPy अनुरोधों और प्रतिक्रियाओं को सही ढंग से चुनता है।

  • चेरीपाइ दो अलग-अलग तरीकों से अनुरोधों का समर्थन करती है - अगर-संशोधित-कब से और अगर-अनमॉडिफाइड-चूंकि हेडर है और तदनुसार अनुरोधों के अनुसार प्रतिक्रिया भेजता है।

  • CherryPy किसी भी HTTP विधि की अनुमति देता है।

  • CherryPy क्लाइंट और सर्वर के लिए सेट की गई सेटिंग के बीच HTTP संस्करणों के संयोजन को संभालता है।

Multithreaded अनुप्रयोग सर्वर

चेरीपीथ को मल्टीथ्रेडिंग अवधारणा पर आधारित बनाया गया है। जब भी कोई डेवलपर CherryPy नामस्थान में मान प्राप्त करता है या सेट करता है, तो यह बहु-थ्रेडेड वातावरण में किया जाता है।

दोनों cherrypy.request और cherrypy.response थ्रेड-डेटा कंटेनर हैं, जिसका अर्थ है कि आपका एप्लिकेशन स्वतंत्र रूप से यह जानकर कॉल करता है कि रनटाइम में उनके माध्यम से अनुरोध किया गया है।

थ्रेडेड पैटर्न का उपयोग करने वाले एप्लिकेशन सर्वर को अत्यधिक माना नहीं जाता है क्योंकि थ्रेड्स का उपयोग सिंक्रनाइज़ेशन आवश्यकताओं के कारण समस्याओं की संभावना को बढ़ाने के रूप में देखा जाता है।

अन्य विकल्पों में शामिल हैं -

बहु प्रक्रिया पैटर्न

प्रत्येक अनुरोध को अपनी स्वयं की पायथन प्रक्रिया द्वारा नियंत्रित किया जाता है। यहां, सर्वर के प्रदर्शन और स्थिरता को बेहतर माना जा सकता है।

अतुल्यकालिक पैटर्न

यहां, नए कनेक्शन स्वीकार करने और ग्राहक को डेटा वापस भेजने का अनुरोध प्रक्रिया से एसिंक्रोनस रूप से किया जाता है। यह तकनीक अपनी दक्षता के लिए जानी जाती है।

URL डिस्पैचिंग

चेरी समुदाय अधिक लचीला होना चाहता है और डिस्पैचर्स के लिए अन्य समाधानों की सराहना की जाएगी। चेरीपी 3 अन्य बिल्ट-इन डिस्पैचर प्रदान करता है और अपने स्वयं के डिस्पैचर को लिखने और उपयोग करने का एक सरल तरीका प्रदान करता है।

  • HTTP विधियों को विकसित करने के लिए उपयोग किए जाने वाले अनुप्रयोग। (GET, POST, PUT, आदि)
  • जो URL में मार्गों को परिभाषित करता है - रूट डिस्पैचर

HTTP मेथड डिस्पैचर

कुछ अनुप्रयोगों में, यूआरआई कार्रवाई से स्वतंत्र होते हैं, जो कि संसाधन पर सर्वर द्वारा किया जाना है।

उदाहरण के लिए,http://xyz.com/album/delete/10

URI में वह ऑपरेशन होता है जिसे ग्राहक करना चाहता है।

डिफ़ॉल्ट रूप से, चेरी डिस्पैचर निम्नलिखित तरीके से मैप करेगा -

album.delete(12)

उपर्युक्त प्रेषण को सही ढंग से उल्लेख किया गया है, लेकिन निम्नलिखित तरीके से स्वतंत्र किया जा सकता है -

http://xyz.com/album/10

उपयोगकर्ता आश्चर्यचकित हो सकता है कि सर्वर सटीक पृष्ठ को कैसे भेजता है। यह जानकारी स्वयं HTTP अनुरोध द्वारा की जाती है। जब क्लाइंट से सर्वर के लिए अनुरोध होता है, तो चेरीपी सबसे अच्छा सूटिंग हैंडलर दिखता है, हैंडलर यूआरआई द्वारा लक्षित संसाधन का प्रतिनिधित्व करता है।

DELETE /album/12 HTTP/1.1

रूट डिस्पैचर

प्रेषण में आवश्यक विधि के मापदंडों की एक सूची इस प्रकार है -

  • कनेक्ट करने के मार्ग के लिए नाम पैरामीटर अद्वितीय नाम है।

  • मार्ग URI से मेल करने के लिए पैटर्न है।

  • नियंत्रक पृष्ठ संचालकों वाला उदाहरण है।

  • रूट डिस्पैचर का उपयोग करना एक पैटर्न को जोड़ता है जो यूआरआई से मेल खाता है और एक विशिष्ट पेज हैंडलर को जोड़ता है।

उदाहरण

आइए हम एक उदाहरण लें कि यह कैसे काम करता है -

import random
import string
import cherrypy

class StringMaker(object):
   @cherrypy.expose
   def index(self):
      return "Hello! How are you?"
   
   @cherrypy.expose
   def generate(self, length=9):
      return ''.join(random.sample(string.hexdigits, int(length)))
		
if __name__ == '__main__':
   cherrypy.quickstart(StringMaker ())

उपरोक्त कोड का आउटपुट पाने के लिए नीचे दिए गए चरणों का पालन करें -

Step 1 - ऊपर बताई गई फाइल को इस प्रकार सेव करें tutRoutes.py

Step 2 - निम्न URL पर जाएं -

http://localhost:8080/generate?length=10

Step 3 - आपको निम्न आउटपुट प्राप्त होंगे -