इस पेज पर, Cloud Firestore के डेटा के एक्सपोर्ट को शेड्यूल करने का तरीका बताया गया है. हमारा सुझाव है कि एक्सपोर्ट को शेड्यूल पर चलाने के लिए, Cloud Functions और Cloud Scheduler का इस्तेमाल करें.
शुरू करने से पहले
मैनेज किए गए डेटा एक्सपोर्ट को शेड्यूल करने से पहले, आपको ये काम पूरे करने होंगे:
- अपने Google Cloud प्रोजेक्ट के लिए बिलिंग की सुविधा चालू करें. एक्सपोर्ट और इंपोर्ट करने की सुविधा का इस्तेमाल सिर्फ़ उन Google Cloud प्रोजेक्ट के लिए किया जा सकता है जिनमें बिलिंग की सुविधा चालू हो.
- एक्सपोर्ट कार्रवाइयों के लिए डेस्टिनेशन Cloud Storage बकेट ज़रूरी है. अपने Cloud Firestore डेटाबेस की जगह के आस-पास, एक Cloud Storage बकेट बनाएं. एक्सपोर्ट करने के लिए, अनुरोध करने वाले के पैसे चुकाने वाली बकेट का इस्तेमाल नहीं किया जा सकता.
Cloud Function और Cloud Scheduler जॉब बनाएं
Node.js Cloud फ़ंक्शन बनाने के लिए, यह तरीका अपनाएं. यह फ़ंक्शन, Cloud Firestore डेटा एक्सपोर्ट और उस फ़ंक्शन को कॉल करने के लिए Cloud Scheduler जॉब शुरू करता है:
Firebase CLI
-
Firebase सीएलआई इंस्टॉल करें. नई डायरेक्ट्री में, Cloud Functions के लिए सीएलआई को शुरू करें:
firebase init functions --project PROJECT_ID
- भाषा के लिए JavaScript चुनें.
- इसके अलावा, ESLint को चालू करें.
- डिपेंडेंसी इंस्टॉल करने के लिए,
y
डालें.
-
functions/index.js
फ़ाइल में मौजूद कोड को, यहां दिए गए कोड से बदलें:const functions = require('firebase-functions'); const firestore = require('@google-cloud/firestore'); const client = new firestore.v1.FirestoreAdminClient(); // Replace BUCKET_NAME const bucket = 'gs://BUCKET_NAME'; exports.scheduledFirestoreExport = functions.pubsub .schedule('every 24 hours') .onRun((context) => { const projectId = process.env.GCP_PROJECT; const databaseName = client.databasePath(projectId, '(default)'); return client.exportDocuments({ name: databaseName, outputUriPrefix: bucket, // Leave collectionIds empty to export all collections // or set to a list of collection IDs to export, // collectionIds: ['users', 'posts'] collectionIds: [] }) .then(responses => { const response = responses[0]; console.log(`Operation Name: ${response['name']}`); }) .catch(err => { console.error(err); throw new Error('Export operation failed'); }); });
-
ऊपर दिए गए कोड में, इनमें बदलाव करें:
BUCKET_NAME
की जगह अपनी बकेट का नाम डालें.- एक्सपोर्ट का शेड्यूल सेट करने के लिए,
every 24 hours
में बदलाव करें. AppEngine cron.yaml सिंटैक्स या unix-cron फ़ॉर्मैट (* * * * *
) में से किसी एक का इस्तेमाल करें. -
सिर्फ़ बताए गए कलेक्शन ग्रुप को एक्सपोर्ट करने के लिए,
collectionIds: []
में बदलाव करें. सभी कलेक्शन को एक्सपोर्ट करने के लिए, वैसे ही छोड़ दें.
-
शेड्यूल किए गए फ़ंक्शन को डिप्लॉय करें:
firebase deploy --only functions
Google Cloud कंसोल
कोई क्लाउड फ़ंक्शन बनाएं
-
Google Cloud Console में, Cloud Functions पेज पर जाएं:
- फ़ंक्शन बनाएं पर क्लिक करें
- फ़ंक्शन का नाम डालें, जैसे कि
firestoreExport
- ट्रिगर में जाकर, Cloud Pub/Sub चुनें
- विषय में जाकर, नया विषय बनाएं को चुनें. Pub/Sub के विषय के लिए कोई नाम डालें, जैसे कि
initiateFirestoreExport
. विषय के उस नाम को नोट कर लें जिसकी आपको Cloud Scheduler जॉब बनाने के लिए ज़रूरत है. - सोर्स कोड में, इनलाइन एडिटर चुनें.
index.js
में यह कोड डालें: ऊपर दिए गए कोड में, इनमें बदलाव करें:const firestore = require('@google-cloud/firestore'); const client = new firestore.v1.FirestoreAdminClient(); // Replace BUCKET_NAME const bucket = 'gs://BUCKET_NAME' exports.scheduledFirestoreExport = (event, context) => { const databaseName = client.databasePath( process.env.GCP_PROJECT, '(default)' ); return client .exportDocuments({ name: databaseName, outputUriPrefix: bucket, // Leave collectionIds empty to export all collections // or define a list of collection IDs: // collectionIds: ['users', 'posts'] collectionIds: [], }) .then(responses => { const response = responses[0]; console.log(`Operation Name: ${response['name']}`); return response; }) .catch(err => { console.error(err); }); };
BUCKET_NAME
की जगह अपनी बकेट का नाम डालें.-
सिर्फ़ बताए गए कलेक्शन ग्रुप को एक्सपोर्ट करने के लिए,
collectionIds: []
में बदलाव करें. सभी कलेक्शन एक्सपोर्ट करने के लिए, इस सेटिंग को वैसे ही रहने दें.
package.json
में जाकर, यह डिपेंडेंसी जोड़ें:{ "dependencies": { "@google-cloud/firestore": "^1.3.0" } }
- कार्रवाई करने के लिए फ़ंक्शन में,
scheduledFirestoreExport
डालें. इसके बाद,index.js
में फ़ंक्शन का नाम डालें. - Cloud फ़ंक्शन को डिप्लॉय करने के लिए, बनाएं पर क्लिक करें.
Cloud Scheduler जॉब बनाना
इसके बाद, Cloud Scheduler जॉब बनाएं, जो आपके Cloud फ़ंक्शन को कॉल करता है:
-
Google Cloud Console में Cloud Scheduler पेज पर जाएं:
- जॉब बनाएं पर क्लिक करें.
- नौकरी के लिए कोई नाम डालें, जैसे कि
scheduledFirestoreExport
. - फ़्रीक्वेंसी डालें, जैसे कि
every 24 hours
. - कोई टाइमज़ोन चुनें.
- टारगेट में जाकर, Pub/Sub चुनें. Topic फ़ील्ड में,
उस pub/sub विषय का नाम डालें जिसे आपने ऊपर दिए गए उदाहरण में, अपने Cloud फ़ंक्शन,
initiateFirestoreExport
के साथ तय किया था. - पेलोड फ़ील्ड में,
start export
डालें. इस जॉब के लिए पेलोड तय करना ज़रूरी है, लेकिन ऊपर दिया गया Cloud फ़ंक्शन असल में इस वैल्यू का इस्तेमाल नहीं करता. - बनाएं पर क्लिक करें.
ऐक्सेस से जुड़ी अनुमतियां कॉन्फ़िगर करना
इसके बाद, Cloud Function को डेटा एक्सपोर्ट करने और GCS बकेट में डेटा लिखने की अनुमति दें.
यह Cloud फ़ंक्शन, एक्सपोर्ट ऑपरेशन की पुष्टि करने और उन्हें अनुमति देने के लिए, आपके प्रोजेक्ट के डिफ़ॉल्ट सेवा खाते का इस्तेमाल करता है. प्रोजेक्ट बनाने पर, आपके लिए डिफ़ॉल्ट सेवा खाता इस नाम से बन जाता है:
PROJECT_ID@appspot.gserviceaccount.com
इस सेवा खाते को एक्सपोर्ट करने की प्रोसेस शुरू करने और आपकी Cloud Storage बकेट में डेटा लिखने की अनुमति चाहिए. ये अनुमतियां देने के लिए, डिफ़ॉल्ट सेवा खाते को यहां दी गई आईएएम भूमिकाएं असाइन करें:
Cloud Datastore Import Export Admin
-
बकेट में
Owner
याStorage Admin
की भूमिका
इन भूमिकाओं को असाइन करने के लिए, gcloud
और gsutil
कमांड-लाइन
टूल का इस्तेमाल किया जा सकता है.
अगर ये टूल पहले से इंस्टॉल नहीं हैं, तो इन्हें Google Cloud कंसोल में Cloud Shell से ऐक्सेस किया जा सकता है:
शुरू करें Cloud Shell
-
Cloud Datastore इंपोर्ट एक्सपोर्ट एडमिन की भूमिका असाइन करें. PROJECT_ID को बदलें और यह निर्देश चलाएं:
gcloud projects add-iam-policy-binding PROJECT_ID \ --member serviceAccount:PROJECT_ID@appspot.gserviceaccount.com \ --role roles/datastore.importExportAdmin
-
अपनी बकेट में स्टोरेज एडमिन की भूमिका असाइन करें. PROJECT_ID और BUCKET_NAME को बदलें और यह कमांड चलाएं:
gsutil iam ch serviceAccount:PROJECT_ID@appspot.gserviceaccount.com:admin \ gs://BUCKET_NAME
अगर आपने App Engine डिफ़ॉल्ट सेवा खाते को बंद या मिटा दिया है, तो आपके App Engine ऐप्लिकेशन के पास Cloud Firestore डेटाबेस का ऐक्सेस नहीं रहेगा. अगर आपने अपना App Engine सेवा खाता बंद कर दिया है, तो उसे फिर से चालू किया जा सकता है. इसके लिए, सेवा खाता चालू करना लेख पढ़ें. अगर आपने पिछले 30 दिनों में अपना App Engine सेवा खाता मिटाया है, तो उसे वापस पाया जा सकता है. इसके लिए, सेवा खाते को मिटाने के बाद उसे वापस लाना लेख पढ़ें.
Cloud Scheduler जॉब और क्लाउड फ़ंक्शन की जांच करें
Google Cloud Console के Cloud Scheduler पेज पर जाकर, Cloud Scheduler जॉब की जांच की जा सकती है.
Google Cloud Console में, Cloud Scheduler पेज पर जाएं.
Cloud Scheduler पर जाएंअपनी नई Cloud Scheduler जॉब की लाइन में, अभी चलाएं पर क्लिक करें.
कुछ सेकंड बाद, Cloud Scheduler जॉब के नतीजे वाले कॉलम को सफल और पिछली बार चलाया गया को मौजूदा समय पर अपडेट करना चाहिए. इसके लिए, आपको रीफ़्रेश करें पर क्लिक करना पड़ सकता है.
Cloud Scheduler पेज सिर्फ़ इस बात की पुष्टि करता है कि नौकरी ने आपके Cloud फ़ंक्शन को कॉल किया है. अपने फ़ंक्शन के लॉग देखने के लिए, Cloud Function पेज खोलें.
Cloud Function लॉग देखना
यह देखने के लिए कि Cloud फ़ंक्शन ने एक्सपोर्ट की प्रोसेस शुरू की है या नहीं, फ़ंक्शन के लॉग खोलें:
Firebase कंसोल
Firebase कंसोल में Cloud Functions पेज पर जाएं.
जीसीपी कंसोल
Google Cloud Console में, Cloud Functions पेज पर जाएं.
एक्सपोर्ट की प्रोग्रेस देखना
अपने एक्सपोर्ट की प्रोग्रेस देखने के लिए, gcloud firestore operations list
कमांड का इस्तेमाल किया जा सकता है. साथ ही, एक्सपोर्ट और इंपोर्ट से जुड़ी कार्रवाइयां मैनेज करना लेख पढ़ें.
एक्सपोर्ट की कार्रवाई पूरी होने के बाद, अपने Cloud Storage बकेट में आउटपुट फ़ाइलें देखी जा सकती हैं: