উদাহরণ: সাধারণ উদ্দেশ্য ক্যাশিং

আপনি Apigee Edge ডকুমেন্টেশন দেখছেন।
Apigee X ডকুমেন্টেশনে যান
তথ্য

আপনি দ্রুত পুনরুদ্ধারের জন্য একটি সাধারণ উদ্দেশ্য ক্যাশে ডেটা সংরক্ষণ করতে নীতিগুলি ব্যবহার করতে পারেন৷ নিম্নলিখিত নীতিগুলি ব্যবহার করে, আপনার প্রক্সি রানটাইমে ক্যাশে করা ডেটা সংরক্ষণ এবং পুনরুদ্ধার করতে পারে:

এই নীতিগুলি আপনার প্রক্সি দ্বারা ব্যবহৃত ডেটার সাধারণ ক্যাশিংয়ের জন্য ডিজাইন করা হয়েছে৷

এই বিষয়ের নমুনা কোডটি Github-এ আউটবাউন্ড OAuth নমুনা প্রক্সির উপর ভিত্তি করে ( নমুনা তালিকা দেখুন)। এই নমুনা একাধিক আউটবাউন্ড কল জুড়ে পুনরায় ব্যবহারের জন্য একটি OAuth অ্যাক্সেস টোকেন সংরক্ষণ করতে ক্যাশে নীতি ব্যবহার করে।

প্রতিটি নীতির ধরন একটি XML স্কিমা (.xsd) দ্বারা সংজ্ঞায়িত করা হয়। রেফারেন্সের জন্য, নীতি স্কিমা GitHub এ উপলব্ধ।

নিম্নলিখিত উদাহরণে, একটি PopulateCache নীতি ব্যবহার করে একটি OAuth অ্যাক্সেস টোকেন ক্যাশে লেখা হয়৷ OAuth টোকেন একটি LookupCache নীতি দ্বারা পরবর্তী অনুরোধের জন্য পুনরুদ্ধার করা হয়। একবার অ্যাক্সেস টোকেনের মেয়াদ শেষ হয়ে গেলে, জাভাস্ক্রিপ্ট একটি নতুন অ্যাক্সেস টোকেন পুনরুদ্ধার করতে ব্যবহার করা হয়, যা পপুলেটক্যাশ নীতি দ্বারা ক্যাশে করা হয়।

ক্যাশে পপুলেট করুন

ক্যাশে ডেটা লিখতে PopulateCache নীতি ব্যবহার করুন। এই উদাহরণটি ক্যাশে একটি 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 ভেরিয়েবল নিম্নলিখিত জাভাস্ক্রিপ্ট কল দ্বারা পপুলেট করা হয়েছে: context.setVariable('twitter-translate.apiAccessToken', getAccessToken());

ক্যাশে কী সম্পর্কে আরও জানতে, ক্যাশে কীগুলির সাথে কাজ করা দেখুন।

ক্যাশে করা ডেটা দেখুন

আপনি LookupCache নীতির মাধ্যমে ক্যাশে করা মান পুনরুদ্ধার করতে পারেন। নিম্নলিখিত LookupCache নীতিটি mycache থেকে একটি মান পড়ে এবং ভ্যারিয়েবল twitter-translate.apiAccessToken এ মানটি লিখে। নীতির রেফারেন্স তথ্যের জন্য, দেখুন লুকআপক্যাচে নীতি

<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>

ক্যাশে বাতিল করুন

একটি HTTP শিরোনাম উল্লেখ করে ক্যাশে স্পষ্টভাবে অবৈধ করা যেতে পারে। নির্দিষ্ট HTTP শিরোনাম ধারণকারী একটি অনুরোধ প্রাপ্ত হলে, ক্যাশে ফ্লাশ করা হবে। নীতির রেফারেন্স তথ্যের জন্য, InvalidateCache নীতি দেখুন।

<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>