1. परिचय
इस लैब में, आपको सामान्य ज्ञान के क्विज़ जनरेट करने के लिए एक वेब सेवा बनानी है. साथ ही, इसे मज़ेदार और काम करने वाले ऐप्लिकेशन में इंटिग्रेट करना है. इसके लिए, आपको ऐसी प्रोग्रामिंग भाषा का इस्तेमाल करना होगा जिसका इस्तेमाल आपने पहले कभी नहीं किया होगा: अंग्रेज़ी!
आपको क्या करना होगा...
- आपको एक ऐसा प्रॉम्प्ट बनाना होगा जो शर्तों के एक सेट के मुताबिक, सामान्य ज्ञान का क्विज़ जनरेट करे.
- आपको एक सामान्य वेब ऐप्लिकेशन बनाना होगा. साथ ही, यह पुष्टि करनी होगी कि वह आपके डेवलपमेंट एनवायरमेंट में उम्मीद के मुताबिक काम कर रहा है.
- आपको अपने वेब ऐप्लिकेशन में लॉजिक जोड़ना होगा, ताकि उसे एपीआई सर्वर में बदला जा सके. यह सर्वर, इनपुट पैरामीटर के सेट के हिसाब से क्विज़ जनरेट करता है.
- आपको पता चलेगा कि Google Cloud Run का इस्तेमाल करके, क्विज़ जनरेट करने की सेवा को क्लाउड पर डिप्लॉय करना कितना आसान है.
- आखिर में, आपको एक असली ऐप्लिकेशन ( quizaic.com) को कॉन्फ़िगर करना होगा, ताकि वह आपकी डिप्लॉय की गई क्विज़ जनरेटर सेवा का इस्तेमाल कर सके. इसके बाद, आपको आउटपुट के आधार पर लाइव क्विज़ खेलने का विकल्प मिलेगा.
आपको यह जानकारी मिलेगी...
- लार्ज लैंग्वेज मॉडल (एलएलएम) के लिए, टेंप्लेट वाला प्रॉम्प्ट कैसे बनाएं.
- Python में एक सामान्य वेब सर्वर ऐप्लिकेशन बनाने का तरीका.
- अपने वेब ऐप्लिकेशन में Google के एलएलएम के लिए सहायता कैसे जोड़ें.
- अपने ऐप्लिकेशन को क्लाउड पर डिप्लॉय करने का तरीका, ताकि कोई भी व्यक्ति आपकी नई क्रिएशन को आज़मा सके.
- क्विज़ जनरेट करने वाले टूल को किसी बड़े ऐप्लिकेशन में इंटिग्रेट करने का तरीका.
आपको इन चीज़ों की ज़रूरत होगी...
- Chrome वेब ब्राउज़र
- Google खाता
- ऐसा Cloud प्रोजेक्ट जिसमें बिलिंग की सुविधा चालू हो
यह लैब, सभी लेवल के डेवलपर के लिए है. इसमें शुरुआती डेवलपर भी शामिल हैं. हालांकि, आपको Python का इस्तेमाल करना होगा, लेकिन इसके लिए आपको Python प्रोग्रामिंग के बारे में जानकारी होना ज़रूरी नहीं है. ऐसा इसलिए, क्योंकि हम आपको दिखने वाले सभी कोड के बारे में बताएंगे.
2. सेटअप

इस सेक्शन में, इस लैब को शुरू करने के लिए ज़रूरी सभी चरणों के बारे में बताया गया है.
अपने हिसाब से एनवायरमेंट सेट अप करना
- Google Cloud Console में साइन इन करें और नया प्रोजेक्ट बनाएं या किसी मौजूदा प्रोजेक्ट का फिर से इस्तेमाल करें. अगर आपके पास पहले से कोई Gmail या Google Workspace खाता नहीं है, तो आपको एक खाता बनाना होगा.



- प्रोजेक्ट का नाम, इस प्रोजेक्ट में हिस्सा लेने वाले लोगों के लिए डिसप्ले नेम होता है. यह एक वर्ण स्ट्रिंग है, जिसका इस्तेमाल Google API नहीं करते. इसे कभी भी अपडेट किया जा सकता है.
- प्रोजेक्ट आईडी, सभी Google Cloud प्रोजेक्ट के लिए यूनीक होता है. साथ ही, इसे बदला नहीं जा सकता. Cloud Console, यूनीक स्ट्रिंग को अपने-आप जनरेट करता है. आम तौर पर, आपको इससे कोई फ़र्क़ नहीं पड़ता कि यह क्या है. ज़्यादातर कोडलैब में, आपको अपने प्रोजेक्ट आईडी (आम तौर पर
PROJECT_IDके तौर पर पहचाना जाता है) का रेफ़रंस देना होगा. अगर आपको जनरेट किया गया आईडी पसंद नहीं है, तो कोई दूसरा रैंडम आईडी जनरेट किया जा सकता है. इसके अलावा, आपके पास अपना नाम आज़माने का विकल्प भी है. इससे आपको पता चलेगा कि वह नाम उपलब्ध है या नहीं. इस चरण के बाद, इसे बदला नहीं जा सकता. यह प्रोजेक्ट की अवधि तक बना रहता है. - आपकी जानकारी के लिए बता दें कि एक तीसरी वैल्यू भी होती है, जिसे प्रोजेक्ट नंबर कहते हैं. इसका इस्तेमाल कुछ एपीआई करते हैं. इन तीनों वैल्यू के बारे में ज़्यादा जानने के लिए, दस्तावेज़ देखें.
- इसके बाद, आपको Cloud Console में बिलिंग चालू करनी होगी, ताकि Cloud संसाधनों/एपीआई का इस्तेमाल किया जा सके. इस कोडलैब को पूरा करने में ज़्यादा समय नहीं लगेगा. इस ट्यूटोरियल के बाद बिलिंग से बचने के लिए, संसाधनों को बंद किया जा सकता है. इसके लिए, बनाए गए संसाधनों को मिटाएं या प्रोजेक्ट को मिटाएं. Google Cloud के नए उपयोगकर्ताओं को, 300 डॉलर का क्रेडिट मिलेगा. वे इसे मुफ़्त में आज़मा सकते हैं.
Cloud Shell शुरू करें
इस लैब में, आपको Cloud Shell सेशन में काम करना होगा. यह एक कमांड इंटरप्रेटर है, जिसे Google के क्लाउड में चल रही वर्चुअल मशीन होस्ट करती है. इस सेक्शन को अपने कंप्यूटर पर भी आसानी से चलाया जा सकता है. हालांकि, Cloud Shell का इस्तेमाल करने से, सभी लोगों को एक जैसे एनवायरमेंट में एक जैसा अनुभव मिलता है. लैब के बाद, अपने कंप्यूटर पर इस सेक्शन को फिर से आज़माया जा सकता है.

