आपको Apigee Edge दस्तावेज़ दिख रहा है.
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
इस पेज पर जाएं
Apigee X दस्तावेज़. जानकारी
क्या
सेवा कॉलआउट की नीति की मदद से, एपीआई प्रॉक्सी फ़्लो से किसी दूसरी सेवा को कॉल किया जा सकता है. आपने लोगों तक पहुंचाया मुफ़्त में किसी बाहरी सेवा (जैसे कि बाहरी RESTful सेवा एंडपॉइंट) के लिए कॉलआउट बना सकता है या अंदरूनी सेवाएं (जैसे कि एक ही संगठन और एनवायरमेंट में एपीआई प्रॉक्सी).
- बाहरी इस्तेमाल के उदाहरण में, ऐसे तीसरे पक्ष के एपीआई के लिए कॉलआउट बनाया जाता है जो आपके प्रॉक्सी. तीसरे पक्ष के एपीआई से मिले रिस्पॉन्स को पार्स करके, आपके एपीआई के रिस्पॉन्स में शामिल किया जाता है मैसेज, उसे बेहतर बनाना, और "मैश अप करना" असली उपयोगकर्ताओं का डेटा सुरक्षित रखा जा सके. यह अनुरोध भी किया जा सकता है अनुरोध फ़्लो में सेवा कॉलआउट नीति का इस्तेमाल करके, फिर जवाब में जानकारी पास करें को एपीआई प्रॉक्सी के TargetEndpoint तक ले जाना.
- इस्तेमाल के दूसरे उदाहरण में, ऐसी प्रॉक्सी को कॉल किया जा सकता है जो उसी संगठन और एनवायरमेंट में मौजूद है जिसे आपने कॉल किया है. उदाहरण के लिए, यह आपको तब उपयोगी लग सकता है, जब आपके पास कुछ अलग तरह के लो-लेवल फ़ंक्शन उपलब्ध कराता है जिनका इस्तेमाल एक या उससे ज़्यादा प्रॉक्सी करेंगे. इसके लिए उदाहरण के लिए, एक ऐसी प्रॉक्सी जो बैकएंड डेटा स्टोर के साथ बनाने, पढ़ने/अपडेट करने/मिटाने की कार्रवाई दिखाती है क्लाइंट को डेटा दिखाने वाली कई अन्य प्रॉक्सी के लिए टारगेट प्रॉक्सी हो सकती है.
इस नीति के तहत, एचटीटीपी और एचटीटीपीएस पर अनुरोध किए जा सकते हैं.
सैंपल
इंटरनल प्रॉक्सी को लोकल कॉल
<LocalTargetConnection> <APIProxy>data-manager</APIProxy> <ProxyEndpoint>default</ProxyEndpoint> </LocalTargetConnection>
यह उदाहरण, लोकल एपीआई प्रॉक्सी (यानी कि एक ही संगठन के किसी एक व्यक्ति) के लिए एक कॉलआउट बनाता है
और एनवायरमेंट) कॉल करता है, जो data-manager
अपने प्रॉक्सी एंडपॉइंट को बताते हैं जिसका नाम
default
है.
वैरिएबल के तौर पर यूआरएल
<HTTPTargetConnection> <URL>http://example.com/{request.myResourcePath}</URL> </HTTPTargetConnection>
इस उदाहरण में यूआरएल में एक वैरिएबल का इस्तेमाल किया गया है, ताकि टारगेट के यूआरएल को डाइनैमिक तरीके से भरा जा सके. कॉन्टेंट बनाने http:// यूआरएल के प्रोटोकॉल वाले हिस्से को, वैरिएबल. साथ ही, आपको यूआरएल के डोमेन वाले हिस्से के लिए अलग-अलग वैरिएबल का इस्तेमाल करना होगा और यूआरएल के बाकी हिस्से के लिए.
Google जियोकोडिंग / अनुरोध परिभाषित करें
<ServiceCallout name="ServiceCallout-GeocodingRequest1"> <DisplayName>Inline request message</DisplayName> <Request variable="authenticationRequest"> <Set> <QueryParams> <QueryParam name="address">{request.queryparam.postalcode}</QueryParam> <QueryParam name="region">{request.queryparam.country}</QueryParam> <QueryParam name="sensor">false</QueryParam> </QueryParams> </Set> </Request> <Response>GeocodingResponse</Response> <Timeout>30000</Timeout> <HTTPTargetConnection> <URL>http://maps.googleapis.com/maps/api/geocode/json</URL> </HTTPTargetConnection> </ServiceCallout>
http://maps.googleapis.com/maps/api/geocode/json
अनुरोध ऑब्जेक्ट बनाने के लिए, मैसेज असाइन करें जैसी नीति का इस्तेमाल करने के बजाय, ये काम किए जा सकते हैं इसे सीधे सेवा कॉलआउट नीति में परिभाषित किया जा सकता है. इस उदाहरण में, सेवा कॉलआउट नीति बाहरी सेवा को पास किए जाने वाले तीन क्वेरी पैरामीटर की वैल्यू सेट करता है. आपके पास सर्विस कॉलआउट नीति में पूरे अनुरोध के मैसेज के साथ पेलोड, एन्कोडिंग टाइप की जानकारी मिलती है जैसे कि application/xml, हेडर, फ़ॉर्म पैरामीटर वगैरह.
यहां एक और उदाहरण दिया गया है, जिसमें सेवा कॉलआउट तक पहुंचने से पहले अनुरोध किया जाता है की नीति देखें.
<ServiceCallout name="ServiceCallout-GeocodingRequest2"> <Request clearPayload="false" variable="GeocodingRequest"/> <Response>GeocodingResponse</Response> <Timeout>30000</Timeout> <HTTPTargetConnection> <URL>http://maps.googleapis.com/maps/api/geocode/json</URL> </HTTPTargetConnection> </ServiceCallout>
अनुरोध के मैसेज का कॉन्टेंट GeocodingRequest नाम के वैरिएबल से निकाला जाता है. यह कॉन्टेंट, उदाहरण के लिए, Tasks मैसेज की नीति से अपने-आप जानकारी भर जाती है. जवाब वाला मैसेज इन्हें असाइन किया गया है: GeocodingResponse नाम का वैरिएबल, जहां यह एक 'वैरिएबल निकालें' नीति या JavaScript में लिखे गए कस्टम कोड के ज़रिए पार्स किए जाने के लिए उपलब्ध है या Java का इस्तेमाल करें. यह नीति, Google Geocoding API से जवाब मिलने के लिए 30 सेकंड तक इंतज़ार करती है समय खत्म हो रहा है.
सेवा कॉलआउट के इस उदाहरण के साथ ही, मैसेज और वैरिएबल एक्सट्रैक्ट करने से जुड़ी नीतियां असाइन करना, नीति का इस्तेमाल करना देखें कंपोज़िशन.
कॉल टारगेट सर्वर
<ServiceCallout async="false" continueOnError="false" enabled="true" name="service-callout"> <DisplayName>service-callout</DisplayName> <Properties/> <Request clearPayload="true" variable="myRequest"> <IgnoreUnresolvedVariables>false</IgnoreUnresolvedVariables> </Request> <Response>myResponse</Response> <HTTPTargetConnection> <LoadBalancer> <Algorithm>RoundRobin</Algorithm> <Server name="httpbin"/> <Server name="yahoo"/> </LoadBalancer> <Path>/get</Path> </HTTPTargetConnection> </ServiceCallout>
यह नीति टारगेट सर्वर को कॉल करने और लोड बैलेंसिंग के लिए Load Balancer एट्रिब्यूट का इस्तेमाल करती है ट्रैक करें. इस उदाहरण में, लोड को "httpbin" नाम के दो टारगेट सर्वर में बांटा गया है और "yahoo" शामिल हैं. अपनी प्रॉक्सी के लिए टारगेट सर्वर सेट अप करने और कॉन्फ़िगर करने की जानकारी के लिए लोड बैलेंसिंग, लोड बैलेंसिंग अक्रॉस बैकएंड सर्वर.
सेवा कॉलआउट की नीति के बारे में जानकारी
कई मामलों में एपीआई प्रॉक्सी में सेवा कॉलआउट की नीति का इस्तेमाल किया जा सकता है. इसके लिए उदाहरण के लिए, एपीआई प्रॉक्सी को कॉन्फ़िगर किया जा सकता है, ताकि डिलीवर करने के लिए किसी बाहरी सेवा को कॉल किया जा सके भौगोलिक स्थान का डेटा, ग्राहकों की समीक्षाएं, पार्टनर के रीटेल कैटलॉग में मौजूद आइटम वगैरह.
कॉलआउट का इस्तेमाल आम तौर पर दो अन्य नीतियों के साथ किया जाता है: मैसेज असाइन करना और वैरिएबल एक्सट्रैक्ट करना.
- अनुरोध करें: मैसेज असाइन करने पर, रिमोट पर भेजे गए अनुरोध वाले मैसेज की जानकारी अपने-आप भर जाती है सेवा.
-
रिस्पॉन्स: वैरिएबल निकालें, रिस्पॉन्स को पार्स करता है और खास जानकारी को एक्सट्रैक्ट करता है कॉन्टेंट.
सेवा कॉलआउट की नीति में ये चीज़ें शामिल हैं:
- मैसेज असाइन करें नीति: अनुरोध वाला मैसेज बनाता है, एचटीटीपी हेडर और क्वेरी पैरामीटर अपने-आप भरता है, और एचटीटीपी सेट करता है क्रिया, वगैरह
- सेवा कॉलआउट नीति: 'असाइन करें' मैसेज से बनाए गए मैसेज का रेफ़रंस देती है
नीति, बाहरी कॉल के लिए टारगेट यूआरएल की जानकारी देती है, और रिस्पॉन्स ऑब्जेक्ट के लिए एक नाम तय करती है
जिसे टारगेट सेवा वापस करती है.
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है बेहतर परफ़ॉर्मेंस के लिए, सेवा कॉलआउट के जवाबों को कैश मेमोरी में सेव भी किया जा सकता है. इसका तरीका Apigee कम्यूनिटी थ्रेड: https://community.apigee.com/questions/34110/how-can-i-store-the-results-of-the-servicecallout.html. - वैरिएबल निकालें नीति: आम तौर पर, ऐसे JSONPath या एसएएमएल एक्सप्रेशन को तय करता है जो जनरेट किए गए मैसेज को पार्स करता है सेवा कॉलआउट की मदद से. इसके बाद नीति, सेवा कॉल आउट जवाब.
नीति का इस्तेमाल करना देखें कंपोज़िशन, एपीआई प्रॉक्सी के पूरे नमूने के लिए, जो सेवा कॉल आउट नीति के साथ-साथ 'मैसेज असाइन करें' और 'वैरिएबल एक्सट्रैक्ट करें' नीतियों के बारे में ज़्यादा जानें.
कस्टम गड़बड़ी मैनेज करना
एलिमेंट का रेफ़रंस
यहां ऐसे एलिमेंट और एट्रिब्यूट दिए गए हैं जिन्हें इस नीति पर कॉन्फ़िगर किया जा सकता है:
<ServiceCallout async="false" continueOnError="false" enabled="true" name="Service-Callout-1"> <DisplayName>Custom label used in UI</DisplayName> <Request clearPayload="true" variable="myRequest"> <IgnoreUnresolvedVariables>false</IgnoreUnresolvedVariables> <Remove> <ReasonPhrase/> <StatusCode/> <Path/> <Version/> <Verb/> </Remove> <Copy> <ReasonPhrase/> <StatusCode/> <Path/> <Version/> <Verb/> </Copy> <Add> <Headers/> <QueryParams/> <FormParams/> </Add> <Set> <Headers/> <QueryParams/> <FormParams/> <Payload/> <ReasonPhrase/> <StatusCode/> <Path/> <Version/> <Verb/> </Set> </Request> <Response>calloutResponse</Response> <Timeout>30000</Timeout> <HTTPTargetConnection> <URL>http://example.com</URL> <LoadBalancer/> <SSLInfo/> <Properties/> </HTTPTargetConnection> <LocalTargetConnection> <APIProxy/> <ProxyEndpoint/> <Path/> </LocalTargetConnection> </ServiceCallout>
<ServiceCallout> एट्रिब्यूट
<ServiceCallout async="false" continueOnError="false" enabled="true" name="Service-Callout-1">
यहां दी गई टेबल में, ऐसे एट्रिब्यूट के बारे में बताया गया है जो नीति के सभी पैरंट एलिमेंट में एक जैसे होते हैं:
एट्रिब्यूट | ब्यौरा | डिफ़ॉल्ट | मौजूदगी |
---|---|---|---|
name |
नीति का अंदरूनी नाम. इसके अलावा, नीति को लेबल करने के लिए, |
लागू नहीं | ज़रूरी है |
continueOnError |
किसी नीति के काम न करने पर, गड़बड़ी दिखाने के लिए नीति के लागू होने के बाद भी फ़्लो को एक्ज़ीक्यूट करने के लिए, इसे |
गलत | वैकल्पिक |
enabled |
नीति को लागू करने के लिए, नीति को बंद करने के लिए, |
सही | वैकल्पिक |
async |
यह एट्रिब्यूट अब काम नहीं करता. |
गलत | बहिष्कृत |
<DisplayName> एलिमेंट
इस कॉलम में नीति को लेबल करने के लिए, name
एट्रिब्यूट के साथ-साथ इस्तेमाल करें
मैनेजमेंट यूज़र इंटरफ़ेस (यूआई) प्रॉक्सी एडिटर, जिसका नाम अलग और सामान्य भाषा में है.
<DisplayName>Policy Display Name</DisplayName>
डिफ़ॉल्ट |
लागू नहीं अगर आप इस एलिमेंट को छोड़ देते हैं, तो नीति की |
---|---|
मौजूदगी | वैकल्पिक |
टाइप | स्ट्रिंग |
<Request> एलिमेंट
यह नीति, अनुरोध वाले मैसेज वाले वैरिएबल के बारे में बताती है, जिसे एपीआई प्रॉक्सी से अन्य सेवा. वैरिएबल को फ़्लो में बनाई गई पिछली नीति के ज़रिए बनाया जा सकता है या आपके पास इसे बनाने का विकल्प है सेवा कॉलआउट नीति में इनलाइन देखें.
<Request clearPayload="true" variable="myRequest"> <IgnoreUnresolvedVariables>false</IgnoreUnresolvedVariables> <Remove> <ReasonPhrase/> <StatusCode/> <Path/> <Version/> <Verb/> </Remove> <Copy> <ReasonPhrase/> <StatusCode/> <Path/> <Version/> <Verb/> </Copy> <Add> <Headers/> <QueryParams/> <FormParams/> </Add> <Set> <Headers/> <QueryParams/> <FormParams/> <Payload/> <ReasonPhrase/> <StatusCode/> <Path/> <Version/> <Verb/> </Set> </Request>
<Remove>, <Copy>, <Add>, और <Set> टैग का सिंटैक्स वही होता है जो मैसेज असाइन करें नीति पढ़ें.
अगर अनुरोध के मैसेज का समाधान नहीं किया जा सकता या वह अमान्य है, तो यह नीति गड़बड़ी दिखाती है अनुरोध संदेश प्रकार.
सबसे आसान उदाहरण में, आप ऐसा वैरिएबल पास करते हैं जिसमें अनुरोध वाला मैसेज शामिल होता है. एपीआई प्रॉक्सी के फ़्लो में पहले:
<Request clearPayload="true" variable="myRequest"/>
इसके अलावा, सेवा कॉलआउट की नीति में जाकर, बाहरी सेवा को भेजा गया अनुरोध का मैसेज अपने-आप भरा जा सकता है:
<Request> <Set> <Headers> <Header name="Accept">application/json</Header> </Headers> <Verb>POST</Verb> <Payload contentType="application/json">{"message":"my test message"}</Payload> </Set> <IgnoreUnresolvedVariables>false</IgnoreUnresolvedVariables> </Request>
डिफ़ॉल्ट | अगर अनुरोध एलिमेंट या उसके किसी भी एट्रिब्यूट को छोड़ दिया जाता है, तो Edge
डिफ़ॉल्ट वैल्यू नीचे दी गई हैं:
<Request clearPayload="true" variable="servicecallout.request"/> आइए, देखते हैं कि इन डिफ़ॉल्ट वैल्यू का क्या मतलब है. पहले,
अगर डेटा मास्किंग का इस्तेमाल किया जा रहा है, तो इस डिफ़ॉल्ट नाम के बारे में जानना ज़रूरी है -- अगर वैरिएबल नाम को छोड़ दिया जाता है,
आपको |
मौजूदगी | ज़रूरी नहीं. |
स्ट्रीम किस तरह की है | लागू नहीं |
विशेषताएं
एट्रिब्यूट | ब्यौरा | डिफ़ॉल्ट | मौजूदगी |
---|---|---|---|
वैरिएबल |
उस वैरिएबल का नाम जिसमें अनुरोध वाला मैसेज होगा. |
servicecallout.request |
वैकल्पिक |
clearPayload |
अगर clearPayload सेट करें अनुरोध मैसेज की ज़रूरत होने पर ही 'गलत' पर सेट करें. ऐसा तब ही होगा, जब सेवा कॉलआउट के बाद लागू किया गया. |
सही | वैकल्पिक |
<Request>/<IgnoreUnresolvedVariables> एलिमेंट
true पर सेट करने पर, नीति अनुरोध में ऐसी किसी भी वैरिएबल गड़बड़ी को अनदेखा कर देता है जिसे ठीक नहीं किया गया है.
<Request clearPayload="true" variable="myRequest"> <IgnoreUnresolvedVariables>false</IgnoreUnresolvedVariables> </Request>
डिफ़ॉल्ट | गलत |
मौजूदगी | वैकल्पिक |
स्ट्रीम किस तरह की है | बूलियन |
<Response> एलिमेंट
इस एलिमेंट को तब शामिल करें, जब एपीआई प्रॉक्सी लॉजिक को आगे की प्रक्रिया.
यह एलिमेंट मौजूद होने पर, यह उस वैरिएबल का नाम तय करता है जिसमें बाहरी सेवा से मिला रिस्पॉन्स मैसेज. टारगेट से मिला रिस्पॉन्स इसे असाइन किया जाता है वैरिएबल सिर्फ़ तब सबमिट किया जा सकता है, जब नीति के पूरे रिस्पॉन्स को पढ़ लिया जाए. अगर रिमोट कॉल किसी वजह से कार्रवाई नहीं की जाती, तो नीति गड़बड़ी दिखाती है.
अगर इस एलिमेंट को शामिल नहीं किया जाता, तो एपीआई प्रॉक्सी को जवाब का इंतज़ार नहीं किया जाता; एपीआई प्रॉक्सी फ़्लो
एक्ज़ीक्यूशन, आगे के किसी भी फ़्लो के साथ जारी रहता है. साथ ही, साफ़ तौर पर यह बताओ कि
Response
एलिमेंट, टारगेट से मिला रिस्पॉन्स, इसके ज़रिए प्रोसेसिंग के लिए उपलब्ध नहीं है
है और रिमोट कॉल में गड़बड़ी का पता लगाने के लिए प्रॉक्सी फ़्लो का कोई तरीका उपलब्ध नहीं है.
सर्विसकॉलआउट का इस्तेमाल करते समय Response
एलिमेंट को छोड़ने का सामान्य इस्तेमाल: लॉग करने के लिए
बाहरी सिस्टम को भेजे जाने वाले संदेश.
<Response>calloutResponse</Response>
डिफ़ॉल्ट | लागू नहीं |
मौजूदगी | वैकल्पिक |
स्ट्रीम किस तरह की है | स्ट्रिंग |
<समय खत्म> एलिमेंट
सेवा कॉल आउट नीति के तहत, मिलीसेकंड में जवाब मिलने तक टारगेट. रनटाइम के दौरान, इस वैल्यू को डाइनैमिक तौर पर सेट नहीं किया जा सकता. अगर सेवा कॉलआउट का समय खत्म हो जाता है, तो एचटीटीपी 500 का रिस्पॉन्स मिलता है, नीति काम नहीं करती, और एपीआई प्रॉक्सी गड़बड़ी की स्थिति में जाता है, जैसे कि गड़बड़ियां ठीक करने का तरीका वाले लेख में बताया गया है.
<Timeout>30000</Timeout>
डिफ़ॉल्ट | 55000 मिलीसेकंड (55 सेकंड), Apigee के लिए डिफ़ॉल्ट एचटीटीपी टाइम आउट सेटिंग किनारे |
मौजूदगी | वैकल्पिक |
स्ट्रीम किस तरह की है | पूर्णांक |
<HTTPTargetConnection> एलिमेंट
यूआरएल, TLS/एसएसएल, और एचटीटीपी प्रॉपर्टी जैसी ट्रांसपोर्ट से जुड़ी जानकारी देता है. ज़्यादा जानकारी के लिए,
<TargetEndpoint>
कॉन्फ़िगरेशन रेफ़रंस.
<HTTPTargetConnection> <URL>http://example.com</URL> <LoadBalancer/> <SSLInfo/> <Properties/> </HTTPTargetConnection>
डिफ़ॉल्ट | लागू नहीं |
मौजूदगी | ज़रूरी है |
स्ट्रीम किस तरह की है | लागू नहीं |
<HTTPTargetConnection>/<URL> एलिमेंट
जिस सेवा को कॉल किया जा रहा है उसका URL:
<HTTPTargetConnection> <URL>http://example.com</URL> </HTTPTargetConnection>
किसी वैरिएबल की मदद से, यूआरएल के हिस्से को डाइनैमिक तरीके से सप्लाई किया जा सकता है. हालांकि, नीचे दिया गया http:// यूआरएल किसी वैरिएबल के ज़रिए तय होता है. अगले उदाहरण में, क्वेरी की वैल्यू बताने के लिए वैरिएबल का इस्तेमाल किया जाएगा पैरामीटर:
<URL>http://example.com/forecastrss?w=${request.header.woeid}</URL>
इसके अलावा, यूआरएल पाथ के किसी हिस्से को वैरिएबल के साथ सेट करें:
<URL>http://example.com/{request.resourcePath}?w=${request.header.woeid}</URL>
अगर आपको यूआरएल के डोमेन और पोर्ट की जानकारी देने के लिए, किसी वैरिएबल का इस्तेमाल करना है, तो एक वैरिएबल का इस्तेमाल करें यह सुविधा सिर्फ़ डोमेन और पोर्ट के लिए है. यूआरएल के किसी दूसरे हिस्से के लिए दूसरा वैरिएबल:
<URL>http://{request.dom_port}/{request.resourcePath}</URL>
डिफ़ॉल्ट | लागू नहीं |
मौजूदगी | ज़रूरी है |
स्ट्रीम किस तरह की है | स्ट्रिंग |
<HTTPTargetConnection>/<SSLInfo> एलिमेंट
बैकएंड सेवा के लिए TLS/एसएसएल कॉन्फ़िगरेशन. TLS/SSL कॉन्फ़िगरेशन पर सहायता के लिए, देखें TLS कॉन्फ़िगर करना Edge से बैकएंड (Cloud और Private Cloud) तक और "TLS/SSL TargetEndpoint कॉन्फ़िगरेशन" पर जाते हैं एपीआई प्रॉक्सी कॉन्फ़िगरेशन के रेफ़रंस में.
<HTTPTargetConnection> <URL>https://example.com</URL> <SSLInfo> <Enabled>true</Enabled> <ClientAuthEnabled>true</ClientAuthEnabled> <KeyStore>ref://mykeystoreref</KeyStore> ## Use of a reference is recommended <KeyAlias>myKey</KeyAlias> <TrustStore>myTruststore</TrustStore> <Ciphers/> <Protocols/> </SSLInfo> </HTTPTargetConnection>
डिफ़ॉल्ट | लागू नहीं |
मौजूदगी | वैकल्पिक |
स्ट्रीम किस तरह की है | लागू नहीं |
<HTTPTargetConnection>/<Properties> एलिमेंट
बैकएंड सेवा पर एचटीटीपी ट्रांसपोर्ट प्रॉपर्टी. ज़्यादा जानकारी के लिए, यह देखें एंडपॉइंट प्रॉपर्टी का रेफ़रंस.
<HTTPTargetConnection> <URL>http://example.com</URL> <Properties> <Property name="allow.http10">true</Property> <Property name="request.retain.headers"> User-Agent,Referer,Accept-Language </Property> </Properties> </HTTPTargetConnection>
डिफ़ॉल्ट | लागू नहीं |
मौजूदगी | वैकल्पिक |
स्ट्रीम किस तरह की है | लागू नहीं |
<HTTPTargetConnection>/<LoadBalancer> एलिमेंट
एक या ज़्यादा टारगेट सर्वर पर कॉल करें और बैलेंस लोड करें. कॉल टारगेट देखें सर्वर सैंपल सेक्शन में सैंपल. बैकएंड में लोड बैलेंसिंग की जानकारी भी देखें सर्वर पर सेव कर सकें. यह समुदाय भी देखें इस पोस्ट में, सेवा कॉलआउट की नीति और रास्ते के नियमों का इस्तेमाल करके.
<HTTPTargetConnection> <LoadBalancer> <Algorithm>RoundRobin</Algorithm> <Server name="httpbin"/> <Server name="yahoo"/> </LoadBalancer> <Path>/get</Path> </HTTPTargetConnection>
डिफ़ॉल्ट | लागू नहीं |
मौजूदगी | वैकल्पिक |
स्ट्रीम किस तरह की है | लागू नहीं |
<LocalTargetConnection> एलिमेंट
लोकल प्रॉक्सी तय करता है -- जो उसी संगठन और एनवायरमेंट में मौजूद प्रॉक्सी होती है -- जो सेवा के कॉलआउट का टारगेट.
टारगेट के बारे में ज़्यादा जानकारी देने के लिए, <APIProxy>
और <ProxyEndpoint>
एलिमेंट या <Path>
एलिमेंट का इस्तेमाल करें.
<LocalTargetConnection> <APIProxy/> <ProxyEndpoint/> <Path/> </LocalTargetConnection>
डिफ़ॉल्ट | लागू नहीं |
मौजूदगी | ज़रूरी है |
स्ट्रीम किस तरह की है | लागू नहीं |
<LocalTargetConnection>/<APIProxy> एलिमेंट
उस एपीआई प्रॉक्सी का नाम जो किसी लोकल कॉल का टारगेट है. प्रॉक्सी बराबर होनी चाहिए संगठन और एनवायरमेंट की मदद से कॉल करने वाले प्रॉक्सी सर्वर का इस्तेमाल किया जाता है.
<LocalTargetConnection> <APIProxy>data-manager</APIProxy> <ProxyEndpoint>default</ProxyEndpoint> </LocalTargetConnection>
<APIProxy>
एलिमेंट के साथ-साथ, इन चीज़ों को भी शामिल करें
उस प्रॉक्सी एंडपॉइंट का नाम तय करने के लिए <ProxyEndpoint>
एलिमेंट जिसे
कॉल के लिए लक्षित रहे होंगे.
<LocalTargetConnection> <APIProxy/> <ProxyEndpoint/> </LocalTargetConnection>
डिफ़ॉल्ट | लागू नहीं |
मौजूदगी | ज़रूरी है |
स्ट्रीम किस तरह की है | स्ट्रिंग |
<LocalTargetConnection>/<ProxyEndpoint> एलिमेंट
उस प्रॉक्सी एंडपॉइंट का नाम जिसे कॉल का टारगेट होना चाहिए. यह इसमें प्रॉक्सी एंडपॉइंट है
<APIProxy>
एलिमेंट के साथ तय किया गया एपीआई प्रॉक्सी.
<LocalTargetConnection> <APIProxy>data-manager</APIProxy> <ProxyEndpoint>default</ProxyEndpoint> </LocalTargetConnection>
डिफ़ॉल्ट | लागू नहीं |
मौजूदगी | वैकल्पिक |
स्ट्रीम किस तरह की है | लागू नहीं |
<LocalTargetConnection>/<Path> एलिमेंट
टारगेट किए जा रहे एंडपॉइंट का पाथ. एंडपॉइंट को उसी में प्रॉक्सी को रेफ़र करना चाहिए संगठन और एनवायरमेंट की मदद से कॉल करने वाले प्रॉक्सी सर्वर का इस्तेमाल किया जाता है.
जब इस्तेमाल न हो, तो <APIProxy>/<ProxyEndpoint>
पेयर के बजाय इसका इस्तेमाल करें
प्रॉक्सी नाम को जानते हैं -- या उस पर भरोसा नहीं कर सकता. पाथ कोई भरोसेमंद टारगेट हो सकता है.
<LocalTargetConnection> <Path>/data-manager</Path> </LocalTargetConnection>
डिफ़ॉल्ट | लागू नहीं |
मौजूदगी | वैकल्पिक |
स्ट्रीम किस तरह की है | लागू नहीं |
स्कीमा
फ़्लो वैरिएबल
फ़्लो वैरिएबल, एचटीटीपी के आधार पर रनटाइम के दौरान नीतियों और फ़्लो के डाइनैमिक व्यवहार को चालू करते हैं हेडर, मैसेज कॉन्टेंट या फ़्लो कॉन्टेक्स्ट. पहले से तय फ़्लो वैरिएबल उपलब्ध हैं सेवा कॉल आउट नीति लागू होने के बाद. फ़्लो वैरिएबल के बारे में ज़्यादा जानकारी के लिए, वैरिएबल रेफ़रंस देखें.
सेवा कॉलआउट का अपना अनुरोध और जवाब होता है. साथ ही, इस डेटा को इनके ज़रिए ऐक्सेस किया जा सकता है
वैरिएबल. क्योंकि मुख्य मैसेज में request.*
और
response.*
वैरिएबल प्रीफ़िक्स, myrequest.*
और
calloutResponse.*
प्रीफ़िक्स (सर्विस कॉलआउट कॉन्फ़िगरेशन में डिफ़ॉल्ट)
सेवा कॉल आउट के लिए खास मैसेज डेटा पाएं. नीचे दी गई टेबल में दिए गए पहले उदाहरण में,
देख लें कि आपको सेवा कॉलआउट में एचटीटीपी हेडर कैसे दिखेंगे.
वैरिएबल | ब्यौरा |
---|---|
नीचे सेवा कॉलआउट का अनुरोध और रिस्पॉन्स हेडर पाने का एक उदाहरण दिया गया है यह ठीक वैसे ही होता है जैसे मुख्य अनुरोध और जवाब से हेडर मिलते हैं.
जहां calloutResponse, सेवा में जवाब के लिए वैरिएबल नाम है कॉलआउट और myRequest, अनुरोध के वैरिएबल का नाम है. उदाहरण के लिए:
यह फ़ंक्शन, सेवा कॉलआउट के जवाब के लिए कॉन्टेंट की लंबाई वाला हेडर दिखाता है. |
दायरा: सेवा के कॉलआउट से सेवा कॉलआउट के अनुरोध या जवाब में एक मैसेज हेडर. उदाहरण के लिए, अगर एपीआई प्रॉक्सी टारगेट http://example.com है और सेवा कॉलआउट का टारगेट है http://mocktarget.apigee.net में, ये वैरिएबल कॉलआउट के हेडर हैं: http://mocktarget.apigee.net. |
servicecallout.requesturi |
दायरा: सेवा कॉलआउट के अनुरोध से सर्विसकॉलआउट नीति के लिए TargetEndpoint यूआरआई. यूआरआई, TargetEndpoint का यूआरएल होता है तय नहीं किया जा सकता. |
servicecallout.{policy-name}.target.url |
दायरा: सेवा कॉलआउट के अनुरोध से किसी सेवा के कॉलआउट के लिए टारगेट यूआरएल. |
जहां |
दायरा: सेवा कॉलआउट के जवाब से सेवा के कॉलआउट से मिला जवाब का मुख्य हिस्सा. |
servicecallout.{policy-name}.expectedcn |
दायरा: सेवा कॉलआउट के अनुरोध से सेवा कॉलआउट में बताए गए TargetEndpoint का अनुमानित सामान्य नाम की नीति देखें. इसका इस्तेमाल सिर्फ़ तब किया जा सकता है, जब TargetEndpoint किसी TLS/एसएसएल से जुड़ा हो एंडपॉइंट का इस्तेमाल करें. |
servicecallout.{policy-name}.failed |
दायरा: सेवा कॉलआउट के जवाब से बूलियन से पता चलता है कि नीति लागू हुई, गलत या फ़ेल हुई, सही है. |
गड़बड़ियां
इस सेक्शन में, गड़बड़ी के कोड और गड़बड़ी के मैसेज के बारे में बताया गया है. साथ ही, इन गड़बड़ियों के वैरिएबल के बारे में भी बताया गया है, जो Edge की मदद से सेट किए जाते हैं. यह जानकारी जानना ज़रूरी है कि क्या आप गड़बड़ियों को ठीक करता है. ज़्यादा जानने के लिए, आपके लिए ज़रूरी जानकारी देखें नीति से जुड़ी गड़बड़ियों और हैंडलिंग के बारे में जानकारी गलतियां.
रनटाइम की गड़बड़ियां
नीति के लागू होने पर ये गड़बड़ियां हो सकती हैं.
गड़बड़ी कोड | एचटीटीपी कोड स्थिति | वजह | ठीक करें |
---|---|---|---|
steps.servicecallout.ExecutionFailed |
500 |
यह गड़बड़ी तब हो सकती है, जब:
|
build |
steps.servicecallout.RequestVariableNotMessageType |
500 | नीति में दिए गए अनुरोध वैरिएबल का टाइप मैसेज नहीं है. उदाहरण के लिए, अगर यह कोई स्ट्रिंग या कोई दूसरा गैर-मैसेज टाइप है, तो आपको यह गड़बड़ी दिखेगी. | build |
steps.servicecallout.RequestVariableNotRequestMessageType |
500 | नीति में दिए गए अनुरोध वैरिएबल का टाइप, अनुरोध मैसेज नहीं है. इसके लिए उदाहरण के लिए, अगर यह रिस्पॉन्स का टाइप है, तो आपको यह गड़बड़ी दिखेगी. | build |
डिप्लॉयमेंट से जुड़ी गड़बड़ियां
ये गड़बड़ियां तब हो सकती हैं, जब इस नीति वाली प्रॉक्सी को डिप्लॉय किया जाता है.
गड़बड़ी का नाम | वजह | ठीक करें |
---|---|---|
URLMissing |
<HTTPTargetConnection> में <URL> एलिमेंट
मौजूद नहीं है या खाली है. |
build |
ConnectionInfoMissing |
यह गड़बड़ी तब होती है, जब नीति में
<HTTPTargetConnection> या <LocalTargetConnection>
एलिमेंट. |
build |
InvalidTimeoutValue |
यह गड़बड़ी तब होती है, जब <Timeout> की वैल्यू नेगेटिव या शून्य होती है. |
build |
गड़बड़ी के वैरिएबल
रनटाइम की गड़बड़ी होने पर ये वैरिएबल सेट किए जाते हैं. ज़्यादा जानकारी के लिए, आपके लिए ज़रूरी जानकारी देखें नीति से जुड़ी गड़बड़ियों के बारे में जानकारी.
वैरिएबल | कहां | उदाहरण |
---|---|---|
fault.name="fault_name" |
fault_name गड़बड़ी का नाम है, जैसा कि ऊपर रनटाइम में गड़बड़ियां टेबल में बताया गया है. गड़बड़ी का नाम, गड़बड़ी के कोड का आखिरी हिस्सा होता है. | fault.name = "RequestVariableNotMessageType" |
servicecallout.policy_name.failed |
policy_name, उपयोगकर्ता की ओर से बताया गया उस नीति का नाम है जिसमें गड़बड़ी हुई है. | servicecallout.SC-GetUserData.failed = true |
गड़बड़ी के रिस्पॉन्स का उदाहरण
{ "fault":{ "detail":{ "errorcode":"steps.servicecallout.RequestVariableNotMessageType" }, "faultstring":"ServiceCallout[ServiceCalloutGetMockResponse]: request variable data_str value is not of type Message" } }
गड़बड़ी के नियम का उदाहरण
<faultrule name="VariableOfNonMsgType"></faultrule><FaultRule name="RequestVariableNotMessageType"> <Step> <Name>AM-RequestVariableNotMessageType</Name> </Step> <Condition>(fault.name = "RequestVariableNotMessageType")</Condition> </FaultRule>
मिलते-जुलते विषय
- मैसेज जनरेट करें या उनमें बदलाव करें: मैसेज से जुड़ी नीति असाइन करें
- वैरिएबल निकालें: वैरिएबल निकालें: नीति
- वैरिएबल: वैरिएबल रेफ़रंस
- TLS/एसएसएल कॉन्फ़िगरेशन
- कॉन्फ़िगर करना Edge से बैकएंड तक TLS (क्लाउड और प्राइवेट क्लाउड)
- "TLS/SSL TargetEndpoint कॉन्फ़िगरेशन" एपीआई प्रॉक्सी कॉन्फ़िगरेशन के रेफ़रंस में
- एचटीटीपी ट्रांसपोर्ट प्रॉपर्टी: एंडपॉइंट प्रॉपर्टी का रेफ़रंस
- सेवा कॉलआउट का विकल्प: JavaScript में लिखा गया HTTPClient, देखें JavaScript ऑब्जेक्ट मॉडल