फ़ंक्शन शेड्यूल करें


अगर आपको फ़ंक्शन को तय समय पर चलाने के लिए शेड्यूल करना है, तो onSchedule हैंडलर का इस्तेमाल करके, Pub/Sub विषय बनाएं. यह विषय, उस विषय पर इवेंट ट्रिगर करने के लिए Cloud Scheduler का इस्तेमाल करता है.

शुरू करने से पहले

अपने Firebase प्रोजेक्ट में इस समाधान का इस्तेमाल करने के लिए, आपका प्रोजेक्ट, Blaze के कीमत वाले प्लान पर होना चाहिए. अगर आपका खाता पहले से ही ब्लेज़ प्लान पर नहीं है, तो अपने प्लान को अपग्रेड करें.

हालांकि, बिलिंग की ज़रूरत होती है, लेकिन आपको कुल खर्च को मैनेज करने में मदद मिल सकती है. ऐसा इसलिए, क्योंकि हर Cloud Scheduler जॉब के लिए हर महीने 0.10 डॉलर (अमेरिकन डॉलर) का शुल्क लिया जाता है. साथ ही, हर Google खाते के लिए तीन जॉब बिना किसी शुल्क के किए जा सकते हैं. अनुमानित इस्तेमाल के आधार पर, लागत का अनुमान जनरेट करने के लिए, Blaze के प्राइसिंग कैलकुलेटर का इस्तेमाल करें.

आपके प्रोजेक्ट के लिए, Pub/Sub और Cloud Scheduler एपीआई चालू होने चाहिए. ज़्यादातर Firebase प्रोजेक्ट के लिए, ये पहले से ही चालू होने चाहिए. Google Cloud कंसोल में जाकर इसकी पुष्टि की जा सकती है.

शेड्यूल किया गया फ़ंक्शन लिखना

Cloud Functions for Firebase में, शेड्यूलिंग लॉजिक आपके फ़ंक्शन कोड में मौजूद होता है. साथ ही, डिप्लॉय करने के समय कोई खास ज़रूरी शर्त नहीं होती. शेड्यूल किया गया फ़ंक्शन बनाने के लिए, functions.pubsub.schedule('your schedule').onRun((context)) का इस्तेमाल करें. उदाहरण के लिए, App Engine cron.yaml सिंटैक्स का इस्तेमाल करके, हर पांच मिनट में कोई फ़ंक्शन चलाने के लिए, कुछ ऐसा करें:

exports.scheduledFunction = functions.pubsub.schedule('every 5 minutes').onRun((context) => {
  console.log('This will be run every 5 minutes!');
  return null;
});

Cloud Scheduler में, Unix Crontab और App Engine सिंटैक्स, दोनों काम करते हैं. उदाहरण के लिए, Crontab का इस्तेमाल करके, शेड्यूल किया गया फ़ंक्शन चलाने के लिए कोई टाइमज़ोन चुनने के लिए, ऐसा करें:

exports.scheduledFunctionCrontab = functions.pubsub.schedule('5 11 * * *')
  .timeZone('America/New_York') // Users can choose timezone - default is America/Los_Angeles
  .onRun((context) => {
  console.log('This will be run every day at 11:05 AM Eastern!');
  return null;
});

timeZone की वैल्यू, tz डेटाबेस में मौजूद टाइम ज़ोन का नाम होनी चाहिए. इस्तेमाल की जा सकने वाली प्रॉपर्टी के बारे में ज़्यादा जानकारी के लिए, Cloud Scheduler का रेफ़रंस देखें.

शेड्यूल किया गया फ़ंक्शन डिप्लॉय करना

शेड्यूल किए गए फ़ंक्शन को डिप्लॉय करने पर, उससे जुड़ी शेड्यूलर जॉब और पब्लिश/सब्सक्राइब टॉपिक अपने-आप बन जाता है. Firebase सीएलआई, विषय का नाम दिखाता है. साथ ही, Google Cloud console में जॉब और विषय देखा जा सकता है. विषय का नाम इस तरीके से रखा जाता है:

Firebase के लिए शेड्यूल की गई तारीख-function_name-region

उदाहरण के लिए:

firebase-scheduled-scheduledFunctionCrontab-us-east1.