Cloud Shell चालू करें
- Cloud Console में, Cloud Shell चालू करें
पर क्लिक करें.

अगर आपने Cloud Shell को पहली बार शुरू किया है, तो आपको एक इंटरमीडिएट स्क्रीन दिखेगी. इसमें Cloud Shell के बारे में जानकारी दी गई होगी. अगर आपको इंटरमीडिएट स्क्रीन दिखती है, तो जारी रखें पर क्लिक करें.

Cloud Shell से कनेक्ट होने में कुछ ही सेकंड लगेंगे.

इस वर्चुअल मशीन में, डेवलपमेंट के लिए ज़रूरी सभी टूल पहले से मौजूद हैं. यह 5 जीबी की होम डायरेक्ट्री उपलब्ध कराता है, जो हमेशा बनी रहती है. साथ ही, यह Google Cloud में काम करता है. इससे नेटवर्क की परफ़ॉर्मेंस और पुष्टि करने की प्रोसेस बेहतर होती है. इस कोडलैब में ज़्यादातर काम ब्राउज़र से किया जा सकता है.
Cloud Shell से कनेक्ट होने के बाद, आपको दिखेगा कि आपकी पुष्टि हो गई है और प्रोजेक्ट को आपके प्रोजेक्ट आईडी पर सेट कर दिया गया है.
- पुष्टि करें कि आपने Cloud Shell में पुष्टि कर ली है. इसके लिए, यह कमांड चलाएं:
gcloud auth list
कमांड आउटपुट
Credentialed Accounts
ACTIVE ACCOUNT
* <my_account>@<my_domain.com>
To set the active account, run:
$ gcloud config set account `ACCOUNT`
- यह पुष्टि करने के लिए कि gcloud कमांड को आपके प्रोजेक्ट के बारे में पता है, Cloud Shell में यह कमांड चलाएं:
gcloud config list project
कमांड आउटपुट
[core] project = <PROJECT_ID>
अगर ऐसा नहीं है, तो इस कमांड का इस्तेमाल करके इसे सेट किया जा सकता है:
gcloud config set project <PROJECT_ID>
कमांड आउटपुट
Updated property [core/project].
कुछ एपीआई चालू करना
बाद के चरणों में, आपको पता चलेगा कि इन सेवाओं की ज़रूरत कहां है और क्यों. हालांकि, फ़िलहाल इस कमांड को चलाकर, अपने प्रोजेक्ट को Cloud Build, Artifact Registry, Vertex AI, और Cloud Run का ऐक्सेस दें:
gcloud services enable cloudbuild.googleapis.com \
artifactregistry.googleapis.com \
aiplatform.googleapis.com \
run.googleapis.com
इससे आपको इस तरह का मैसेज मिलेगा:
Operation "operations/acf.cc11852d-40af-47ad-9d59-477a12847c9e" finished successfully.
3. प्रॉम्प्ट करना - नैचुरल लैंग्वेज में प्रोग्रामिंग करना

हम लार्ज लैंग्वेज मॉडल के लिए प्रॉम्प्ट बनाने का तरीका सीखेंगे. Google Cloud Console > Vertex AI > Vertex AI Studio (Language) पर जाएं. आपको इस तरह का पेज दिखेगा:

Generate Text में जाकर, Text Prompt बटन पर क्लिक करें. अगले डायलॉग बॉक्स में, ऐसा प्रॉम्प्ट डालें जो इन ज़रूरी शर्तों के हिसाब से, सामान्य ज्ञान से जुड़ा क्विज़ जनरेट करने के लिए असरदार हो:
- विषय: विश्व का इतिहास
- सवालों की संख्या: 5
- कठिनाई का लेवल: इंटरमीडिएट
- भाषा: अंग्रेज़ी
आउटपुट देखने के लिए, 'सबमिट करें' बटन पर क्लिक करें.
नीचे दिए गए स्क्रीनशॉट में दिखाया गया है कि दाईं ओर मौजूद पैनल में, आपके पास यह चुनने का विकल्प होता है कि आपको कौनसे मॉडल का इस्तेमाल करना है. साथ ही, कुछ सेटिंग को बेहतर बनाने का विकल्प भी होता है:

निम्न सेटिंग उपलब्ध हैं:
- रीजन वह जगह है जहां जनरेट करने का अनुरोध किया जाना चाहिए.
- मॉडल से यह चुना जाता है कि आपको कौनसा लार्ज लैंग्वेज मॉडल इस्तेमाल करना है. इस कोडलैब के लिए, "gemini-1.0-pro-001" का इस्तेमाल करें.
- टेंपरेचर से यह तय होता है कि टोकन को कितनी बार रैंडम तरीके से चुना जाएगा. कम तापमान उन प्रॉम्प्ट के लिए अच्छा होता है जिनके लिए सही जवाब की ज़रूरत होती है. वहीं, ज़्यादा तापमान से अलग-अलग या अनचाहे नतीजे मिल सकते हैं.
- टोकन की सीमा से यह तय होता है कि एक प्रॉम्प्ट से ज़्यादा से ज़्यादा कितना टेक्स्ट आउटपुट किया जा सकता है. एक टोकन में करीब चार वर्ण होते हैं. डिफ़ॉल्ट वैल्यू 1024 है.
- टॉप-k से यह तय होता है कि मॉडल, आउटपुट के लिए टोकन कैसे चुनता है. टॉप-k की वैल्यू 1 होने का मतलब है कि चुना गया टोकन, मॉडल की शब्दावली में मौजूद सभी टोकन में से सबसे ज़्यादा संभावित है. इसे ग्रीडी डिकोडिंग भी कहा जाता है. वहीं, टॉप-k की वैल्यू 3 होने का मतलब है कि अगला टोकन, सबसे ज़्यादा संभावित तीन टोकन में से चुना गया है. इसके लिए, तापमान का इस्तेमाल किया जाता है. टॉप-के की डिफ़ॉल्ट वैल्यू 40 होती है.
- टॉप-पी, मॉडल के आउटपुट के लिए टोकन चुनने के तरीके में बदलाव करता है. टोकन को सबसे ज़्यादा से लेकर सबसे कम संभावना के हिसाब से चुना जाता है. ऐसा तब तक किया जाता है, जब तक उनकी संभावनाओं का योग टॉप-पी वैल्यू के बराबर न हो जाए.
- जवाबों की ज़्यादा से ज़्यादा संख्या का मतलब है कि हर प्रॉम्प्ट के लिए, मॉडल के ज़्यादा से ज़्यादा कितने जवाब जनरेट किए जा सकते हैं.
- स्टॉप सीक्वेंस, वर्णों (इनमें स्पेस भी शामिल हैं) की एक सीरीज़ होती है. अगर मॉडल को यह सीरीज़ मिलती है, तो वह जवाब जनरेट करना बंद कर देता है.
- 'जवाबों को रीयल टाइम में देखना' सुविधा से यह चुना जाता है कि जवाब जनरेट होते ही दिखाए जाएँ या पूरा जवाब तैयार होने के बाद दिखाया जाए.
- सेफ़्टी फ़िल्टर के थ्रेशोल्ड से यह तय होता है कि आपको ऐसे जवाब कितनी बार दिखेंगे जो नुकसान पहुंचा सकते हैं.
जब आपके पास ऐसा प्रॉम्प्ट हो जो ऊपर बताई गई ज़रूरी शर्तों के हिसाब से सही क्विज़ जनरेट करता हो, तो हम कस्टम कोड का इस्तेमाल करके इस क्विज़ को पार्स कर सकते हैं. हालांकि, क्या यह बेहतर नहीं होगा कि एलएलएम, क्विज़ को ऐसे स्ट्रक्चर्ड फ़ॉर्मैट में जनरेट करे जिसे हम सीधे अपने प्रोग्राम में लोड कर सकें? इस लैब में हम बाद में जिस प्रोग्राम का इस्तेमाल करेंगे वह आपके जनरेटर को कॉल करेगा. इसके लिए, क्विज़ को JSON फ़ॉर्मैट में दिखाना होगा. यह स्ट्रक्चर्ड डेटा को दिखाने के लिए, अलग-अलग भाषाओं में इस्तेमाल किया जाने वाला एक लोकप्रिय फ़ॉर्मैट है.
इस लैब में क्विज़ को ऑब्जेक्ट की कैटगरी के तौर पर दिखाया गया है. इसमें हर ऑब्जेक्ट में एक सवाल, उस सवाल के संभावित जवाबों की कैटगरी, और सही जवाब शामिल होता है. इस लैब में क्विज़ के लिए JSON एन्कोडिंग यहां दी गई है:
[
{
"question": "Who was the first person to walk on the moon?",
"responses": [
"Neil Armstrong",
"Buzz Aldrin",
"Michael Collins",
"Yuri Gagarin"
],
"correct": "Neil Armstrong"
},
{
"question": "What was the name of the war that took place between the British and the French in North America from 1754 to 1763??",
"responses": [
"The French and Indian War",
"The Seven Years' War",
"The War of the Austrian Succession",
"The Great War"
],
"correct": "The French and Indian War"
},
...
]
देखें कि क्या अब क्विज़ को ज़रूरी JSON फ़ॉर्मैट में आउटपुट करने के लिए, अपने प्रॉम्प्ट में बदलाव किया जा सकता है.
- आपको जिस फ़ॉर्मैट में जवाब चाहिए उसके बारे में शब्दों में बताएं. उदाहरण के लिए, ऊपर इटैलिक किया गया वाक्य.
- अपने प्रॉम्प्ट में, JSON फ़ॉर्मैट का कोई उदाहरण शामिल करें.
अपनी ज़रूरत के हिसाब से क्विज़ जनरेट करने वाला प्रॉम्प्ट मिलने के बाद, पेज के सबसे ऊपर दाएं कोने में मौजूद GET CODE बटन पर क्लिक करें. इससे आपको Python कोड दिखेगा. इस कोड का इस्तेमाल करके, अपने प्रॉम्प्ट को Vertex AI LLM में प्रोग्राम के हिसाब से सबमिट किया जा सकता है. अगर आपको Python के अलावा किसी दूसरी प्रोग्रामिंग भाषा का इस्तेमाल करना है, तो https://cloud.google.com/vertex-ai/docs/samples?text=generative पर जाएं.
4. एक सामान्य वेब सर्वर बनाना

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

इसके बाद, आपको Visual Studio Code जैसे IDE एनवायरमेंट में ले जाया जाएगा. यहां प्रोजेक्ट बनाए जा सकते हैं, सोर्स कोड में बदलाव किया जा सकता है, प्रोग्राम चलाए जा सकते हैं वगैरह.
अगर आपकी स्क्रीन पर जगह कम है, तो कंसोल और आपकी बदलाव/टर्मिनल विंडो के बीच की लाइन को बड़ा या छोटा किया जा सकता है. इसके लिए, इन दोनों हिस्सों के बीच मौजूद हॉरिज़ॉन्टल बार को खींचें. इसे यहां हाइलाइट किया गया है:

Open Editor और Open Terminal बटन पर क्लिक करके, एडिटर और टर्मिनल के बीच स्विच किया जा सकता है. अब इन दोनों एनवायरमेंट के बीच स्विच करके देखें.
इसके बाद, एक फ़ोल्डर बनाएं. इसमें आपको इस लैब के लिए अपना काम सेव करना है. इसके लिए, फ़ोल्डर जोड़ें बटन
पर क्लिक करें, quiz-generator डालें, और Enter दबाएं. इस लैब में बनाई गई सभी फ़ाइलें और Cloud Shell में किया गया सारा काम, इसी फ़ोल्डर में सेव होगा.
अब एक requirements.txt फ़ाइल बनाएं. इससे Python को पता चलता है कि आपका ऐप्लिकेशन किन लाइब्रेरी पर निर्भर करता है. इस सामान्य वेब ऐप्लिकेशन के लिए, आपको वेब सर्वर बनाने के लिए Python के एक लोकप्रिय मॉड्यूल का इस्तेमाल करना होगा. इसे Flask, google-cloud-aiplatform क्लाइंट लाइब्रेरी कहा जाता है. साथ ही, आपको gunicorn नाम के वेब सर्वर फ़्रेमवर्क का इस्तेमाल करना होगा. फ़ाइल नेविगेशन पैन में, quiz-generator फ़ोल्डर पर राइट क्लिक करें और New file मेन्यू आइटम चुनें. जैसे:

जब आपसे नई फ़ाइल का नाम पूछा जाए, तब requirements.txt डालें और Enter दबाएं. पक्का करें कि नई फ़ाइल, quiz-generator प्रोजेक्ट फ़ोल्डर में सेव हो.
नई फ़ाइल में यहां दी गई लाइनों को चिपकाएं. इससे यह पता चलेगा कि आपका ऐप्लिकेशन, Python के flask पैकेज, gunicorn वेब सर्वर, और google-cloud-aiplatform क्लाइंट लाइब्रेरी पर निर्भर करता है. साथ ही, इससे हर लाइब्रेरी के वर्शन के बारे में भी पता चलेगा.
flask==3.0.0 gunicorn==21.2.0 google-cloud-aiplatform==1.47.0
आपको इस फ़ाइल को सेव करने की ज़रूरत नहीं है, क्योंकि Cloud Editor आपके लिए बदलावों को अपने-आप सेव कर देगा.
इसी तरीके का इस्तेमाल करके, main.py नाम की एक और नई फ़ाइल बनाएं. यह आपके ऐप्लिकेशन की मुख्य (और एकमात्र) Python सोर्स फ़ाइल होगी. फिर से, पक्का करें कि नई फ़ाइल quiz-generator फ़ोल्डर में सेव हो.
इस फ़ाइल में यह कोड डालें:
from flask import Flask
import os
app = Flask(__name__) # Create a Flask object.
PORT = os.environ.get("PORT") # Get PORT setting from environment.
if not PORT:
PORT = 8080
# The app.route decorator routes any GET requests sent to the root path
# to this function, which responds with a "Hello world!" HTML document.
@app.route("/", methods=["GET"])
def say_hello():
html = "<h1>Hello world!</h1>"
return html
# This code ensures that your Flask app is started and listens for
# incoming connections on the local interface and port 8080.
if __name__ == "__main__":
app.run(host="0.0.0.0", port=PORT)
टर्मिनल पर वापस जाएं और इस कमांड का इस्तेमाल करके, प्रोजेक्ट फ़ोल्डर में जाएं:
cd quiz-generator
अपने प्रोजेक्ट की डिपेंडेंसी इंस्टॉल करने के लिए, यह कमांड चलाएं:
pip3 install -r requirements.txt
डिपेंडेंसी इंस्टॉल करने के बाद, आपको ऐसा आउटपुट दिखेगा:
Successfully installed flask-3.0.0
अब टर्मिनल में यह निर्देश डालकर, अपना ऐप्लिकेशन लॉन्च करें:
flask --app main.py --debug run --port 8080
इस समय, आपका ऐप्लिकेशन उस वर्चुअल मशीन पर चल रहा होता है जो आपके Cloud Shell सेशन के लिए उपलब्ध कराई गई है. Cloud Shell में एक प्रॉक्सी मैकेनिज़्म शामिल होता है. इसकी मदद से, ग्लोबल इंटरनेट पर कहीं से भी अपनी वर्चुअल मशीन पर चल रहे वेब सर्वर (जैसे कि आपने अभी शुरू किया है) को ऐक्सेस किया जा सकता है.
web preview बटन पर क्लिक करें. इसके बाद, Preview on Port 8080 मेन्यू आइटम पर क्लिक करें. जैसे:

इससे आपके चालू ऐप्लिकेशन के लिए एक वेब ब्राउज़र टैब खुलेगा. यह कुछ इस तरह दिखना चाहिए:

5. पैरामीटर पार्स करने के साथ जनरेट करने का तरीका जोड़ना
अब हमें generate नाम के नए तरीके के लिए सहायता जोड़नी है. इसके लिए, एचटीटीपी अनुरोध में बदलाव करने के लिए, इंपोर्ट स्टेटमेंट जोड़ें. साथ ही, इस अनुरोध को पार्स करने और पैरामीटर प्रिंट करने के लिए, मुख्य रूट में बदलाव करें. ऐसा इस तरह करें:
from flask import Flask
from flask import request #<-CHANGED
import os
app = Flask(__name__) # Create a Flask object.
PORT = os.environ.get("PORT") # Get PORT setting from environment.
if not PORT:
PORT = 8080
# The app.route decorator routes any GET requests sent to the /generate
# path to this function, which responds with "Generating:" followed by
# the body of the request.
@app.route("/", methods=["GET"]) #<-CHANGED
def generate(): #<-CHANGED
params = request.args.to_dict() #<-CHANGED
html = f"<h1>Quiz Generator</h1>" #<-CHANGED
for param in params: #<-CHANGED
html += f"<br>{param}={params[param]}" #<-CHANGED
return html #<-CHANGED
# This code ensures that your Flask app is started and listens for
# incoming connections on the local interface and port 8080.
if __name__ == "__main__":
app.run(host="0.0.0.0", port=PORT)
अब नतीजे देखने के लिए, अपने मौजूदा वेब ब्राउज़र टैब को फिर से लोड करें. इस बार आपको "क्विज़ जनरेटर" दिखेगा. साथ ही, आपके यूआरएल में एक क्वेरी पैरामीटर अपने-आप जुड़ जाएगा (authuser). अपने ब्राउज़र के पता बार में यूआरएल के आखिर में "`¶m1=val1¶m2=val2`" स्ट्रिंग जोड़कर, दो और पैरामीटर जोड़ने की कोशिश करें. इसके बाद, पेज को फिर से लोड करें. आपको कुछ ऐसा दिखेगा:

अब हमने देख लिया है कि यूआरएल पर क्वेरी पैरामीटर कैसे भेजे और पार्स किए जाते हैं. इसलिए, हम उन पैरामीटर के लिए सहायता जोड़ेंगे जिन्हें हमें अपने क्विज़ जनरेटर को भेजना है. ये पैरामीटर यहां दिए गए हैं:
topic- क्विज़ का विषयnum_q- सवालों की संख्याdiff- कठिनाई का लेवल (आसान, सामान्य, मुश्किल)lang- क्विज़ की पसंदीदा भाषा
from flask import Flask
from flask import request
import os
# Default quiz settings #<-CHANGED
TOPIC = "History" #<-CHANGED
NUM_Q = "5" #<-CHANGED
DIFF = "intermediate" #<-CHANGED
LANG = "English" #<-CHANGED
app = Flask(__name__) # Create a Flask object.
PORT = os.environ.get("PORT") # Get PORT setting from environment.
if not PORT:
PORT = 8080
# This function takes a dictionary, a name, and a default value.
# If the name exists as a key in the dictionary, the corresponding
# value is returned. Otherwise, the default value is returned.
def check(args, name, default): #<-CHANGED
if name in args: #<-CHANGED
return args[name] #<-CHANGED
return default #<-CHANGED
# The app.route decorator routes any GET requests sent to the /generate
# path to this function, which responds with "Generating:" followed by
# the body of the request.
@app.route("/", methods=["GET"])
# This function generates a quiz using Vertex AI.
def generate():
args = request.args.to_dict() #<-CHANGED
topic = check(args, "topic", TOPIC) #<-CHANGED
num_q = check(args, "num_q", NUM_Q) #<-CHANGED
diff = check(args, "diff", DIFF) #<-CHANGED
lang = check(args, "lang", LANG) #<-CHANGED
html = f"""
<h1>Quiz Generator</h1><br>
{topic=}<br>
{num_q=}<br>
{diff=}<br>
{lang=}""" #<-CHANGED
return html
# This code ensures that your Flask app is started and listens for
# incoming connections on the local interface and port 8080.
if __name__ == "__main__":
app.run(host="0.0.0.0", port=PORT)
अब नतीजे देखने के लिए, अपने मौजूदा वेब ब्राउज़र टैब को फिर से लोड करें. आपको कुछ ऐसा वेब पेज दिखेगा:

अलग-अलग पैरामीटर के लिए वैल्यू सेट करने के लिए, यूआरएल बदलकर देखें. उदाहरण के लिए, पता बार में मौजूद यूआरएल के आखिर में "?authuser=0&topic=Literature&num_q=10&diff=easy&lang=French" सफ़िक्स का इस्तेमाल करके देखें:

6. प्रॉम्प्ट जोड़ना और उसे फ़ॉर्मैट करना
इसके बाद, हम उन पैरामीटर के लिए सहायता जोड़ेंगे जिन्हें हमें क्विज़ जनरेटर को भेजना है. ये पैरामीटर यहां दिए गए हैं:
topic- क्विज़ का विषयnum_q- सवालों की संख्याdiff- कठिनाई का लेवल (आसान, सामान्य, मुश्किल)lang- क्विज़ की पसंदीदा भाषा
पिछले चरण में, Vertex Generative AI Studio की मदद से बनाए गए प्रॉम्प्ट को कॉपी करें. हालांकि, विषय, सवालों की संख्या, और मुश्किल लेवल के लिए हार्ड-कोड की गई वैल्यू को इन स्ट्रिंग से बदलें:
- {topic}
- {num_q}
- {diff}
- {lang}
from flask import Flask
from flask import request
import os
# Default quiz settings
TOPIC = "History"
NUM_Q = 5
DIFF = "intermediate"
LANG = "English"
PROMPT = """
Generate a quiz according to the following specifications:
- topic: {topic}
- num_q: {num_q}
- diff: {diff}
- lang: {lang}
Output should be (only) an unquoted json array of objects with keys:
"Question", "responses", and "correct".
""" #<-CHANGED
app = Flask(__name__) # Create a Flask object.
PORT = os.environ.get("PORT") # Get PORT setting from environment.
if not PORT:
PORT = 8080
# This function takes a dictionary, a name, and a default value.
# If the name exists as a key in the dictionary, the corresponding
# value is returned. Otherwise, the default value is returned.
def check(args, name, default):
if name in args:
return args[name]
return default
# The app.route decorator routes any GET requests sent to the /generate
# path to this function, which responds with "Generating:" followed by
# the body of the request.
@app.route("/", methods=["GET"])
# This function generates a quiz using Vertex AI.
def generate():
args = request.args.to_dict()
topic = check(args, "topic", TOPIC)
num_q = check(args, "num_q", NUM_Q)
diff = check(args, "diff", DIFF)
lang = check(args, "lang", LANG)
prompt = PROMPT.format(topic=topic, num_q=num_q, diff=diff, lang=lang) #<-CHANGED
html = f"<h1>Prompt:</h1><br><pre>{prompt}</pre>" #<-CHANGED
return html
# This code ensures that your Flask app is started and listens for
# incoming connections on the local interface and port 8080.
if __name__ == "__main__":
app.run(host="0.0.0.0", port=PORT)
अब नतीजे देखने के लिए, अपने मौजूदा वेब ब्राउज़र टैब को फिर से लोड करें. आपको कुछ ऐसा वेब पेज दिखेगा:

उन चार पैरामीटर को बदलने के लिए, यूआरएल में बदलाव करने की कोशिश करें.
7. Vertex AI क्लाइंट लाइब्रेरी जोड़ना
अब हम Vertex AI Python क्लाइंट लाइब्रेरी का इस्तेमाल करके, आपकी क्विज़ जनरेट करने के लिए तैयार हैं. इससे, तीसरे चरण में की गई इंटरैक्टिव प्रॉम्प्टिंग की प्रोसेस अपने-आप पूरी हो जाएगी. साथ ही, जनरेटर सेवा को Google के एलएलएम की सुविधाओं का प्रोग्राम के हिसाब से ऐक्सेस मिल जाएगा. अपनी main.py फ़ाइल को इस तरह अपडेट करें:
"YOUR_PROJECT" की जगह अपना प्रोजेक्ट आईडी डालना न भूलें.
from flask import Flask
from flask import request
from flask import Response #<-CHANGED
import os
import vertexai
from vertexai.generative_models import GenerativeModel #<-CHANGED
# Default quiz settings
TOPIC = "History"
NUM_Q = 5
DIFF = "intermediate"
LANG = "English"
MODEL = "gemini-1.0-pro" #<-CHANGED
PROMPT = """
Generate a quiz according to the following specifications:
- topic: {topic}
- num_q: {num_q}
- diff: {diff}
- lang: {lang}
Output should be (only) an unquoted json array of objects with keys "question", "responses", and "correct".
"""
app = Flask(__name__) # Create a Flask object.
PORT = os.environ.get("PORT") # Get PORT setting from environment.
if not PORT:
PORT = 8080
# Initialize Vertex AI access.
vertexai.init(project="YOUR_PROJECT", location="us-central1") #<-CHANGED
parameters = { #<-CHANGED
"candidate_count": 1, #<-CHANGED
"max_output_tokens": 1024, #<-CHANGED
"temperature": 0.5, #<-CHANGED
"top_p": 0.8, #<-CHANGED
"top_k": 40, #<-CHANGED
} #<-CHANGED
model = GenerativeModel(MODEL) #<-CHANGED
# This function takes a dictionary, a name, and a default value.
# If the name exists as a key in the dictionary, the corresponding
# value is returned. Otherwise, the default value is returned.
def check(args, name, default):
if name in args:
return args[name]
return default
# The app.route decorator routes any GET requests sent to the /generate
# path to this function, which responds with "Generating:" followed by
# the body of the request.
@app.route("/", methods=["GET"])
# This function generates a quiz using Vertex AI.
def generate():
args = request.args.to_dict()
topic = check(args, "topic", TOPIC)
num_q = check(args, "num_q", NUM_Q)
diff = check(args, "diff", DIFF)
lang = check(args, "lang", LANG)
prompt = PROMPT.format(topic=topic, num_q=num_q, diff=diff, lang=lang)
response = model.generate_content(prompt, generation_config=parameters) #<-CHANGED
print(f"Response from Model: {response.text}") #<-CHANGED
html = f"{response.text}" #<-CHANGED
return Response(html, mimetype="application/json") #<-CHANGED
# This code ensures that your Flask app is started and listens for
# incoming connections on the local interface and port 8080.
if __name__ == "__main__":
app.run(host="0.0.0.0", port=PORT)
अब नतीजे देखने के लिए, अपने मौजूदा वेब ब्राउज़र टैब को फिर से लोड करें. ध्यान दें कि इसमें कुछ सेकंड लग सकते हैं, क्योंकि अब एलएलएम से अनुरोध किया जा रहा है. आपको कुछ ऐसा वेब पेज दिखेगा:

किसी दूसरे विषय पर क्विज़, सवालों की संख्या, और कठिनाई का लेवल तय करने के लिए, यूआरएल में बदलाव करके देखें.
इसके साथ ही, आपकी माइक्रोसेवा तैयार हो गई है. बधाई हो! अगले चरण में, आपको अपनी सेवा को Cloud में डिप्लॉय करने का तरीका बताया जाएगा, ताकि कोई भी व्यक्ति इसे कहीं से भी ऐक्सेस कर सके.
8. क्लाउड पर!

