आपको Apigee Edge दस्तावेज़ दिख रहा है.
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
इस पेज पर जाएं
Apigee X दस्तावेज़. जानकारी
होस्ट किए गए टारगेट प्रॉक्सी को डिप्लॉय न करना
जब आप किसी ऐसे Edge प्रॉक्सी को डिप्लॉय नहीं करते हैं जिसमें होस्ट किए गए टारगेट ऐप्लिकेशन शामिल है, तो होस्ट किए गए Target ऐप्लिकेशन को डिप्लॉय नहीं किया गया है, लेकिन ऐप्लिकेशन की बुनियादी इमेज नहीं मिटाई गई है. अगर आपको प्रॉक्सी को फिर से डिप्लॉय करने के बाद, होस्ट किए गए टारगेट ऐप्लिकेशन को फिर से डिप्लॉय किया जाता है.
होस्ट किए गए टारगेट प्रॉक्सी को मिटाना
होस्ट किए गए टारगेट प्रॉक्सी को मिटाने के बाद, इससे जुड़े रनटाइम इंस्टेंस रुक जाएंगे कम या ज़्यादा कर सकता है. हालांकि, ऐप्लिकेशन कोड बना रहेगा.
लॉग फ़ाइलें ऐक्सेस करना
लॉग फ़ाइलों को डीबग करने और समस्या हल करने में मदद मिलती है. आप होस्ट किए गए टारगेट का डिप्लॉयमेंट:
- बिल्ड लॉग - आपको होस्ट किए गए टारगेट ऐप्लिकेशन को डिप्लॉय और बनाने से जुड़ा आउटपुट दिखाता है.
- रनटाइम लॉग - आपको होस्ट किए गए टारगेट ऐप्लिकेशन से जुड़ा आउटपुट दिखाता है. रनटाइम लॉग एनवायरमेंट के दायरे में आते हैं और मौजूदा समय में डिप्लॉय किए गए प्रॉक्सी रिविज़न की लॉग जानकारी दिखाते हैं.
Edge के यूज़र इंटरफ़ेस (यूआई) से लॉग ऐक्सेस करना
- इस लिंक पर जाएं: apigee.com/edge
- अपने लॉगिन क्रेडेंशियल डालें और साइन इन करें पर क्लिक करें.
- डेवलप करें > एपीआई प्रॉक्सी पर क्लिक करें.
- वह प्रॉक्सी चुनें जिसके लिए आपको लॉग देखना है.
- डेवलप करें टैब पर क्लिक करें.
- बिल्ड लॉग देखने के लिए, लॉग बनाएं पर क्लिक करें.
- रनटाइम लॉग देखने के लिए, रनटाइम लॉग पर क्लिक करें.
एपीआई की मदद से लॉग ऐक्सेस करना
होस्ट किए गए टारगेट के लॉग पाने के लिए, Edge API का भी इस्तेमाल किया जा सकता है. जानकारी के लिए, यह देखें कैश मेमोरी में सेव किए गए Node.js के लॉग पाएं.
निजी एनपीएम डेटा स्टोर करने की जगह का इस्तेमाल करना
इस सेक्शन में बताया गया है कि होस्ट किए गए टारगेट पर Node.js प्रॉक्सी को उन मामलों में कैसे डिप्लॉय करें जहां आपको निजी NPM डेटा स्टोर करने की जगह का इस्तेमाल का इस्तेमाल कैसे किया जा सकता है.
डेटा स्टोर करने की निजी जगह का इस्तेमाल करने के बारे में ज़रूरी जानकारी
Node.js ऐप्लिकेशन को Edge में डिप्लॉय करने पर, आपके प्रोजेक्ट की सभी डिपेंडेंसी अपने-आप इंपोर्ट हो जाती हैं
डिप्लॉयमेंट प्रोसेस का हिस्सा है.
दरअसल, होस्ट किए गए टारगेट आपके कोड पर npm install
रन करते हैं.
हालांकि, अगर अपने डेवलपमेंट एनवायरमेंट में निजी एनपीएम रिपॉज़िटरी का इस्तेमाल किया जाता है, तो निजी
डिपेंडेंसी को क्लाउड में ठीक नहीं किया जा सकता. तय सीमा में
इस मामले में, समाधान यह है कि आप --bundled-dependencies
विकल्प का उपयोग करें जब आप
डिप्लॉयमेंट यूटिलिटी apigeetool. इन्हें भी देखें
Node.js को अपने सिस्टम से Edge पर डिप्लॉय करें.
जब आप apigeetool
पर --bundled-dependencies
फ़्लैग का इस्तेमाल करते हैं, तो आपके
Node.js ऐप्लिकेशन को होस्ट किए गए टारगेट और सूची में दी गई किसी भी स्थानीय/निजी फ़ाइलों में अपलोड किया जाएगा
bundledDependencies अरे में
package.json
को ज़िप करके बंडल के साथ अपलोड किया जाता है.
हालांकि, यह आम स्थिति नहीं है, लेकिन ध्यान रखें कि अगर किसी सार्वजनिक एनपीएम रिपॉज़िटरी का डुप्लीकेट वर्शन बनाया जाता है, तो डिप्लॉय नहीं किया जा सकता
अगर आपके डिप्लॉयमेंट बंडल में ऐसी .npmrc
या package-lock.json
फ़ाइल शामिल है जो
आपके आईने की मदद से. इस मामले में, .npmrc
या package-lock.json
को हटा दें
को डिप्लॉय किया जा सकता है.
निजी एनपीएम डेटा स्टोर करने की जगह के साथ डिप्लॉय करना
निजी एनपीएम डेटा स्टोर करने की जगह से मिले मॉड्यूल इस्तेमाल करने के लिए यह तरीका अपनाएं:
- एनपीएम में लॉग इन करें:
npm login
- npm पुष्टि टोकन पाएं:
- अपने .npmrc (~/.npmrc में होना चाहिए) पर जाएं.
- अपने .npmrc में, लाइन के आखिर में मौजूद टोकन को नोट करें, जो इस तरह दिखता है:
//registry.npmjs.org/:_authToken=****
- इसके अलावा, सूची बनाने के लिए
npm token <list | create | revoke>
कमांड का इस्तेमाल करें, बनाने या रद्द करने के लिए पुष्टि करने का टोकन. npm-टोकन देखें दस्तावेज़ देखें. - नीचे बताए गए तरीके से, Key Value Maps के कॉन्फ़िगरेशन पेज को ऐक्सेस करें.
Edge
Edge यूज़र इंटरफ़ेस (यूआई) का इस्तेमाल करके, पासकोड की वैल्यू वाले मैप के कॉन्फ़िगरेशन पेज को ऐक्सेस करने के लिए:
- apigee.com/edge में साइन इन करें.
- एडमिन > एनवायरमेंट > बाएं नेविगेशन बार में मौजूद 'की वैल्यू मैप' पर क्लिक करें.
क्लासिक Edge (प्राइवेट क्लाउड)
क्लासिक एज यूआई का इस्तेमाल करके, पासकोड की वैल्यू वाले मैप के कॉन्फ़िगरेशन पेज को ऐक्सेस करने के लिए:
http://ms-ip:9000
में साइन इन करें, जहां ms-ip मैनेजमेंट सर्वर नोड का आईपी पता या डीएनएस नाम.- एपीआई > चुनें एनवायरमेंट का कॉन्फ़िगरेशन > मुख्य नेविगेशन बार में मौजूद 'की वैल्यू मैप' पर क्लिक करें.
- + की वैल्यू मैप पर क्लिक करें.
- नई कुंजी की वैल्यू वाले मैप के डायलॉग में, कोई नाम डालें और एन्क्रिप्ट (सुरक्षित) किया गया चुनें.
- जोड़ें पर क्लिक करें.
- हर केवीएम में वह ऑथराइज़ेशन टोकन जोड़ें जिसे आपने पहले दिखाया था या नई एंट्री के तौर पर बनाया था जो आपने अभी-अभी बनाया है.
- अपनी app.yaml फ़ाइल में, केवीएम और कुंजी का रेफ़रंस देने वाली एंट्री जोड़ें यह npm पुष्टि टोकन से जुड़ा होता है. यह कुछ ऐसी नज़र आनी चाहिए:
- टॉप लेवल name एट्रिब्यूट, एनवायरमेंट के नाम से मेल खाता है बनाया जाएगा.
- valueRef में मौजूद नाम, आपको केवीएम से मेल खाता है पहले बनाया गया.
- key एट्रिब्यूट उस पासकोड से मेल खाता है जो आपके एनपीएम टोकन को मैप करता है को केवीएम में जोड़ा गया.
- .npmrc फ़ाइल उसी डायरेक्ट्री में बनाएं जिसमें आपकी Package.json की फ़ाइल है. यह
फ़ाइल इसके जैसी दिखनी चाहिए:
या अगर आप//registry.npmjs.org/:_authToken=${NPM_TOKEN}
registry.npmjs.org
का इस्तेमाल नहीं कर रहे हैं, तो आप स्कोप सेट कर सकते हैं .npmrc फ़ाइल में इस तरह की एक पंक्ति जोड़कर@myscope:registry=https://mycustomregistry.example.org
npmrc दस्तावेज़ भी देखें. - .npmrc फ़ाइल और app.yaml फ़ाइलों को शामिल करके, Node.js प्रॉक्सी को अपलोड या अपडेट करें.
- पक्का करें कि आपका नया या अपडेट किया गया प्रॉक्सी डिप्लॉय करता है और आपकी पसंद के निजी डेटा स्टोर करने की जगह के साथ काम करता है मॉड्यूल का इस्तेमाल नहीं किया जाएगा.
- अगर प्रॉक्सी डिप्लॉय नहीं होती है, तो बिल्ड लॉग देखें और देखें कि क्या यह निजी एनपीएम मॉड्यूल. अगर ऐसा है, तो:
- 'बनाएं' टैब में, पक्का करें कि .npmrc मौजूद हो.
- पक्का करें कि आपका टोकन मान्य है. मॉड्यूल को स्थानीय तौर पर इंस्टॉल करने की कोशिश करें, जहां टोकन मौजूद हो kvm में) देखें.
- अगर पसंद के मुताबिक बनाए गए स्कोप का इस्तेमाल किया जा रहा है, तो पक्का करें कि वह सेट हो.
env:
- name: NPM_TOKEN
valueRef:
name: npm_store
key: private_token
कहां:
बंडल की गई डिपेंडेंसी के लिए NPM वर्शन तय करना
डिफ़ॉल्ट रूप से, NPM v4 का इस्तेमाल, होस्ट किए गए टारगेट एनवायरमेंट में बंडल की गई डिपेंडेंसी इंस्टॉल करने के लिए किया जाता है.
हालांकि, अगर आपको NPM का कोई दूसरा वर्शन इस्तेमाल करना है, तो NPM_VERSION
में इसकी जानकारी दें
एनवायरमेंट वैरिएबल. आप इस वैरिएबल को ऐप्लिकेशन की मेनिफ़ेस्ट फ़ाइल में सेट कर सकते हैं. ज़्यादा जानकारी के लिए, मेनिफ़ेस्ट फ़ाइल के एलिमेंट देखें.
बंडल डिपेंडेंसी का इस्तेमाल करने और NPM_VERSION
की जानकारी न देने पर, होस्ट किए गए टारगेट
डिफ़ॉल्ट रूप से, NPM v4 का इस्तेमाल करता है. अगर बंडल डिपेंडेंसी का इस्तेमाल नहीं किया जाता है, तो NPM का वह वर्शन शामिल है जो
में आपके तय किए गए Node.js रनटाइम का इस्तेमाल किया जाता है.
बंडल किए गए डिपेंडेंसी का उदाहरण
होस्ट किए गए टारगेट के साथ बंडल की गई डिपेंडेंसी दिखाने वाले उदाहरण के लिए, देखें कस्टम मॉड्यूल का इस्तेमाल करके, होस्ट किए गए फ़ंक्शन के साथ Node.js ऐप्लिकेशन बनाने का तरीका.स्वास्थ्य जांच का एंडपॉइंट जोड़ें
आपके पास अपने Node.js ऐप्लिकेशन के लिए, हेल्थ चेक एंडपॉइंट लागू करने का भी विकल्प है. Apigee इस एंडपॉइंट का इस्तेमाल तब करता है, जब आपका Node.js ऐप्लिकेशन यह जांच करता है कि ऐप्लिकेशन चालू है और कंटेनर में चल रहा है.
डिफ़ॉल्ट रूप से, Apigee को जो एंडपॉइंट चाहिए वह /health
है. डिफ़ॉल्ट बटन को बदला जा सकता है
एंडपॉइंट में, एंडपॉइंट के नाम को एनवायरमेंट वैरिएबल
HOSTED_TARGET_HEALTH_CHECK_PATH
. आपके पास इस वैरिएबल को ऐप्लिकेशन के मेनिफ़ेस्ट में सेट करने का विकल्प है
फ़ाइल से लिए जाते हैं. ज़्यादा जानकारी के लिए, मेनिफ़ेस्ट फ़ाइल के एलिमेंट देखें.
हेल्थ चेक एंडपॉइंट लागू करने की ज़रूरत नहीं है. हालांकि, अगर प्रॉडक्ट की परफ़ॉर्मेंस की जांच करने के लिए, एंडपॉइंट के लिए, इन बातों का ध्यान रखें:
- अगर Apigee के एंडपॉइंट पर हिट करने पर आपका ऐप्लिकेशन बंद हो जाता है, तो ऐप्लिकेशन उम्मीद के मुताबिक शुरू नहीं होगा.
- अगर आपका एंडपॉइंट, 404 नहीं मिला एचटीटीपी स्टेटस दिखाता है, तो ठीक है.
/health
याHOSTED_TARGET_HEALTH_CHECK_PATH
का इस्तेमाल सिर्फ़ यह देखने के लिए किया जाता है कि आपका ऐप्लिकेशन चल रहा है या नहीं. असल जवाब को अनदेखा कर दिया जाता है.
एनपीएम कैश मेमोरी की जगह बदलना
Node.js के नए वर्शन में एनपीएम के ऐसे वर्शन का इस्तेमाल किया जाता है जो एनपीएम की कैश मेमोरी के लिए /root/.npm
का इस्तेमाल करता है.
इस जगह पर होस्ट किए गए टारगेट में समस्या आती है. इसकी वजह यह है कि डायरेक्ट्री की जगह सिर्फ़ रीड-ओनली होती है
ऐसा इसलिए, क्योंकि होस्ट किए गए टारगेट का रनटाइम, tmpfs फ़ाइल सिस्टम का इस्तेमाल करता है, जहां सिर्फ़ /tmp
को लिखा जा सकता है.
इस समस्या को हल करने के लिए, npm_config_cache
एनवायरमेंट वैरिएबल को इसमें सेट किया जा सकता है
आपके ऐप्लिकेशन का
app.yaml
फ़ाइल (मैनिफ़ेस्ट फ़ाइल)
/tmp
के अंदर की किसी डायरेक्ट्री में. उदाहरण के लिए:
runtime: node application: my-express-app env: - name: npm_config_cache value: /tmp/.npm - name: NODE_ENV value: production - name: LOG_LEVEL value: 3
ऐप्लिकेशन को NPM के बिना चलाएं
डिफ़ॉल्ट रूप से, होस्ट किए गए टारगेट आपके होस्ट किए गए टारगेट ऐप्लिकेशन को चलाने के लिए npm start
का इस्तेमाल करते हैं. लेकिन
पिछले टास्क में हमने एनपीएम के इस्तेमाल में होने वाली एक समस्या के बारे में चर्चा की थी, क्योंकि नए वर्शन
NPM कैश मेमोरी के लिए /root/.npm
, जिसे लिखा नहीं जा सकता. इसकी वजह से, होस्ट किया गया टारगेट मिलता है
शुरू नहीं किया जा सका. हालांकि, पिछला टास्क करने पर यह समस्या हल हो जाएगी, लेकिन दूसरा विकल्प यह होगा कि
आपकी ऐप्लिकेशन को NPM के बिना चला सकता है. ऐसा करने के लिए, command
और
आपके ऐप्लिकेशन के args
मान
app.yaml
फ़ाइल (मेनिफ़ेस्ट फ़ाइल)
node index.js
का इस्तेमाल करके अपने होस्ट किए गए टारगेट को सीधे चलाने के लिए. उदाहरण के लिए:
runtime: node application: my-express-app command: node args: - index.js env: - name: NODE_ENV value: production - name: LOG_LEVEL value: 3
node index.js
उदाहरण के लिए.