परफ़ॉर्मेंस बजट सेट करने के लिए, Lighthouse बॉट का इस्तेमाल करना

आपने तेज़ी से लोड होने के लिए ज़रूरी कदम उठाए हैं. अब Lighthouse Bot की मदद से, परफ़ॉर्मेंस की जांच को ऑटोमेट करके पक्का करें कि आपका ऐप्लिकेशन तेज़ी से लोड होता रहे.

Lighthouse आपके ऐप्लिकेशन को पांच कैटगरी में ग्रेड करता है और उनमें से एक कैटगरी है, परफ़ॉर्मेंस. कोड में बदलाव करने के बाद, DevTools या Lighthouse CLI की मदद से, परफ़ॉर्मेंस में हुए बदलावों को मॉनिटर करना याद रखें. हालांकि, ऐसा करना ज़रूरी नहीं है. टूल आपके लिए मुश्किल काम कर सकते हैं. Travis CI एक बेहतरीन सेवा है. यह हर बार नया कोड पुश करने पर, क्लाउड में आपके ऐप्लिकेशन की जांच अपने-आप करती है.

Lighthouse Bot, Travis CI के साथ इंटिग्रेट होता है. साथ ही, इसकी परफ़ॉर्मेंस बजट की सुविधा से यह पक्का होता है कि आपने अनजाने में परफ़ॉर्मेंस को डाउनग्रेड न कर दिया हो. अपनी रिपॉज़िटरी को कॉन्फ़िगर किया जा सकता है, ताकि अगर Lighthouse का स्कोर आपके तय किए गए थ्रेशोल्ड (उदाहरण के लिए, 96/100 से कम) से नीचे चला जाए, तो वह पुल-रिक्वेस्ट को मर्ज करने की अनुमति न दे.

GitHub पर लाइटहाउस बॉट की जांच में फ़ेल होना
GitHub पर Lighthouse बॉट की जांच.

हालांकि, localhost पर परफ़ॉर्मेंस की जांच की जा सकती है, लेकिन लाइव सर्वर पर आपकी साइट अक्सर अलग तरह से परफ़ॉर्म करती है. ज़्यादा सटीक जानकारी पाने के लिए, अपनी साइट को स्टैजिंग सर्वर पर डिप्लॉय करना सबसे अच्छा होता है. किसी भी होस्टिंग सेवा का इस्तेमाल किया जा सकता है. इस गाइड में, Firebase होस्टिंग के बारे में बताया गया है.

1. सेटअप

इस आसान ऐप्लिकेशन की मदद से, तीन नंबरों को क्रम से लगाया जा सकता है.

GitHub से उदाहरण को क्लोन करें और पक्का करें कि आपने इसे अपने GitHub खाते में रिपॉज़िटरी के तौर पर जोड़ा हो.

2. Firebase पर डिप्लॉय करना

शुरू करने के लिए, आपके पास Firebase खाता होना चाहिए. इसके बाद, "प्रोजेक्ट जोड़ें" पर क्लिक करके, Firebase कंसोल में नया प्रोजेक्ट बनाएं:

Firebase पर डिप्लॉय करना

ऐप्लिकेशन को डिप्लॉय करने के लिए, आपके पास Firebase CLI होना चाहिए. भले ही, आपने इसे पहले से ही इंस्टॉल कर लिया हो, लेकिन इस निर्देश का इस्तेमाल करके, सीएलआई को नए वर्शन पर अपडेट करना अच्छा होता है:

npm install -g firebase-tools

Firebase सीएलआई को अनुमति देने के लिए, यह तरीका अपनाएं:

firebase login

अब प्रोजेक्ट को शुरू करें:

firebase init

सेटअप के दौरान, Console आपसे कई सवाल पूछेगा:

  • सुविधाएं चुनने के लिए कहा जाने पर, "होस्टिंग" चुनें.
  • डिफ़ॉल्ट Firebase प्रोजेक्ट के लिए, वह प्रोजेक्ट चुनें जिसे आपने Firebase कंसोल में बनाया है.
  • अपनी सार्वजनिक डायरेक्ट्री के तौर पर "सार्वजनिक" टाइप करें.
  • एक पेज वाले ऐप्लिकेशन के तौर पर कॉन्फ़िगर करने के लिए, "N" (नहीं) टाइप करें.

इस प्रोसेस से, आपकी प्रोजेक्ट डायरेक्ट्री की रूट में firebase.json कॉन्फ़िगरेशन फ़ाइल बनती है.

बधाई हो, अब आपके पास डिप्लॉय करने का विकल्प है! चलाएं:

firebase deploy

