ऐप्लिकेशन होस्टिंग के लिए फ़्रेमवर्क और टूल

Firebase App Hosting को खास तौर पर, फ़्रेमवर्क पर आधारित मॉडर्न वेब ऐप्लिकेशन डेवलपमेंट में मदद करने के लिए डिज़ाइन किया गया है. इस पेज का इस्तेमाल, उन टूल और फ़्रेमवर्क के बारे में जानने के लिए करें जिन्हें App Hosting सीधे तौर पर सपोर्ट करता है. साथ ही, इस पेज का इस्तेमाल, इससे जुड़े फ़्रेमवर्क और टूलिंग के बारे में जानने के लिए भी किया जा सकता है.

वेब फ़्रेमवर्क और App Hosting

App Hosting, मॉडर्न वेब फ़्रेमवर्क के लिए दो तरह की सहायता उपलब्ध कराता है: पहले से कॉन्फ़िगर किए गए बिल्ड और डिप्लॉय की सुविधा. साथ ही, कम्यूनिटी लेवल पर सहायता. इसके लिए, ओपन सोर्स कॉन्ट्रिब्यूशन का इस्तेमाल किया जाता है. ये कॉन्ट्रिब्यूशन, आउटपुट बंडल स्पेसिफ़िकेशन के मुताबिक होते हैं. दोनों ही मामलों में, फ़्रेमवर्क अडैप्टर कॉम्पोनेंट की मदद से, किसी फ़्रेमवर्क को App Hosting के साथ इंटिग्रेट किया जा सकता है.

पहले से कॉन्फ़िगर किए गए ऐसे फ़्रेमवर्क जिनमें बनाने और डिप्लॉय करने की सुविधा उपलब्ध हो

पहले से कॉन्फ़िगर किए गए बिल्ड और डिप्लॉय की सुविधा के साथ, Firebase यह पता लगाता है कि package-lock.json फ़ाइल या अन्य लॉक फ़ाइल की जांच करके, कौनसे फ़्रेमवर्क का इस्तेमाल किया जा रहा है. साथ ही, यह आपके ऐप्लिकेशन के लिए बिल्ड और डिप्लॉयमेंट की प्रोसेस को ऑप्टिमाइज़ करता है. Google इन फ़्रेमवर्क के लिए सहायता बनाए रखने के लिए प्रतिबद्ध है. साथ ही, Firebase की सहायता टीम, समस्या की रिपोर्ट और सुविधा के अनुरोध स्वीकार कर सकती है.

इस लेवल की सहायता इन मामलों में मिलती है:

  • Next.js
  • Angular

किसी वर्शन और सहायता के लेवल के बारे में ज़्यादा जानने के लिए, सहायता के शेड्यूल देखें.

अगर लॉक फ़ाइल के बिना किसी Node.js ऐप्लिकेशन को डिप्लॉय करने की कोशिश की जाती है, तो App Hosting आपके ऐप्लिकेशन को न तो बना पाएगा और न ही चला पाएगा. package-lock.json बनाने के लिए, अपनी रूट डायरेक्ट्री में npm install चलाएं.

कम्यूनिटी की मदद से बनाए गए फ़्रेमवर्क

Next.js और Angular के अलावा, App Hosting ऐसे किसी भी वेब फ़्रेमवर्क के साथ काम करता है जो हमारे आउटपुट बंडल स्पेसिफ़िकेशन से मेल खाने वाला बिल्ड आउटपुट दे सकता है. फ़्रेमवर्क के लेखक, आउटपुट बंडल स्पेसिफ़िकेशन का फ़ायदा ले सकते हैं. इससे वे यह पक्का कर सकते हैं कि उनका फ़्रेमवर्क App Hosting के साथ काम करता हो. उदाहरण के लिए, लोकप्रिय Nuxt फ़्रेमवर्क को Nitro टीम सपोर्ट करती है. इस टीम ने App Hosting पर Nuxt ऐप्लिकेशन डिप्लॉय करने के लिए, Firebase अडैप्टर बनाया है.