आपने क्विज़ जनरेट करने वाला अपना टूल बना लिया है. अब आपको इसे दुनिया के साथ शेयर करना है. इसलिए, इसे क्लाउड पर डिप्लॉय करने का समय आ गया है. हालांकि, आपको इसे सिर्फ़ शेयर करने के अलावा और भी बहुत कुछ करना है. आपको यह पक्का करना होगा कि:
- भरोसेमंद तरीके से चलता है - अगर आपका ऐप्लिकेशन चलाने वाला कंप्यूटर क्रैश हो जाता है, तो आपको अपने-आप फ़ॉल्ट टॉलरेंस मिल जाता है
- अपने-आप स्केल होता है - आपका ऐप्लिकेशन, ज़्यादा ट्रैफ़िक को मैनेज कर पाएगा. साथ ही, इस्तेमाल न होने पर यह अपने-आप कम जगह लेगा
- यह उन संसाधनों के लिए आपसे शुल्क नहीं लेता जिनका इस्तेमाल नहीं किया जा रहा है. इससे आपकी लागत कम हो जाती है. आपसे सिर्फ़ उन संसाधनों के लिए शुल्क लिया जाता है जिनका इस्तेमाल ट्रैफ़िक को जवाब देने के दौरान किया जाता है
- को कस्टम डोमेन नेम के ज़रिए ऐक्सेस किया जा सकता है - आपके पास अपनी सेवा को कस्टम डोमेन नेम असाइन करने के लिए, एक क्लिक में उपलब्ध समाधान का ऐक्सेस होता है
- जवाब देने में कम समय लगता है - कोल्ड स्टार्ट के दौरान जवाब देने में थोड़ा समय लगता है, लेकिन कम से कम इंस्टेंस कॉन्फ़िगरेशन तय करके इसे बेहतर बनाया जा सकता है
- यह स्टैंडर्ड एसएसएल/टीएलएस वेब सुरक्षा का इस्तेमाल करके, एंड-टू-एंड एन्क्रिप्शन की सुविधा देता है. जब कोई सेवा डिप्लॉय की जाती है, तो आपको स्टैंडर्ड वेब एन्क्रिप्शन और उससे जुड़े ज़रूरी सर्टिफ़िकेट, बिना किसी शुल्क के और अपने-आप मिल जाते हैं
अपने ऐप्लिकेशन को Google Cloud Run पर डिप्लॉय करने से, आपको ऊपर दी गई सभी सुविधाएं और इसके अलावा और भी कई सुविधाएं मिलती हैं. Cloud Run के साथ ऐप्लिकेशन शेयर करने के लिए, कंटेनर सबसे ज़रूरी कॉम्पोनेंट होता है.
कंटेनर की मदद से, हम एक मॉड्यूलर बॉक्स बना सकते हैं. इसमें ऐप्लिकेशन को उसकी सभी डिपेंडेंसी के साथ बंडल करके चलाया जा सकता है. कंटेनर का इस्तेमाल लगभग किसी भी वर्चुअल या असली सर्वर पर किया जा सकता है. इससे हमें आपके ऐप्लिकेशन को अपनी पसंद के हिसाब से कहीं भी डिप्लॉय करने का विकल्प मिलता है. जैसे, ऑन-प्रिमाइसेस से लेकर क्लाउड तक. साथ ही, अपने ऐप्लिकेशन को एक सेवा देने वाली कंपनी से दूसरी कंपनी पर ले जाने का विकल्प भी मिलता है.
कंटेनर और Google Cloud Run में उनके काम करने के तरीके के बारे में ज़्यादा जानने के लिए, Cloud Run की मदद से तीन आसान चरणों में डेवलपमेंट से लेकर प्रोडक्शन तक की प्रोसेस पूरी करना कोडलैब देखें.
अपने ऐप्लिकेशन को Cloud Run पर डिप्लॉय करना
Cloud Run, एक क्षेत्रीय सेवा है. इसका मतलब है कि Cloud Run की सेवाओं को चलाने वाला इन्फ़्रास्ट्रक्चर, किसी खास क्षेत्र में मौजूद होता है. साथ ही, Google इसे मैनेज करता है, ताकि यह उस क्षेत्र के सभी ज़ोन में उपलब्ध रहे. आसानी के लिए, इस लैब में हम हार्डकोड किए गए क्षेत्र us-central1 का इस्तेमाल करेंगे.
हम आपके कंटेनर को अपने-आप जनरेट करने के लिए, बिल्डपैक का इस्तेमाल करेंगे. Cloud Editor में Procfile नाम की एक नई फ़ाइल बनाएं और इसमें यह एक लाइन का टेक्स्ट डालें:
web: gunicorn --bind :$PORT --workers 1 --threads 8 --timeout 0 main:app
इससे बिल्डपैक सिस्टम को यह पता चलता है कि अपने-आप जनरेट हुए कंटेनर में आपके ऐप्लिकेशन को कैसे चलाना है. इसके बाद, Cloud Shell टर्मिनल में यह कमांड चलाएं. यह कमांड, उसी quiz-generator डायरेक्ट्री से चलाएं:
gcloud run deploy quiz-generator \
--source . \
--region us-central1 \
--allow-unauthenticated
इससे gcloud कमांड को यह पता चलता है कि आपको कंटेनर इमेज बनाने के लिए, बिल्डपैक का इस्तेमाल करना है. यह इमेज, मौजूदा डायरेक्ट्री में मौजूद सोर्स फ़ाइलों के आधार पर बनाई जाएगी. --source . में मौजूद dot, मौजूदा डायरेक्ट्री के लिए शॉर्टहैंड है. यह सेवा कंटेनर इमेज का ध्यान रखती है. इसलिए, आपको इस gcloud कमांड में इमेज के बारे में जानकारी देने की ज़रूरत नहीं है.
डिप्लॉयमेंट पूरा होने तक कुछ देर इंतज़ार करें. सफल होने पर, gcloud कमांड नई सेवा का यूआरएल दिखाती है:
Building using Buildpacks and deploying container to Cloud Run service [quiz-generator] in project [YOUR_PROJECT] region [YOUR_REGION] OK Building and deploying new service... Done. OK Creating Container Repository... OK Uploading sources... OK Building Container... Logs are available at [https://console.cloud.google.com/cloud-build/builds/0cf1383f-35db-412d -a973-557d5e2cd4a4?project=780573810218]. OK Creating Revision... OK Routing traffic... OK Setting IAM Policy... Done. Service [quiz-generator] revision [quiz-generator-00001-xnr] has been deployed and is serving 100 percent of traffic. Service URL: https://quiz-generator-co24gukjmq-uc.a.run.app
इस कमांड का इस्तेमाल करके भी, सेवा का यूआरएल वापस पाया जा सकता है:
gcloud run services describe quiz-generator \ --region us-central1 \ --format "value(status.url)"
यह कुछ इस तरह दिखना चाहिए:
https://quiz-generator-co24gukjmq-uc.a.run.app
यह लिंक, आपकी Cloud Run सेवा के लिए टीएलएस सुरक्षा वाला एक खास यूआरएल है. यह लिंक हमेशा के लिए होता है. जब तक सेवा बंद नहीं की जाती, तब तक इसका इस्तेमाल किया जा सकता है. साथ ही, इसका इस्तेमाल इंटरनेट पर कहीं भी किया जा सकता है. यह Cloud Shell के प्रॉक्सी मैकेनिज़्म का इस्तेमाल नहीं करता है. यह मैकेनिज़्म, कुछ समय के लिए उपलब्ध वर्चुअल मशीन पर निर्भर करता है.
हाइलाइट किए गए Service URL पर क्लिक करें. इससे, आपका ऐप्लिकेशन वेब ब्राउज़र टैब में खुल जाएगा. पुष्टि करें कि नतीजे वही हैं जो आपको डेवलपमेंट एनवायरमेंट में दिखे थे. यह भी पुष्टि करें कि यूआरएल के आखिर में पैरामीटर जोड़कर, जनरेट की गई क्विज़ में बदलाव किया जा सकता है.
बधाई हो! अब आपका ऐप्लिकेशन, Google के क्लाउड पर चल रहा है. आपको इस बारे में सोचने की ज़रूरत नहीं है कि आपका ऐप्लिकेशन सार्वजनिक तौर पर उपलब्ध है या नहीं. साथ ही, यह टीएलएस (एचटीटीपीएस) एन्क्रिप्शन के साथ उपलब्ध है. इसके अलावा, यह ट्रैफ़िक के हिसाब से अपने-आप स्केल होता है.
9. सभी टुकड़ों को एक साथ जोड़ना
इस आखिरी चरण में, हम क्विज़ जनरेटर को Quizaic ऐप्लिकेशन के हिस्से के तौर पर चलाने के लिए तैयार हैं. Quizaic के यूआरएल पर जाएं, अपने Google खाते में लॉग इन करें, और Create Quiz टैब पर जाएं. जनरेटर टाइप Custom चुनें. इसके बाद, Cloud Run यूआरएल को यूआरएल फ़ील्ड में चिपकाएं. अन्य ज़रूरी फ़ील्ड भरें और फ़ॉर्म सबमिट करें.

कुछ ही समय में, आपको एक नया क्विज़ दिखेगा. नीचे दी गई इमेज में "मेरा नया क्विज़" देखें. इसमें एआई से जनरेट की गई थंबनेल इमेज होगी. इसे इससे जुड़े बटन की मदद से, बदला जा सकता है, चलाया जा सकता है, डुप्लीकेट बनाया जा सकता है या मिटाया जा सकता है. इस नए क्विज़ को, आपकी ओर से अभी-अभी डिप्लॉय की गई वेब सेवा का इस्तेमाल करके बनाया गया है. इसे आपके टेंप्लेट वाले प्रॉम्प्ट के आधार पर बनाया गया है!

10. क्लीन अप करना

Cloud Run, सेवा का इस्तेमाल न किए जाने पर कोई शुल्क नहीं लेता. हालांकि, बनाई गई कंटेनर इमेज को सेव करने के लिए आपसे शुल्क लिया जा सकता है.
शुल्क से बचने के लिए, अपने GCP प्रोजेक्ट को मिटाया जा सकता है. इससे उस प्रोजेक्ट में इस्तेमाल किए गए सभी संसाधनों के लिए बिलिंग बंद हो जाएगी. इसके अलावा, इस कमांड का इस्तेमाल करके अपनी कंटेनर इमेज को मिटाया जा सकता है:
gcloud config set artifacts/repository cloud-run-source-deploy gcloud config set artifacts/location us-central1 gcloud artifacts docker images list # Note image tag for resulting list gcloud artifacts docker images delete <IMAGE-TAG>
Cloud Run सेवा को मिटाने के लिए, इस कमांड का इस्तेमाल करें:
gcloud run services delete quiz-generator --region us-central1 --quiet
11. आपने कर दिखाया!

बधाई हो - आपने एलएलएम प्रॉम्प्ट बना लिया है और उस प्रॉम्प्ट का इस्तेमाल करके Cloud Run माइक्रोसेवा को डिप्लॉय कर लिया है. अब आम भाषा में प्रोग्रामिंग की जा सकती है और अपनी क्रिएटिविटी को दुनिया के साथ शेयर किया जा सकता है!
हम आपसे एक ज़रूरी सवाल पूछना चाहते हैं:
डेवलपर एनवायरमेंट में ऐप्लिकेशन को चालू करने के बाद, Cloud Run की ओर से ऑफ़र की जाने वाली प्रोडक्शन-ग्रेड की सभी एट्रिब्यूट के साथ, इसे क्लाउड पर डिप्लॉय करने के लिए आपको कोड की कितनी लाइनों में बदलाव करना पड़ा?
ज़ाहिर है, इसका जवाब शून्य है. :)
देखने के लिए अन्य कोडलैब...
- Cloud Run की मदद से, तीन आसान चरणों में डेवलपमेंट से प्रोडक्शन तक का प्रोसेस पूरी करें
- Vertex AI और Svelte Kit की मदद से बनाया गया टेक्स्ट को छोटा करने वाला ऐप्लिकेशन
- Cloud Run पर PaLM API के साथ Chat ऐप्लिकेशन
- PaLM Text Bison मॉडल को रैप करने वाला Cloud फ़ंक्शन
- Spanner और Vertex AI Imagen API की मदद से, डेटा को जनरेटिव एआई में बदलना
रेफ़रंस दस्तावेज़...
12. कॉल-टू-ऐक्शन
अगर आपको यह कोडलैब पसंद आया है और आपको Google Cloud का इस्तेमाल करने में ज़्यादा समय लगता है, तो आपको आज ही Google Cloud Innovators में शामिल होना चाहिए!

Google Cloud Innovators में शामिल होने के लिए, आपको कोई शुल्क नहीं देना होगा. इसमें ये सुविधाएं शामिल हैं:
- Google कर्मचारियों से सीधे तौर पर नई जानकारी पाने के लिए, लाइव चर्चाएं, एएमए, और रोडमैप सेशन
- सीधे अपने इनबॉक्स में, Google Cloud से जुड़ी ताज़ा खबरें पाएं
- डिजिटल बैज और वीडियो कॉन्फ़्रेंस का बैकग्राउंड
- Skills Boost पर, लैब और लर्निंग के लिए 500 क्रेडिट
रजिस्टर करने के लिए, यहां क्लिक करें!