कुछ ही सेकंड में, आपके पास लाइव ऐप्लिकेशन होगा.

3. ट्रैविस को सेट अप करना

आपको Travis पर एक खाता रजिस्टर करना होगा और फिर अपनी प्रोफ़ाइल के सेटिंग सेक्शन में GitHub Apps इंटिग्रेशन को चालू करना होगा.

Travis CI पर GitHub ऐप्लिकेशन का इंटिग्रेशन

खाता बनाने के बाद

अपनी प्रोफ़ाइल में जाकर सेटिंग पर जाएं. इसके बाद, 'खाता सिंक करें' बटन पर क्लिक करें. साथ ही, पक्का करें कि आपके प्रोजेक्ट का रिपॉज़िटरी, Travis पर मौजूद हो.

लगातार इंटिग्रेशन की सुविधा शुरू करने के लिए, आपको इन दो चीज़ों की ज़रूरत होगी:

  1. रूट डायरेक्ट्री में .travis.yml फ़ाइल हो
  2. सामान्य रूप से पुराना गिट पुश करके बिल्ड ट्रिगर करने के लिए

lighthouse-bot-starter repo में पहले से ही .travis.yml YAML फ़ाइल मौजूद है:

language: node_js
node_js:
  - "8.1.3"
install:
  - npm install
before_script:
  - npm install -g firebase-tools
script:
  - webpack

YAML फ़ाइल, Travis को सभी डिपेंडेंसी इंस्टॉल करने और आपके ऐप्लिकेशन को बनाने के लिए कहती है. अब आपको उदाहरण के तौर पर दिए गए ऐप्लिकेशन को अपनी GitHub रिपॉज़िटरी में पुश करना है. अगर आपने पहले से ऐसा नहीं किया है, तो नीचे दिया गया निर्देश चलाएं:

git push origin main

अपने प्रोजेक्ट का Travis डैशबोर्ड देखने के लिए, Travis में सेटिंग में जाकर अपने repo पर क्लिक करें. अगर सब कुछ ठीक है, तो आपको कुछ ही मिनटों में अपना बिल्ड पीले से हरे रंग में बदला हुआ दिखेगा. 🎉

4. Travis की मदद से Firebase डिप्लॉयमेंट को ऑटोमेट करें

दूसरे चरण में, आपने अपने Firebase खाते में लॉग इन किया और firebase deploy की मदद से, कमांड लाइन से ऐप्लिकेशन को डिप्लॉय किया. Travis को आपके ऐप्लिकेशन को Firebase पर डिप्लॉय करने के लिए, आपको अनुमति देनी होगी. आपको ऐसा कैसे करना है? Firebase टोकन की मदद से. 🗝️🔥

Firebase को अनुमति देना

टोकन जनरेट करने के लिए, यह कमांड चलाएं:

firebase login:ci

इससे ब्राउज़र विंडो में एक नया टैब खुलेगा, ताकि Firebase आपकी पहचान की पुष्टि कर सके. इसके बाद, कंसोल पर वापस जाएं और आपको अपना नया टोकन दिखेगा. इसे कॉपी करें और Travis पर वापस जाएं.

अपने प्रोजेक्ट के Travis डैशबोर्ड में, ज़्यादा विकल्प > सेटिंग > एनवायरमेंट वैरिएबल पर जाएं.

टोकन को वैल्यू फ़ील्ड में चिपकाएं, वैरिएबल को FIREBASE_TOKEN नाम दें, और उसे जोड़ें.

अपने Travis सेटअप में डिप्लॉयमेंट जोड़ना

हर सफल बिल्ड के बाद ट्रैविस को ऐप्लिकेशन डिप्लॉय करने के लिए कहने के लिए, आपको इन लाइनों की ज़रूरत होगी. उन्हें .travis.yml फ़ाइल के आखिर में जोड़ें. 🔚

after_success:
  - firebase deploy --token $FIREBASE_TOKEN --non-interactive

इस बदलाव को GitHub पर पॉश करें और अपने-आप डिप्लॉय होने की सुविधा के पहली बार लागू होने का इंतज़ार करें. Travis लॉग में जाकर, आपको जल्द ही यह मैसेज दिखेगा: ✔️ डिप्लॉय हो गया!

अब जब भी अपने ऐप्लिकेशन में बदलाव किए जाएंगे, तो वे Firebase में अपने-आप डिप्लॉय हो जाएंगे.

5. Lighthouse Bot सेट अप करना

लाइटहाउस बॉट, आपको अपने ऐप्लिकेशन के लाइटहाउस स्कोर के बारे में अपडेट देता है. इसके लिए, आपको अपने रिपॉज़िटरी का न्योता देना होगा.