अगर आपको App Hosting के साथ काम करने वाले अन्य फ़्रेमवर्क देखने हैं, तो फ़्रेमवर्क अडैप्टर बनाया जा सकता है. इसके अलावा, फ़्रेमवर्क को बनाए रखने वालों से संपर्क करके, बिल्ड आउटपुट को App Hosting फ़ॉर्मैट में बदला जा सकता है. Next.js और Angular अडैप्टर, अडैप्टर बनाने वाले किसी भी व्यक्ति के लिए अच्छे रेफ़रंस उदाहरण हैं.

कम्यूनिटी की मदद से बनाए गए फ़्रेमवर्क के बारे में जानकारी, Firebase Open Source पर मिल सकती है. कम्यूनिटी की मदद से बनाए गए फ़्रेमवर्क से जुड़ी समस्याओं और सुविधाओं के अनुरोधों के बारे में, ओपन सोर्स कम्यूनिटी या फ़्रेमवर्क बनाने वाले लोगों से संपर्क करें. कुछ मामलों में, Google आपकी मदद कर सकता है. हालांकि, इन अडैप्टर के लिए सहायता पाने का पहला विकल्प कम्यूनिटी है.

App Hosting फ़्रेमवर्क अडैप्टर

App Hosting में, पहले से कॉन्फ़िगर किए गए और कम्यूनिटी की ओर से सपोर्ट किए गए फ़्रेमवर्क, दोनों के लिए फ़्रेमवर्क अडैप्टर के ज़रिए सहायता दी जाती है. App Hosting फ़्रेमवर्क अडैप्टर की दो मुख्य भूमिकाएं होती हैं:

  • ये आपके सोर्स कोड और फ़्रेमवर्क के हिसाब से कॉन्फ़िगरेशन फ़ाइलों (जैसे कि next.config.js) को पार्स करते हैं. साथ ही, एक आउटपुट बंडल जनरेट करते हैं, जिसे App Hosting के बाकी इंफ़्रास्ट्रक्चर से प्रोसेस किया जा सकता है.
  • ये आपके ऐप्लिकेशन की बिल्ड कमांड चलाते हैं, ताकि स्टैटिक ऐसेट जनरेट की जा सकें. साथ ही, प्रोडक्शन के लिए आपके ऐप्लिकेशन का ऑप्टिमाइज़ किया गया वर्शन बनाया जा सके.

फ़्रेमवर्क अडैप्टर, npm run build की मदद से आपका Node.js ऐप्लिकेशन बनाते हैं. ये हर फ़्रेमवर्क के लिए डिफ़ॉल्ट बिल्ड स्क्रिप्ट के साथ सबसे अच्छी तरह काम करते हैं: Next.js के लिए next build और Angular के लिए ng build. App Hosting, कस्टम बिल्ड कमांड के साथ बिल्ड करने की कोशिश करेगा, लेकिन सफलता की गारंटी नहीं दे सकता. apphosting.yaml में बिल्ड और रन स्क्रिप्ट को बदला जा सकता है.

Next.js और Angular अडैप्टर का सोर्स, firebase-framework-tools में उपलब्ध है.

App Hosting के लिए रनटाइम

App Hosting के बनाए जाने और रोल आउट किए जाने के बाद, आपका Node.js ऐप्लिकेशन Cloud Run वर्शन में चलता है. इसलिए, आपके ऐप्लिकेशन के लिए रनटाइम वर्शन, Cloud Run के साथ काम करने वाले वर्शन और आपके चुने गए वेब फ़्रेमवर्क, दोनों की रेंज में होना चाहिए. Angular और Next.js के लिए पहले से कॉन्फ़िगर की गई सुविधा का मतलब है कि Node.js के इन वर्शन के साथ काम किया जा सकता है:

  • Next.js 13.5.x और इसके बाद के वर्शन
  • Angular 18.2.x और इसके बाद के वर्शन
  • Node.js 20 और उसके बाद के वर्शन

App Hosting, फ़्रेमवर्क के नए वर्शन के लिए अपने-आप सहायता उपलब्ध नहीं कराता. हमारे मौजूदा 'चालू' वर्शन से नए वर्शन को 'प्रीव्यू' स्थिति में माना जाएगा. ऐसा तब तक होगा, जब तक App Hosting के लिए आधिकारिक तौर पर उसे 'चालू' के तौर पर मार्क नहीं कर दिया जाता.

