প্রতিবেদনের জন্য লুকার স্টুডিওর নিজস্ব ক্যাশে সিস্টেম রয়েছে। আপনার সংযোগকারী তৈরি করার সময়, আপনি দ্রুত প্রতিবেদনের সুবিধার্থে একটি কাস্টম ক্যাশে প্রয়োগ করতে পারেন এবং APR হার-সীমা এড়াতে পারেন।
উদাহরণস্বরূপ, আপনি একটি সংযোগকারী তৈরি করছেন যা একটি নির্দিষ্ট জিপ কোডের জন্য গত 7 দিনের ঐতিহাসিক আবহাওয়ার ডেটা প্রদান করে। আপনার সংযোগকারীটি বেশ জনপ্রিয় হয়ে উঠছে তবে আপনি যে বাহ্যিক API থেকে ডেটা আনছেন তার কঠোর হারের সীমা রয়েছে৷ API শুধুমাত্র প্রতিদিন তার ডেটা আপডেট করে, তাই একটি নির্দিষ্ট জিপ কোডের জন্য, একই ডেটা এক দিনের মধ্যে একাধিকবার আনতে হবে না। এই সমাধান নির্দেশিকা ব্যবহার করে, আপনি প্রতিটি জিপ কোডের জন্য একটি দৈনিক ক্যাশে প্রয়োগ করতে পারেন।
প্রয়োজনীয়তা
- একটি ফায়ারবেস রিয়েলটাইম ডাটাবেস । আপনার যদি একটিতে অ্যাক্সেস না থাকে তবে একটি Google ক্লাউড প্ল্যাটফর্ম (GCP) প্রকল্প তৈরি করুন এবং আপনার নিজস্ব Firebase রিয়েলটাইম ডেটাবেস উদাহরণ তৈরি করতে শুরু করুন নির্দেশিকা অনুসরণ করুন৷
- ফায়ারবেস রিয়েলটাইম ডেটাবেস থেকে ডেটা পড়তে এবং লেখার জন্য একটি GCP পরিষেবা অ্যাকাউন্ট।
- একটি কমিউনিটি সংযোগকারী যা একটি উৎস থেকে ডেটা নিয়ে আসে।
সীমাবদ্ধতা
- এই সমাধানটি লুকার স্টুডিও অ্যাডভান্সড সার্ভিসের সাথে ব্যবহার করা যাবে না। আপনি যখন Looker Studio Advanced Services ব্যবহার করেন, তখন Apps Script-এ আপনার সংযোগকারী কোডের ডেটাতে অ্যাক্সেস থাকে না। সুতরাং আপনি অ্যাপস স্ক্রিপ্ট ব্যবহার করে ডেটা ক্যাশে করতে পারবেন না।
- রিপোর্ট সম্পাদক এবং দর্শকরা এই নির্দিষ্ট ক্যাশে রিসেট করতে পারবেন না।
সমাধান
একটি পরিষেবা অ্যাকাউন্ট বাস্তবায়ন করুন
- আপনার Google ক্লাউড প্রকল্পে একটি পরিষেবা অ্যাকাউন্ট তৈরি করুন ।
- ক্লাউড প্রোজেক্টে এই পরিষেবা অ্যাকাউন্টের BigQuery অ্যাক্সেস আছে কিনা তা নিশ্চিত করুন।
- প্রয়োজনীয় আইডেন্টিটি এবং অ্যাক্সেস ম্যানেজমেন্ট (IAM) ভূমিকা:
Firebase Admin
- প্রয়োজনীয় আইডেন্টিটি এবং অ্যাক্সেস ম্যানেজমেন্ট (IAM) ভূমিকা:
- পরিষেবা অ্যাকাউন্ট কী পেতে JSON ফাইলটি ডাউনলোড করুন। আপনার সংযোগকারী প্রকল্পের স্ক্রিপ্ট বৈশিষ্ট্যে ফাইলের বিষয়বস্তু সংরক্ষণ করুন। কীগুলি যোগ করার পরে, অ্যাপস স্ক্রিপ্ট UI-তে এটির মতো দেখতে হবে:
- আপনার Apps স্ক্রিপ্ট প্রকল্পে Apps স্ক্রিপ্ট লাইব্রেরির জন্য OAuth2 অন্তর্ভুক্ত করুন ।
- পরিষেবা অ্যাকাউন্টের জন্য প্রয়োজনীয় OAuth2 কোড প্রয়োগ করুন:
Firebase থেকে পড়তে এবং লিখতে কোড প্রয়োগ করুন
আপনি ফায়ারবেস রিয়েলটাইম ডাটাবেসে পড়তে এবং লিখতে Firebase Database REST API ব্যবহার করবেন। নিম্নলিখিত কোড এই API অ্যাক্সেস করার জন্য প্রয়োজনীয় পদ্ধতি প্রয়োগ করে।
getData() প্রয়োগ করুন
ক্যাশিং ছাড়া আপনার বিদ্যমান getData()
কোডের কাঠামোটি এইরকম হওয়া উচিত:
আপনার getData()
কোডে ক্যাশিং ব্যবহার করতে, এই পদক্ষেপগুলি অনুসরণ করুন:
- ডেটার 'খণ্ড' বা 'ইউনিট' নির্ধারণ করুন যা ক্যাশে করা উচিত।
ক্যাশে ডেটার ন্যূনতম ইউনিট সংরক্ষণ করতে একটি অনন্য কী তৈরি করুন।
উদাহরণ বাস্তবায়নের জন্য,configparams
থেকেzipcode
কী হিসাবে ব্যবহার করা হচ্ছে।
ঐচ্ছিক : প্রতি-ব্যবহারকারী ক্যাশের জন্য, বেস কী এবং ব্যবহারকারীর পরিচয় সহ একটি যৌগিক কী তৈরি করুন। উদাহরণ বাস্তবায়ন:
js var baseKey = getBaseKey(request); var userEmail = Session.getEffectiveUser().getEmail(); var hasheduserEmail = getHashedValue(userEmail); var compositeKey = baseKey + hasheduserEmail;
ক্যাশে ডেটা বিদ্যমান থাকলে, ক্যাশে তাজা কিনা তা পরীক্ষা করুন।
উদাহরণে, একটি নির্দিষ্ট জিপ কোডের জন্য ক্যাশে করা ডেটা বর্তমান তারিখের সাথে সংরক্ষিত হয়। যখন ক্যাশে থেকে ডেটা পুনরুদ্ধার করা হয়, তখন ক্যাশের তারিখ বর্তমান তারিখের বিপরীতে চেক করা হয়।var cacheForZipcode = { data: <data being cached>, ymd: <current date in YYYYMMDD format> }
যদি ক্যাশ করা ডেটা বিদ্যমান না থাকে বা ক্যাশে করা ডেটা তাজা না হয়, উৎস থেকে ডেটা আনুন এবং ক্যাশে সংরক্ষণ করুন।
নিম্নলিখিত উদাহরণে, main.js
ক্যাশিং প্রয়োগের সাথে getData()
কোড অন্তর্ভুক্ত করে।
উদাহরণ কোড
অতিরিক্ত সম্পদ
Chrome UX সংযোগকারী হাজার হাজার ব্যবহারকারীকে একটি ~20GB BigQuery টেবিলের উপর ভিত্তি করে একটি ড্যাশবোর্ডের সুবিধা দেয়৷ এই সংযোগকারী দুটি স্তরযুক্ত ক্যাশিং পদ্ধতির জন্য Apps স্ক্রিপ্ট ক্যাশে পরিষেবা সহ Firebase রিয়েলটাইম ডেটাবেস ব্যবহার করে। বাস্তবায়নের বিশদ বিবরণের জন্য কোড দেখুন।