BatchJobService
का इस्तेमाल करते समय इन दिशा-निर्देशों को ध्यान में रखें.
प्रवाह क्षमता में सुधार
कई छोटी नौकरियों की तुलना में, बड़ी नौकरियां ज़्यादा पसंद की जाती हैं.
कार्रवाई के टाइप के हिसाब से अपलोड की गई कार्रवाइयों को क्रम से लगाएं. उदाहरण के लिए, अगर आपकी नौकरी में कैंपेन, विज्ञापन समूह, और विज्ञापन समूह से जुड़ी शर्तें जोड़ने के लिए कार्रवाइयां शामिल हैं, तो अपने अपलोड में कार्रवाइयों को क्रम में लगाएं, ताकि सभी कैंपेन ऑपरेशन पहले हों, इसके बाद विज्ञापन ग्रुप की सभी कार्रवाइयां और आखिर में विज्ञापन समूह की सभी शर्तों से जुड़ी कार्रवाइयां हों.
एक ही तरह के ऑपरेशन में, पैरंट रिसॉर्स के हिसाब से इनका ग्रुप बनाने से परफ़ॉर्मेंस बेहतर हो सकती है. उदाहरण के लिए, अगर आपके पास
AdGroupCriterionOperation
ऑब्जेक्ट की एक सीरीज़ है, तो अलग-अलग विज्ञापन ग्रुप में विज्ञापन ग्रुप की शर्तों पर असर डालने वाली कार्रवाइयों को आपस में जोड़ने के बजाय, विज्ञापन ग्रुप के हिसाब से ऑपरेशन को ग्रुप करना बेहतर हो सकता है.
एक के बाद एक दिखने वाली समस्याओं से बचना
एक ही खाते के लिए एक साथ कई जॉब सबमिट करते समय, कोशिश करें कि एक ही ऑब्जेक्ट पर एक ही समय में जॉब के काम करने की संभावना कम हो जाए. साथ ही, बड़ी संख्या में जॉब उपलब्ध रखें. कई अधूरे काम (
RUNNING
की स्थिति वाले) जिनमें ऑब्जेक्ट के एक जैसे सेट में बदलाव करने की कोशिश की जाती है वे बंद होने जैसी स्थितियों की वजह बन सकते हैं.एक ही जॉब में, एक ही ऑब्जेक्ट में बदलाव करने वाली कई कार्रवाइयां सबमिट न करें, क्योंकि ऐसा करने पर नतीजा अनुमान से अलग हो सकता है.
बेहतर तरीके से नतीजे फिर से पाएं
जॉब की स्थिति के बारे में बार-बार पोल न करें. ऐसा करने से, हो सकता है कि आप तय की गई दर से जुड़ी गड़बड़ियां देख पाएं.
हर पेज पर 1,000 से ज़्यादा नतीजे न पाएं. लोड या अन्य कारकों के कारण सर्वर से कम वापसी कर सकता है.
नतीजों का क्रम और अपलोड करने का क्रम एक ही होगा.
इस्तेमाल करने के बारे में अतिरिक्त दिशा-निर्देश
आपके पास इस बात की ऊपरी सीमा सेट करने का विकल्प है कि रद्द किए जाने से पहले, बैच जॉब को कितने समय तक चलने की अनुमति है. नया बैच जॉब बनाते समय,
metadata.execution_limit_seconds
फ़ील्ड को सेकंड में, अपनी पसंद की समयसीमा पर सेट करें. अगरmetadata.execution_limit_seconds
सेट नहीं है, तो डिफ़ॉल्ट तौर पर कोई समयसीमा सेट नहीं की जाती है.हमारा सुझाव है कि हर
AddBatchJobOperationsRequest
में 1,000 से ज़्यादा कार्रवाइयां न जोड़ें. साथ ही, एक ही जॉब में बाकी के सभी ऑपरेशन अपलोड करने के लिए,sequence_token
का इस्तेमाल करें. ऑपरेशन के कॉन्टेंट के आधार पर, एक हीAddBatchJobOperationsRequest
में बहुत ज़्यादा कार्रवाइयां करने सेREQUEST_TOO_LARGE
गड़बड़ी हो सकती है. कार्रवाइयों की संख्या को कम करके औरAddBatchJobOperationsRequest
को फिर से आज़माकर, इस गड़बड़ी को ठीक किया जा सकता है.
सीमाएं
हर
BatchJob
पर, ज़्यादा से ज़्यादा 10 लाख ऑपरेशन काम करते हैं.किसी एक खाते में एक साथ 100 सक्रिय या लंबित काम हो सकते हैं.
सात दिन से ज़्यादा पुरानी नौकरियां अपने-आप हट जाती हैं.