App Hosting, मुख्य रिलीज़ के सबसे नए माइनर वर्शन के लिए, लंबे समय तक सहायता (एलटीएस) देता है. यह सहायता, रिलीज़ के चालू रहने की अवधि के दौरान एक साल तक मिलती है. हालांकि, इसके लिए ज़रूरी है कि आप उस माइनर वर्शन में, पैच रिलीज़ को लगातार अपडेट करते रहें. Next.js और Angular के बारे में ज़्यादा जानकारी के लिए, यहां दी गई टेबल देखें.

Next.js के लिए सहायता पाने का शेड्यूल

वर्शन स्थिति बंद की गई सेवाएं/सुविधाएं
13.5.x lts 2026-10-9
14.2.x lts 2026-10-9
15.0.x सक्रिय 2025-10-9 से पहले नहीं
15.1.x सक्रिय 2025-10-9 से पहले नहीं
15.2.x सक्रिय -

ऐंगुलर के लिए सहायता पाने का शेड्यूल

वर्शन स्थिति बंद की गई सेवाएं/सुविधाएं
18.2.x lts 2026-10-9
19.0.x सक्रिय 2025-10-9 से पहले नहीं
19.1.x सक्रिय 2025-10-9 से पहले नहीं
19.2.x सक्रिय -

बुनियादी इमेज अपने-आप अपडेट होने की सुविधा (एबीआईयू)

बेस इमेज अपने-आप अपडेट होने की सुविधा (एबीआईयू) एक ऐसी सुविधा है जो आपके रनटाइम एनवायरमेंट में सुरक्षा पैच अपने-आप लागू करती है. इसके लिए, आपको ऐप्लिकेशन का नया वर्शन रोल आउट करने की ज़रूरत नहीं होती.

App Hosting डिफ़ॉल्ट रूप से, नए बैकएंड के लिए ABIU चालू करता है. इसके लिए, ये खास ज़रूरी शर्तें पूरी करनी होती हैं:

  • वर्शन वाले रनटाइम: ABIU का इस्तेमाल करने के लिए, आपको वर्शन वाला रनटाइम (जैसे कि nodejs20, nodejs22, nodejs24) तय करना होगा. App Hosting, Node.js के सम संख्या वाले वर्शन के साथ काम करता है. यह Cloud Run के साथ काम करने वाले वर्शन के जैसा ही है.
  • package.json मैच करना: App Hosting के लिए चुना गया Node का वर्शन, आपकी package.json फ़ाइल के engines फ़ील्ड में बताए गए वर्शन के साथ काम करना चाहिए. अगर कोई अंतर दिखता है, तो आपको Cloud Build से बिल्ड-टाइम की गड़बड़ी का मैसेज मिलेगा. engines फ़ील्ड में बदलाव करने पर, यह पक्का करें कि आपने डिप्लॉय करने से पहले, अपने बैकएंड के रनटाइम को अपडेट कर दिया हो.

ABIU को बंद करना

अगर आपको ABIU से ऑप्ट आउट करना है, तो शामिल होने के दौरान इसे बंद किया जा सकता है. इसके अलावा, Firebase कंसोल में जाकर, अपने रनटाइम के लिए "लागू नहीं" को चुनकर भी इसे बंद किया जा सकता है. वर्शन के बिना nodejs डिफ़ॉल्ट का इस्तेमाल करने पर, ABIU अपने-आप बंद हो जाता है.

रनटाइम वर्शन मैनेज करना

अपने App Hosting डैशबोर्ड के सेटिंग टैब में जाकर, बैकएंड के रनटाइम वर्शन और ABIU की प्राथमिकता को किसी भी समय देखा और बदला जा सकता है. हालांकि, ध्यान रखें कि अगर नया वर्शन आपके कोड के साथ काम नहीं करता है, तो रनटाइम वर्शन बदलने से आपका ऐप्लिकेशन काम करना बंद कर सकता है.

