उदाहरण: अलग-अलग कामों के लिए इस्तेमाल की जाने वाली कैश मेमोरी

आपको Apigee Edge दस्तावेज़ दिख रहा है.
Apigee X के दस्तावेज़ पर जाएं.
जानकारी

नीतियों का इस्तेमाल करके, डेटा को सामान्य कैश मेमोरी में सेव किया जा सकता है, ताकि उसे तेज़ी से वापस पाया जा सके. इसका उपयोग करके तो आपका प्रॉक्सी, रनटाइम के दौरान कैश मेमोरी में मौजूद डेटा को सेव और वापस पा सकता है:

ये नीतियां, आपकी प्रॉक्सी का इस्तेमाल किए गए डेटा को सामान्य तौर पर कैश मेमोरी में सेव करने के लिए बनाई गई हैं.

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

हर तरह की नीति को एक्सएमएल स्कीमा (.xsd) से तय किया जाता है. रेफ़रंस के लिए, GitHub पर नीति के स्कीमा उपलब्ध हैं.

नीचे दिए गए उदाहरण में, पॉप-अप कैश का इस्तेमाल करके कैश मेमोरी में OAuth ऐक्सेस टोकन लिखा जाता है की नीति देखें. OAuth टोकन, lookupcache नीति के ज़रिए किए गए बाद के अनुरोधों के लिए काे रिकवर किया जाता है. एक बार ऐक्सेस टोकन की समयसीमा खत्म हो जाती है. नया ऐक्सेस टोकन फिर से पाने के लिए, JavaScript का इस्तेमाल किया जाता है. इसके बदले में, इसे कैश मेमोरी में सेव किया जाता है सेटलमेंट कैश मेमोरी की नीति के मुताबिक बनाया गया है.

कैश मेमोरी को पॉप्युलेट करें

कैश मेमोरी में डेटा सेव करने के लिए, File परेशानी नीति का इस्तेमाल करें. यह उदाहरण OAuth ऐक्सेस में बदलाव करता है टोकन को कैश मेमोरी में सेव करना. नीति से जुड़ी जानकारी के लिए, इसे देखें कैश मेमोरी भरने से जुड़ी नीति.

<PopulateCache name="token-cache">
    <!-- The cache to write to. -->
    <CacheResource>mycache</CacheResource>
    <!-- The source of the data, a variable containing the value. -->
    <Source>twitter-translate.apiAccessToken</Source>
    <!-- An enumeration representing a prefix for namespace scope. -->
    <Scope>Exclusive</Scope>
    <!-- A unique pointer (a flow variable value) to the data. Use this later to retrieve it. -->
    <CacheKey>
        <KeyFragment>apiAccessToken</KeyFragment>
        <KeyFragment ref="request.queryparam.client_id"></KeyFragment>
    </CacheKey>
    <!-- Entries placed into the cache with this policy will expire after 600 seconds. -->
    <ExpirySettings>
        <TimeoutInSec>600</TimeoutInSec>
    </ExpirySettings>
</PopulateCache>

वैरिएबल में अपने-आप जानकारी भरने के लिए, नीतियों या कोड का इस्तेमाल किया जा सकता है. इसमें Source वैरिएबल उदाहरण को नीचे दिए गए JavaScript कॉल से भरा जाता है: context.setVariable('twitter-translate.apiAccessToken', getAccessToken());

कैश कुंजियों के बारे में ज़्यादा जानकारी के लिए, कैश कुंजियों के साथ काम करना देखें.

कैश मेमोरी में सेव किया गया डेटा देखना

lookupकैश नीति की मदद से, कैश मेमोरी में सेव की गई वैल्यू वापस पाई जा सकती हैं. लुकअपकैश मेमोरी से जुड़ी यह नीति नीचे दी गई है mycache से कोई मान पढ़ता है और वैरिएबल twitter-translate.apiAccessToken. नीति से जुड़ी जानकारी के लिए जानकारी के लिए, lookupकैश नीति देखें.

<LookupCache name="token-cache">
    <!-- The cache to read from. -->
    <CacheResource>mycache</CacheResource>
    <!-- Where to assign the retrieved value - here, a variable. -->
    <AssignTo>twitter-translate.apiAccessToken</AssignTo>
    <!-- An enumeration representing a prefix for namespace scope. -->
    <Scope>Exclusive</Scope>
    <!-- The unique pointer (a flow variable value) that was used to store the data in the cache. -->

    <CacheKey>
        <KeyFragment>apiAccessToken</KeyFragment>
        <KeyFragment ref="request.queryparam.client_id"></KeyFragment>
    </CacheKey>
</LookupCache>

कैश मेमोरी की पुष्टि करें

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

<InvalidateCache name="InvalidateMyCache">
    <!-- The cache to invalidate. -->
    <CacheResource>test-cache</CacheResource>
    <!-- An enumeration representing a prefix for namespace scope. -->
    <Scope>Exclusive</Scope>
    <!-- Fragments constructing the unique pointer used when 
        the data was put into the cache. -->
    <CacheKey>
        <KeyFragment>apiAccessToken</KeyFragment>
        <KeyFragment ref="request.queryparam.client_id" />
    </CacheKey>
    <PurgeChildEntries>true</PurgeChildEntries>
</InvalidateCache>