আপনি Apigee Edge ডকুমেন্টেশন দেখছেন।
Apigee X ডকুমেন্টেশনে যান । তথ্য
রানটাইমে ক্যাশ করা মানগুলি কীভাবে লেখা উচিত তা কনফিগার করে।
পপুলেট ক্যাশে নীতিটি একটি স্বল্প-মেয়াদী সাধারণ-উদ্দেশ্য ক্যাশে এন্ট্রি লেখার জন্য ডিজাইন করা হয়েছে। এটি লুকআপ ক্যাশে নীতি (ক্যাশে এন্ট্রি পড়ার জন্য) এবং অবৈধ ক্যাশে নীতি (অকার্যকর এন্ট্রিগুলির জন্য) এর সাথে একত্রে ব্যবহৃত হয়।
ব্যাকএন্ড সম্পদের প্রতিক্রিয়া ক্যাশ করার জন্য, প্রতিক্রিয়া ক্যাশে নীতি দেখুন।
উপাদান রেফারেন্স
এই নীতিতে আপনি যে উপাদানগুলি কনফিগার করতে পারেন তা নিম্নলিখিতগুলি তালিকাভুক্ত করে৷
<PopulateCache async="false" continueOnError="false" enabled="true" name="Populate-Cache-1"> <DisplayName>Populate Cache 1</DisplayName> <Properties/> <CacheKey> <Prefix/> <KeyFragment ref=""/> </CacheKey> <!-- Omit this element if you're using the included shared cache. --> <CacheResource/> <Scope>Exclusive</Scope> <ExpirySettings> <TimeoutInSeconds>300</TimeoutInSeconds> </ExpirySettings> <Source>flowVar</Source> </PopulateCache>
<PopulateCache> বৈশিষ্ট্য
নিম্নলিখিত সারণী সমস্ত নীতির মূল উপাদানগুলির জন্য সাধারণ বৈশিষ্ট্যগুলি বর্ণনা করে:
বৈশিষ্ট্য | বর্ণনা | ডিফল্ট | উপস্থিতি |
---|---|---|---|
name | নীতির অভ্যন্তরীণ নাম। ঐচ্ছিকভাবে, ম্যানেজমেন্ট UI প্রক্সি এডিটরে নীতিটিকে একটি ভিন্ন, প্রাকৃতিক-ভাষা নামের সাথে লেবেল করতে | N/A | প্রয়োজন |
continueOnError | একটি নীতি ব্যর্থ হলে একটি ত্রুটি ফেরত দিতে একটি নীতি ব্যর্থ হওয়ার পরেও ফ্লো এক্সিকিউশন চালিয়ে যেতে | মিথ্যা | ঐচ্ছিক |
enabled | নীতি প্রয়োগ করতে নীতি বন্ধ করতে | সত্য | ঐচ্ছিক |
async | এই বৈশিষ্ট্যটি অবমূল্যায়ন করা হয়েছে৷ | মিথ্যা | অবচয় |
<DisplayName> উপাদান
ম্যানেজমেন্ট UI প্রক্সি এডিটরে নীতিটিকে একটি ভিন্ন, প্রাকৃতিক-ভাষা নামের সাথে লেবেল করতে name
বৈশিষ্ট্য ছাড়াও ব্যবহার করুন।
<DisplayName>Policy Display Name</DisplayName>
ডিফল্ট | N/A আপনি এই উপাদানটি বাদ দিলে, নীতির |
---|---|
উপস্থিতি | ঐচ্ছিক |
টাইপ | স্ট্রিং |
<CacheKey> উপাদান
ক্যাশে সংরক্ষিত ডেটার একটি অংশে একটি অনন্য পয়েন্টার কনফিগার করে।
ক্যাশে কীগুলি 2 KB আকারে সীমাবদ্ধ৷
<CacheKey> <Prefix>string</Prefix> <KeyFragment ref="variable_name" /> <KeyFragment>literal_string</KeyFragment> </CacheKey>
ডিফল্ট: | N/A |
উপস্থিতি: | প্রয়োজন |
প্রকার: | N/A |
<CacheKey>
ক্যাশে সংরক্ষিত ডেটার প্রতিটি অংশের নাম তৈরি করে।
রানটাইমে, <KeyFragment>
মানগুলি হয় <Scope>
উপাদান মান বা <Prefix>
মান দিয়ে প্রিপেন্ড করা হয়। উদাহরণস্বরূপ, নিম্নলিখিত ফলাফল UserToken__apiAccessToken__
< value_of_client_id> এর একটি ক্যাশে কীতে পরিণত হয় :
<CacheKey> <Prefix>UserToken</Prefix> <KeyFragment>apiAccessToken</KeyFragment> <KeyFragment ref="request.queryparam.client_id" /> </CacheKey>
আপনি <CacheKey>
উপাদানটি <Prefix>
এবং <Scope>
এর সাথে ব্যবহার করেন। আরও তথ্যের জন্য, ক্যাশে কীগুলির সাথে কাজ করা দেখুন।
<ক্যাশরিসোর্স> উপাদান
ক্যাশে নির্দিষ্ট করে যেখানে বার্তা সংরক্ষণ করা উচিত।
যদি এই নীতিটি (এবং আপনার সংশ্লিষ্ট LookupCache এবং InvalidateCache নীতি) অন্তর্ভুক্ত শেয়ার করা ক্যাশে ব্যবহার করে তাহলে এই উপাদানটি সম্পূর্ণভাবে বাদ দিন।
<CacheResource>cache_to_use</CacheResource>
ডিফল্ট: | N/A |
উপস্থিতি: | ঐচ্ছিক |
প্রকার: | স্ট্রিং |
ক্যাশে কনফিগার করার বিষয়ে আরও জানতে, একটি পরিবেশ ক্যাশে তৈরি এবং সম্পাদনা দেখুন।
<CacheKey>/<KeyFragment> উপাদান
একটি মান নির্দিষ্ট করে যা ক্যাশে কী-তে অন্তর্ভুক্ত করা উচিত, ক্যাশে করা প্রতিক্রিয়াগুলির সাথে মিলিত অনুরোধগুলির জন্য একটি নামস্থান তৈরি করে৷
<KeyFragment ref="variable_name"/> <KeyFragment>literal_string</KeyFragment>
ডিফল্ট: | N/A |
উপস্থিতি: | ঐচ্ছিক |
প্রকার: | N/A |
এটি একটি কী (একটি স্ট্যাটিক নাম যা আপনি প্রদান করেন) বা একটি মান (একটি পরিবর্তনশীল উল্লেখ করে একটি গতিশীল এন্ট্রি সেট) হতে পারে। ক্যাশে কী তৈরি করতে সমস্ত নির্দিষ্ট টুকরো একত্রিত করা হয় (প্লাস উপসর্গ)।
<KeyFragment>apiAccessToken</KeyFragment> <KeyFragment ref="request.queryparam.client_id" />
আপনি <Prefix>
এবং <Scope>
এর সাথে একত্রে <KeyFragment>
উপাদান ব্যবহার করেন। আরও তথ্যের জন্য, ক্যাশে কীগুলির সাথে কাজ করা দেখুন।
গুণাবলী
বৈশিষ্ট্য | টাইপ | ডিফল্ট | প্রয়োজন | বর্ণনা |
---|---|---|---|---|
রেফ | স্ট্রিং | না | যে ভেরিয়েবল থেকে মান পেতে হবে। এই উপাদানটিতে একটি আক্ষরিক মান থাকলে ব্যবহার করা উচিত নয়। |
<CacheKey>/<Prefix> উপাদান
ক্যাশে কী উপসর্গ হিসাবে ব্যবহার করার জন্য একটি মান নির্দিষ্ট করে।
<Prefix>prefix_string</Prefix>
ডিফল্ট: | N/A |
উপস্থিতি: | ঐচ্ছিক |
প্রকার: | স্ট্রিং |
যখন আপনি একটি <Scope>
-গণিত মানের পরিবর্তে আপনার নিজস্ব মান নির্দিষ্ট করতে চান তখন <Scope>
-এর পরিবর্তে এই মানটি ব্যবহার করুন। যদি সংজ্ঞায়িত করা হয়, <Prefix>
ক্যাশে লিখিত এন্ট্রিগুলির জন্য ক্যাশ কী মান পূর্বে-প্রেপেন্ড করে। একটি <Prefix>
উপাদান মান একটি <Scope>
উপাদান মান ওভাররাইড করে।
আপনি <CacheKey>
এবং <Scope>
এর সাথে একত্রে <Prefix>
উপাদানটি ব্যবহার করেন। আরও তথ্যের জন্য, ক্যাশে কীগুলির সাথে কাজ করা দেখুন।
<ExpirySettings> উপাদান
কখন একটি ক্যাশে এন্ট্রির মেয়াদ শেষ হবে তা নির্দিষ্ট করে। উপস্থিত হলে, <TimeoutInSeconds>
<TimeOfDay>
এবং <ExpiryDate>
উভয়কেই ওভাররাইড করে।
<ExpirySettings> <!-- use exactly one of the following child elements --> <TimeoutInSeconds ref="duration_variable">seconds_until_expiration</TimeoutInSeconds> <ExpiryDate ref="date_variable">expiration_date</ExpiryDate> <TimeOfDay ref="time_variable">expiration_time</TimeOfDay> </ExpirySettings>
ডিফল্ট: | N/A |
উপস্থিতি: | প্রয়োজন |
প্রকার: | N/A |
<ExpirySettings>
এর চাইল্ড উপাদান
ঠিক একটি শিশু উপাদান ব্যবহার করুন. নিচের সারণীটি <ExpirySettings>
এর চাইল্ড এলিমেন্টের একটি বর্ণনা প্রদান করে:
শিশু উপাদান | বর্ণনা |
---|---|
<TimeoutInSeconds> | সেকেন্ডের সংখ্যা যার পরে একটি ক্যাশে এন্ট্রির মেয়াদ শেষ হওয়া উচিত। <ExpirySettings> <TimeoutInSeconds ref="var-containing-duration">expiry</TimeoutInSeconds> </ExpirySettings> এই উপাদানটি এখন-বঞ্চিত |
<ExpiryDate> | একটি ক্যাশে এন্ট্রির মেয়াদ শেষ হওয়ার তারিখ নির্দিষ্ট করে। <ExpirySettings> <ExpiryDate ref="var-containing-date">expiry</ExpiryDate> </ExpirySettings> যদি নির্দিষ্ট করা তারিখটি অতীতের হয়, তবে নীতিটি ক্যাশে করা এন্ট্রিতে সর্বাধিক সময়-টু-লাইভ প্রয়োগ করবে। এই সর্বোচ্চ 30 দিন। |
<TimeOfDay> | দিনের সময় নির্দিষ্ট করে যেখানে একটি ক্যাশে এন্ট্রির মেয়াদ শেষ হওয়া উচিত। <ExpirySettings> <TimeOfDay ref="var-containing-time">expiry</TimeOfDay> </ExpirySettings> |
আপনার সম্ভাব্য শিশু উপাদানগুলির মধ্যে শুধুমাত্র একটি নির্দিষ্ট করা উচিত। আপনি যদি একাধিক উপাদান নির্দিষ্ট করেন, তাহলে অগ্রাধিকারের ক্রম হল: TimeoutInSeconds
, ExpiryDate
, TimeOfDay
।
<ExpirySettings>
-এর উপরোক্ত প্রতিটি চাইল্ড এলিমেন্টের সাথে, আপনি যদি চাইল্ড এলিমেন্টে ঐচ্ছিক ref
অ্যাট্রিবিউট উল্লেখ করেন, তাহলে পলিসি নামকৃত প্রসঙ্গ ভেরিয়েবল থেকে মেয়াদ শেষ হওয়ার মান পুনরুদ্ধার করবে। পরিবর্তনশীল সংজ্ঞায়িত না হলে, নীতি শিশু উপাদানের আক্ষরিক পাঠ্য মান ব্যবহার করে।
<স্কোপ> উপাদান
<CacheKey>
উপাদানে <Prefix>
উপাদান প্রদান করা না হলে একটি ক্যাশে কী-এর জন্য একটি উপসর্গ তৈরি করতে ব্যবহৃত গণনা।
<Scope>scope_enumeration</Scope>
ডিফল্ট: | "এক্সক্লুসিভ" |
উপস্থিতি: | ঐচ্ছিক |
প্রকার: | স্ট্রিং |
<Scope>
সেটিং একটি ক্যাশে কী নির্ধারণ করে যা <Scope>
মান অনুসারে পূর্বে যুক্ত করা হয়। উদাহরণ স্বরূপ, স্কোপ Exclusive
এ সেট করা হলে একটি ক্যাশে কী নিম্নলিখিত ফর্মটি গ্রহণ করবে:
orgName__envName__apiProxyName__deployedRevisionNumber__proxy|TargetName__ [ serializedCacheKey ]
যদি একটি <Prefix>
উপাদান <CacheKey>
-এ উপস্থিত থাকে, তাহলে এটি একটি <Scope>
উপাদান মানকে ছাড়িয়ে যায়। বৈধ মান নীচের গণনা অন্তর্ভুক্ত.
আপনি <CacheKey>
এবং <Prefix>
এর সাথে একযোগে <Scope>
উপাদান ব্যবহার করেন। আরও তথ্যের জন্য, ক্যাশে কীগুলির সাথে কাজ করা দেখুন।
গ্রহণযোগ্য মান
Global | ক্যাশে কী পরিবেশে স্থাপন করা সমস্ত API প্রক্সি জুড়ে ভাগ করা হয়। ক্যাশে কী orgName __ envName __ আকারে আগে লেখা আছে। আপনি যদি |
Application | API প্রক্সি নামটি উপসর্গ হিসাবে ব্যবহৃত হয়। ক্যাশে কী orgName__envName__apiProxyName ফর্মে আগে লেখা আছে। |
Proxy | প্রক্সিএন্ডপয়েন্ট কনফিগারেশন উপসর্গ হিসাবে ব্যবহৃত হয়। ক্যাশে কী orgName__envName__apiProxyName__deployedRevisionNumber__proxyEndpointName আকারে আগে লেখা আছে। |
Target | TargetEndpoint কনফিগারেশন উপসর্গ হিসাবে ব্যবহৃত হয়। orgName__envName__apiProxyName__deployedRevisionNumber__targetEndpointName ফর্মে ক্যাশে কী প্রিপেন্ড করা হয়েছে। |
Exclusive | ডিফল্ট এটি সবচেয়ে নির্দিষ্ট, এবং তাই একটি প্রদত্ত ক্যাশের মধ্যে নেমস্পেস সংঘর্ষের ন্যূনতম ঝুঁকি উপস্থাপন করে। উপসর্গ দুটি রূপের একটি:
orgName__envName__apiProxyName__deployedRevisionNumber__proxyNameITargetName ফর্মে ক্যাশে কী প্রিপেন্ড করা হয়েছে উদাহরণস্বরূপ, সম্পূর্ণ স্ট্রিং এই মত দেখতে পারে: apifactory__test__weatherapi__16__default__apiAccessToken |
<উৎস> উপাদান
পরিবর্তনশীল নির্দিষ্ট করে যার মান ক্যাশে লেখা উচিত।
<Source>source_variable</Source>
ডিফল্ট: | N/A |
উপস্থিতি: | প্রয়োজন |
প্রকার: | স্ট্রিং |
ব্যবহারের নোট
সাধারণ উদ্দেশ্য ক্যাশিং জন্য এই নীতি ব্যবহার করুন. রানটাইমে, <PopulateCache>
নীতি আপনার <Source>
উপাদানে নির্দিষ্ট করা পরিবর্তনশীল থেকে <CacheResource>
এলিমেন্টে নির্দিষ্ট করা ক্যাশে ডেটা লেখে। আপনি <CacheKey>
, <Scope>
, এবং <Prefix>
উপাদানগুলি ব্যবহার করতে পারেন একটি কী নির্দিষ্ট করতে যা আপনি <LookupCache>
নীতি থেকে মান পুনরুদ্ধার করতে ব্যবহার করতে পারেন। ক্যাশ করা মান মেয়াদ শেষ হলে কনফিগার করতে <ExpirySettings>
উপাদানটি ব্যবহার করুন।
PopulateCache নীতি, LookupCache নীতি , এবং InvalidateCache নীতির সাথে সাধারণ উদ্দেশ্য ক্যাশে আপনার কনফিগার করা একটি ক্যাশে বা ডিফল্টরূপে অন্তর্ভুক্ত একটি ভাগ করা ক্যাশে ব্যবহার করে৷ বেশিরভাগ ক্ষেত্রে, অন্তর্নিহিত ভাগ করা ক্যাশে আপনার চাহিদা পূরণ করা উচিত। এই ক্যাশে ব্যবহার করতে, কেবল <CacheResource>
উপাদান বাদ দিন।
ক্যাশে সীমা : বিভিন্ন ক্যাশে সীমা প্রযোজ্য, যেমন নাম এবং মান আকার, ক্যাশের মোট সংখ্যা, একটি ক্যাশে আইটেমের সংখ্যা এবং মেয়াদ শেষ।
অন্তর্নিহিত ডেটা স্টোর সম্পর্কে আরও জানতে, ক্যাশে অভ্যন্তরীণ দেখুন। ক্যাশে কনফিগার করার বিষয়ে আরও জানতে, একটি পরিবেশ ক্যাশে তৈরি এবং সম্পাদনা দেখুন।
ক্যাশে এনক্রিপশন সম্পর্কে
পাবলিক ক্লাউডের জন্য এজ: ক্যাশে শুধুমাত্র PCI - এবং HIPAA- সক্ষম সংস্থাগুলিতে এনক্রিপ্ট করা হয়৷ এই সংস্থাগুলির জন্য এনক্রিপশন সংস্থার ব্যবস্থা করার সময় কনফিগার করা হয়।
ত্রুটি কোড
এই বিভাগটি ফল্ট কোড এবং ত্রুটি বার্তাগুলি বর্ণনা করে যেগুলি ফেরত দেওয়া হয় এবং ত্রুটি ভেরিয়েবলগুলি যেগুলি এজ দ্বারা সেট করা হয় যখন এই নীতিটি একটি ত্রুটি ট্রিগার করে৷ এই তথ্যটি জানা গুরুত্বপূর্ণ যে আপনি ত্রুটিগুলি পরিচালনা করার জন্য ত্রুটির নিয়ম তৈরি করছেন কিনা। আরও জানতে, নীতিগত ত্রুটি এবং হ্যান্ডলিং ফল্ট সম্পর্কে আপনার যা জানা দরকার তা দেখুন৷
রানটাইম ত্রুটি
নীতি কার্যকর করার সময় এই ত্রুটিগুলি ঘটতে পারে৷
ফল্ট কোড | HTTP স্থিতি | যখন ঘটে |
---|---|---|
policies.populatecache.EntryCannotBeCached | 500 | একটি এন্ট্রি ক্যাশে করা যাবে না. বার্তা অবজেক্টটি ক্যাশে করা হচ্ছে এমন একটি ক্লাসের উদাহরণ নয় যা সিরিয়ালাইজেবল। |
স্থাপনার ত্রুটি
আপনি যখন এই নীতি সম্বলিত একটি প্রক্সি স্থাপন করেন তখন এই ত্রুটিগুলি ঘটতে পারে৷
ত্রুটির নাম | কারণ | ঠিক করুন |
---|---|---|
InvalidCacheResourceReference | PopulateCache নীতিতে <CacheResource> উপাদানটি এমন একটি নামে সেট করা হলে এই ত্রুটিটি ঘটে যা পরিবেশে যেখানে API প্রক্সি স্থাপন করা হচ্ছে সেখানে বিদ্যমান নেই। | build |
CacheNotFound | <CacheResource> উপাদানে নির্দিষ্ট করা ক্যাশে বিদ্যমান নেই। | build |
ফল্ট ভেরিয়েবল
যখন এই নীতি একটি ত্রুটি ট্রিগার করে তখন এই ভেরিয়েবলগুলি সেট করা হয়৷ আরও তথ্যের জন্য, নীতি ত্রুটি সম্পর্কে আপনার যা জানা দরকার তা দেখুন।
ভেরিয়েবল | যেখানে | উদাহরণ |
---|---|---|
fault.name=" fault_name " | fault_name হল ফল্টের নাম, যা উপরে রানটাইম ত্রুটির সারণীতে তালিকাভুক্ত করা হয়েছে। ফল্ট নামটি ফল্ট কোডের শেষ অংশ। | fault.name = "EntryCannotBeCached" |
populatecache. policy_name .failed | policy_name হল সেই নীতির ব্যবহারকারী-নির্দিষ্ট নাম যা ত্রুটিটি ফেলেছে। | populatecache.POP-CACHE-1.failed = true |
উদাহরণ ত্রুটি প্রতিক্রিয়া
{ "fault": { "faultstring": "[entry] can not be cached. Only serializable entries are cached.", "detail": { "errorcode": "steps.populatecache.EntryCannotBeCached" } } }
উদাহরণ দোষ নিয়ম
<FaultRule name="Populate Cache Fault"> <Step> <Name>AM-EntryCannotBeCached</Name> <Condition>(fault.name Matches "EntryCannotBeCached") </Condition> </Step> <Condition>(populatecache.POP-CACHE-1.failed = true) </Condition> </FaultRule>