रनटाइम वर्शन के लिए, सहायता की लाइफ़साइकल खत्म हो जाती है. ब्रेकिंग चेंज से बचने के लिए, अपने रनटाइम को अपडेट रखना ज़रूरी है:

  • बंद किए गए रनटाइम: अगर चुना गया रनटाइम बंद कर दिया जाता है, तो आम तौर पर आपका ऐप्लिकेशन काम करता रहेगा. आपको कंसोल में एक चेतावनी मिलेगी. आपको जल्द से जल्द नए वर्शन पर स्विच करना चाहिए. ज़्यादा जानकारी के लिए, Cloud Run रनटाइम लाइफ़साइकल का दस्तावेज़ देखें.
  • बंद किए गए रनटाइम: बंद किए गए रनटाइम का इस्तेमाल नहीं किया जा सकता. बंद किए गए वर्शन का इस्तेमाल करके, नई बिल्ड या बैकएंड नहीं बनाए जा सकेंगे. ऐसा करने पर, बिल्ड से जुड़ी गड़बड़ी दिखेगी. बंद किए गए वर्शन पर चल रहे मौजूदा डिप्लॉयमेंट काम करना बंद कर सकते हैं. साथ ही, Cloud Run के पास उन्हें मिटाने का अधिकार है.

इस्तेमाल किए जा सकने वाले, इस्तेमाल नहीं किए जा सकने वाले, और बंद किए गए Node वर्शन की पूरी सूची देखने के लिए, Cloud Run रनटाइम सपोर्ट के बारे में जानकारी देने वाला दस्तावेज़ पढ़ें. बेस इमेज के अपडेट कैसे काम करते हैं, इस बारे में ज़्यादा तकनीकी जानकारी पाने के लिए, Cloud Run ABIU के बारे में जानकारी देने वाला दस्तावेज़ पढ़ें.

पैकेज मैनेजर

App Hosting, डिपेंडेंसी इंस्टॉल करने के लिए Cloud Native Buildpacks का इस्तेमाल करता है. साथ ही, npm, yarn या pnpm का इस्तेमाल करके ऐप्लिकेशन बनाता है. JSR जैसे अन्य पैकेज मैनेजर काम नहीं करते.

एनपीएम

  • NPM, डिफ़ॉल्ट पैकेज मैनेजर होता है.
  • बिल्ड पूरा होने के बाद, नॉन-प्रोडक्शन डिपेंडेंसी को हटा दिया जाता है.
  • अपनी package.json फ़ाइल में मौजूद engines.npm फ़ील्ड का इस्तेमाल करके, npm वर्शन सेक्शन के बारे में जानकारी दी जा सकती है.

ऊन

  • अपने प्रोजेक्ट में yarn.lock फ़ाइल शामिल करने पर, Yarn का इस्तेमाल किया जाता है.
  • package.json फ़ाइल के engines.yarn या packageManager फ़ील्ड में इस्तेमाल किए जाने वाले यार्न के वर्शन के बारे में बताया जा सकता है.
  • App Hosting, Yarn2 PnP मोड के साथ काम करता है.

Pnpm

  • अपने प्रोजेक्ट में pnpm-lock.yaml फ़ाइल शामिल करने पर, Pnpm का इस्तेमाल किया जाता है.
  • अपनी package.json फ़ाइल के engines.pnpm या packageManager फ़ील्ड में, pnpm के किसी वर्शन की जानकारी दी जा सकती है.
  • काम करने वाले उदाहरण के लिए, sample-node-pnpm देखें. ऐप्लिकेशन.

App Hosting के लिए मोनो रिपॉज़िटरी

App Hosting, Nx पर आधारित ऐप्लिकेशन के साथ काम करता है. ज़्यादा जानकारी के लिए, App Hosting के साथ मोनोरिपो इस्तेमाल करना लेख पढ़ें.

Nx के इन वर्शन के साथ काम करता है:

वर्शन स्थिति बंद की गई सेवाएं/सुविधाएं
19.5.x रखरखाव 2025-10-9
19.6.x रखरखाव 2025-10-9
19.7.x रखरखाव 2025-10-9
19.8.x lts 2026-10-9
20.0.x सक्रिय 2025-10-9 से पहले नहीं
20.1.x सक्रिय 2025-10-9 से पहले नहीं
20.2.x सक्रिय 2025-10-9 से पहले नहीं
20.3.x सक्रिय 2025-10-9 से पहले नहीं
20.4.x सक्रिय 2025-10-9 से पहले नहीं
20.5.x सक्रिय 2025-10-9 से पहले नहीं
20.6.x सक्रिय 2025-10-9 से पहले नहीं
20.7.x सक्रिय

अगर आपको अन्य तरह के मोनोरिपो वर्कस्पेस के लिए सहायता चाहिए, तो हमें Firebase UserVoice पर बताएं.