इस दस्तावेज़ में बताया गया है कि आपके क्लाइंट को बनाए जाने वाले एचटीटीपी कनेक्शन कम करने के लिए, एपीआई कॉल को एक साथ किस तरह बैच करना है.
यह दस्तावेज़ खास तौर पर, एचटीटीपी अनुरोध भेजकर बैच अनुरोध भेजने के बारे में है. इसके बजाय, अगर बैच अनुरोध करने के लिए Google क्लाइंट लाइब्रेरी का इस्तेमाल किया जा रहा है, तो क्लाइंट लाइब्रेरी का दस्तावेज़ देखें.
खास जानकारी
आपका क्लाइंट हर एचटीटीपी कनेक्शन के लिए, तय सीमा से ज़्यादा ओवरहेड बनाता है. डायरेक्ट्री एपीआई, एक साथ कई अनुरोध भेजने की सुविधा देता है. इससे आपका क्लाइंट एक एचटीटीपी अनुरोध में कई एपीआई कॉल कर सकता है.
उन स्थितियों के उदाहरण जिनमें शायद आप एक साथ कई अनुरोध करने की सुविधा का इस्तेमाल करना चाहें:
- आपने अभी-अभी एपीआई का इस्तेमाल शुरू किया है और आपके पास अपलोड करने के लिए बहुत सारा डेटा है.
- किसी उपयोगकर्ता ने उस समय डेटा में बदलाव किए हैं जब आपका ऐप्लिकेशन ऑफ़लाइन था (इंटरनेट से डिसकनेक्ट था), इसलिए आपके ऐप्लिकेशन को ज़्यादा अपडेट भेजकर और उसे हटा कर सर्वर के साथ अपना स्थानीय डेटा सिंक करने की ज़रूरत है.
ऐसे मामलों में, हर कॉल को अलग-अलग भेजने के बजाय, उन्हें एक एचटीटीपी अनुरोध में ग्रुप किया जा सकता है. सभी अंदरूनी अनुरोध एक ही Google API को जाने चाहिए.
एक साथ कई अनुरोधों को ज़्यादा से ज़्यादा 1,000 कॉल किया जा सकता है. अगर आपको इससे ज़्यादा कॉल करने हैं, तो एक से ज़्यादा बैच रिक्वेस्ट का इस्तेमाल करें.
ध्यान दें: Directory API का बैच सिस्टम, OData बैच प्रोसेसिंग सिस्टम जैसे ही सिंटैक्स का इस्तेमाल करता है. हालांकि, दोनों के सिमैंटिक अलग होते हैं.
बैच की जानकारी
एक साथ भेजे जाने वाले अनुरोध में कई एपीआई कॉल शामिल होते हैं, जिन्हें एक एचटीटीपी अनुरोध में जोड़ा जाता है. इसे एपीआई डिस्कवरी दस्तावेज़ में बताए गए batchPath
पर भेजा जा सकता है. डिफ़ॉल्ट पाथ /batch/api_name/api_version
है. इस सेक्शन में बैच सिंटैक्स के बारे में पूरी जानकारी दी गई है. बाद में, इसका एक उदाहरण है.
ध्यान दें: एक साथ बैच किए गए n अनुरोधों के सेट को, इस्तेमाल करने की आपकी सीमा में n अनुरोधों के तौर पर गिना जाता है, न कि एक अनुरोध के तौर पर. प्रोसेस करने से पहले, एक साथ कई अनुरोध को अनुरोधों के सेट में अलग कर दिया जाता है.
बैच अनुरोध का फ़ॉर्मैट
बैच अनुरोध, एक स्टैंडर्ड एचटीटीपी अनुरोध होता है. इसमें कई डायरेक्ट्री एपीआई कॉल शामिल होते हैं. इसके लिए multipart/mixed
कॉन्टेंट टाइप का इस्तेमाल किया जाता है. उस मुख्य एचटीटीपी अनुरोध में, हर हिस्से में एक नेस्ट किया गया एचटीटीपी अनुरोध होता है.
हर हिस्सा अपने Content-Type: application/http
एचटीटीपी हेडर से शुरू होता है. इसमें एक वैकल्पिक Content-ID
हेडर भी हो सकता है. हालांकि, पार्ट हेडर सिर्फ़ हिस्से की शुरुआत को मार्क करने के लिए होते हैं; वे नेस्ट किए गए अनुरोध से अलग होते हैं. जब सर्वर बैच अनुरोध को अलग-अलग अनुरोधों में खोल देता है, तो पार्ट हेडर को अनदेखा कर दिया जाता है.
हर हिस्से का मुख्य हिस्सा पूरा एचटीटीपी अनुरोध होता है. इसमें अपनी वर्ब, यूआरएल, हेडर, और मुख्य हिस्से का इस्तेमाल होता है. एचटीटीपी अनुरोध में सिर्फ़ यूआरएल का पाथ वाला हिस्सा शामिल होना चाहिए. एक साथ कई अनुरोध करने वाले अनुरोधों में पूरे यूआरएल की अनुमति नहीं होती.
Content-Type
जैसे Content-
हेडर को छोड़कर, आउटर बैच अनुरोध के एचटीटीपी हेडर, बैच में हर अनुरोध पर लागू होते हैं. अगर किसी एचटीटीपी हेडर को आउटर अनुरोध और व्यक्तिगत कॉल, दोनों में सेट किया जाता है, तो अलग-अलग कॉल हेडर की वैल्यू, आउटर बैच अनुरोध के हेडर की वैल्यू को बदल देती है. किसी एक कॉल के हेडर सिर्फ़ उस कॉल पर लागू होते हैं.
उदाहरण के लिए, अगर किसी खास कॉल के लिए 'ऑथराइज़ेशन' हेडर दिया जाता है, तो वह हेडर सिर्फ़ उस कॉल पर लागू होता है. अगर बाहरी अनुरोध के लिए ऑथराइज़ेशन हेडर दिया जाता है, तो वह हेडर सभी अलग-अलग कॉल पर तब तक लागू होता है, जब तक वे उसे अपने ऑथराइज़ेशन हेडर से नहीं बदलते.
जब सर्वर को बैच किया गया अनुरोध मिलता है, तो वह हर हिस्से पर बाहरी अनुरोध के क्वेरी पैरामीटर और हेडर (जो भी ठीक हो) लागू करता है. इसके बाद, वह हर हिस्से को इस तरह से देखता है जैसे वह कोई अलग एचटीटीपी अनुरोध हो.
बैच में किए गए अनुरोध का जवाब
सर्वर से मिलने वाला रिस्पॉन्स, multipart/mixed
कॉन्टेंट टाइप वाला एक स्टैंडर्ड एचटीटीपी रिस्पॉन्स होता है. हर हिस्सा, बैच में भेजे गए अनुरोध में से किसी एक अनुरोध का जवाब होता है. यह रिस्पॉन्स, अनुरोध की तरह ही होता है.
अनुरोध के हिस्सों की तरह, जवाब के हर हिस्से में पूरा एचटीटीपी रिस्पॉन्स होता है. इसमें स्टेटस कोड, हेडर, और मुख्य हिस्सा शामिल है. अनुरोध के हिस्सों की तरह, जवाब के हर हिस्से से पहले एक Content-Type
हेडर होता है. यह हेडर, हिस्से की शुरुआत का निशान होता है.
अगर अनुरोध के किसी हिस्से में Content-ID
हेडर है, तो रिस्पॉन्स के संबंधित हिस्से का हेडर मेल खाने वाला Content-ID
होगा, जिसमें स्ट्रिंग response-
से पहले आने वाली ओरिजनल वैल्यू होगी, जैसा कि यहां दिए गए उदाहरण में दिखाया गया है.
ध्यान दें: सर्वर किसी भी क्रम में आपके कॉल कर सकता है. उनके लागू होने के उसी क्रम में गिनती न करें जिसमें आपने उन्हें तय किया था. अगर आपको यह पक्का करना है कि दो कॉल एक ही क्रम में आएं, तो उन्हें एक ही अनुरोध में नहीं भेजा जा सकता. इसके बजाय, पहला कॉल खुद भेजें. इसके बाद, दूसरे कॉल का जवाब देने से पहले, पहले वाले का जवाब मिलने का इंतज़ार करें.
उदाहरण
नीचे दिए गए उदाहरण में, जेनरिक (काल्पनिक) डेमो एपीआई की मदद से बैच बनाने की सुविधा के इस्तेमाल के बारे में बताया गया है. इस एपीआई को Farm API कहा जाता है. हालांकि, डायरेक्ट्री एपीआई पर भी यही सिद्धांत लागू होते हैं.
बैच अनुरोध का उदाहरण
POST /batch/farm/v1 HTTP/1.1 Authorization: Bearer your_auth_token Host: www.googleapis.com Content-Type: multipart/mixed; boundary=batch_foobarbaz Content-Length: total_content_length --batch_foobarbaz Content-Type: application/http Content-ID: <item1:12930812@barnyard.example.com> GET /farm/v1/animals/pony --batch_foobarbaz Content-Type: application/http Content-ID: <item2:12930812@barnyard.example.com> PUT /farm/v1/animals/sheep Content-Type: application/json Content-Length: part_content_length If-Match: "etag/sheep" { "animalName": "sheep", "animalAge": "5" "peltColor": "green", } --batch_foobarbaz Content-Type: application/http Content-ID: <item3:12930812@barnyard.example.com> GET /farm/v1/animals If-None-Match: "etag/animals" --batch_foobarbaz--
बैच में दिए गए जवाब का उदाहरण
यह पिछले सेक्शन में उदाहरण के तौर पर दिए गए अनुरोध का जवाब है.
HTTP/1.1 200 Content-Length: response_total_content_length Content-Type: multipart/mixed; boundary=batch_foobarbaz --batch_foobarbaz Content-Type: application/http Content-ID: <response-item1:12930812@barnyard.example.com> HTTP/1.1 200 OK Content-Type application/json Content-Length: response_part_1_content_length ETag: "etag/pony" { "kind": "farm#animal", "etag": "etag/pony", "selfLink": "/farm/v1/animals/pony", "animalName": "pony", "animalAge": 34, "peltColor": "white" } --batch_foobarbaz Content-Type: application/http Content-ID: <response-item2:12930812@barnyard.example.com> HTTP/1.1 200 OK Content-Type: application/json Content-Length: response_part_2_content_length ETag: "etag/sheep" { "kind": "farm#animal", "etag": "etag/sheep", "selfLink": "/farm/v1/animals/sheep", "animalName": "sheep", "animalAge": 5, "peltColor": "green" } --batch_foobarbaz Content-Type: application/http Content-ID: <response-item3:12930812@barnyard.example.com> HTTP/1.1 304 Not Modified ETag: "etag/animals" --batch_foobarbaz--