GitHub पर, अपने प्रोजेक्ट की सेटिंग में जाएं और "lighthousebot" को सहयोगी के तौर पर जोड़ें (सेटिंग>सहयोगी):

Lighthouse बॉट के साथ काम करने वाले लोगों का स्टेटस

इन अनुरोधों को स्वीकार करने की प्रोसेस मैन्युअल होती है. इसलिए, ये अनुरोध हमेशा तुरंत स्वीकार नहीं किए जाते. टेस्टिंग शुरू करने से पहले, पक्का करें कि housebot ने कोलैबर के तौर पर अपने स्टेटस को मंज़ूरी दी है. इस दौरान, आपको Travis पर अपने प्रोजेक्ट के एनवायरमेंट वैरिएबल में एक और कुंजी भी जोड़नी होगी. अपना ईमेल पता यहां डालें, तो आपको अपने इनबॉक्स में Lighthouse Bot की कुंजी मिल जाएगी. 📬

Travis पर, इस कुंजी को एनवायरमेंट वैरिएबल के तौर पर जोड़ें और इसका नाम LIGHTHOUSE_API_KEY रखें:

अपने प्रोजेक्ट में Lighthouse Bot जोड़ना

इसके बाद, अपने प्रोजेक्ट में Lighthouse Bot जोड़ने के लिए, यह तरीका अपनाएं:

npm i --save-dev https://github.com/ebidel/lighthousebot

और package.json में यह बिट जोड़ें:

"scripts": {
  "lh": "lighthousebot"
}

अपने Travis कॉन्फ़िगरेशन में Lighthouse Bot जोड़ना

आखिरी तरकीब के तौर पर, हर पुल अनुरोध के बाद ऐप्लिकेशन की परफ़ॉर्मेंस की जांच करें!

.travis.yml में, after_success में एक और चरण जोड़ें:

after_success:
  - firebase deploy --token $FIREBASE_TOKEN --non-interactive
  - npm run lh -- https://staging.example.com

यह दिए गए यूआरएल पर Lighthouse ऑडिट चलाएगा. इसलिए, https://staging.example.com को अपने ऐप्लिकेशन के यूआरएल (यानी your-app-123.firebaseapp.com) से बदलें.

अपने स्टैंडर्ड ऊंचे रखें और सेटअप में बदलाव करें, ताकि ऐप्लिकेशन में ऐसे कोई भी बदलाव न किया जाए जिससे परफ़ॉर्मेंस स्कोर 95 से कम हो जाए:

- npm run lh -- --perf=95 https://staging.example.com

Travis पर लाइटहाउस बॉट टेस्ट को ट्रिगर करने के लिए, पुश अनुरोध करें

Lighthouse Bot सिर्फ़ पुश अनुरोधों की जांच करेगा. इसलिए, अगर अब मुख्य शाखा पर पुश किया जाता है, तो आपको अपने Travis लॉग में सिर्फ़ "यह स्क्रिप्ट सिर्फ़ Travis के अनुरोधों पर चलाई जा सकती है" दिखेगा.

Lighthouse बॉट टेस्ट को ट्रिगर करने के लिए:

  1. नई ब्रांच देखें
  2. इसे GitHub में भेजें
  3. पुल का अनुरोध करना

पुश अनुरोध वाले पेज पर इंतज़ार करें और लाइटहाउस बॉट के गाना गाने का इंतज़ार करें! 🎤

लाइटहाउस के पासिंग स्कोर

GitHub की जांच पास करना

परफ़ॉर्मेंस का स्कोर बेहतरीन है, ऐप्लिकेशन का बजट कम है, और जांच पूरी हो गई है!

लाइटहाउस के ज़्यादा विकल्प

याद है कि Lighthouse, पांच अलग-अलग कैटगरी की जांच कैसे करता है? Lighthouse बॉट फ़्लैग वाले किसी भी साइट के लिए, स्कोर लागू किए जा सकते हैं:

--perf  # performance
--pwa   # progressive web app score
--a11y  # accessibility score
--bp    # best practices score
--seo   # SEO score

उदाहरण:

npm run lh -- --perf=93 --seo=100 https://staging.example.com

अगर परफ़ॉर्मेंस स्कोर 93 से कम हो जाता है या एसईओ स्कोर 100 से कम हो जाता है, तो प्रॉडक्ट को प्रमोशन नहीं मिलेगा.

आपके पास --no-comment विकल्प का इस्तेमाल करके, लाइटहाउस बॉट की टिप्पणियां न पाने का विकल्प भी है.