欢迎参加我们将于 2022 年 10 月 18 日举办的 Firebase 峰会(线上线下同时进行),了解 Firebase 如何帮助您加快应用开发速度、满怀信心地发布应用并在之后需要时轻松地扩大应用规模。立即报名

টিপস ও ট্রিকস

এই দস্তাবেজটি ক্লাউড ফাংশনগুলি ডিজাইন, বাস্তবায়ন, পরীক্ষা এবং স্থাপনের জন্য সর্বোত্তম অনুশীলনগুলি বর্ণনা করে৷

যথার্থতা

এই বিভাগটি ক্লাউড ফাংশনগুলি ডিজাইন এবং বাস্তবায়নের জন্য সাধারণ সর্বোত্তম অনুশীলনগুলি বর্ণনা করে৷

অক্ষমতার ফাংশন লিখ

আপনার ফাংশনগুলিকে একাধিকবার কল করা হলেও একই ফলাফল পাওয়া উচিত। এটি আপনাকে একটি আমন্ত্রণ পুনরায় চেষ্টা করতে দেয় যদি পূর্ববর্তী আহ্বানটি আপনার কোডের মাধ্যমে আংশিকভাবে ব্যর্থ হয়। আরও তথ্যের জন্য, ইভেন্ট-চালিত ফাংশন পুনরায় চেষ্টা করা দেখুন।

ব্যাকগ্রাউন্ড কার্যক্রম শুরু করবেন না

ব্যাকগ্রাউন্ড অ্যাক্টিভিটি হল আপনার ফাংশন বন্ধ হয়ে যাওয়ার পর যা ঘটে। একটি ফাংশন ইনভোকেশন শেষ হয়ে গেলে ফাংশন রিটার্ন করলে বা অন্যথায় সম্পূর্ণ হওয়ার সংকেত দেয়, যেমন Node.js ইভেন্ট-চালিত ফাংশনে callback আর্গুমেন্ট কল করে। সুন্দর সমাপ্তির পরে চালানো যেকোন কোড CPU অ্যাক্সেস করতে পারে না এবং কোনো অগ্রগতি করতে পারে না।

উপরন্তু, যখন একই পরিবেশে পরবর্তী আমন্ত্রণ কার্যকর করা হয়, তখন আপনার পটভূমি কার্যকলাপ পুনরায় শুরু হয়, নতুন আহ্বানে হস্তক্ষেপ করে। এটি অপ্রত্যাশিত আচরণ এবং ত্রুটির কারণ হতে পারে যা নির্ণয় করা কঠিন। একটি ফাংশন বন্ধ হওয়ার পরে নেটওয়ার্ক অ্যাক্সেস করা সাধারণত সংযোগগুলি পুনরায় সেট করার দিকে পরিচালিত করে ( ECONNRESET ত্রুটি কোড)।

ব্যাকগ্রাউন্ড অ্যাক্টিভিটি প্রায়শই পৃথক আমন্ত্রণ থেকে লগগুলিতে সনাক্ত করা যেতে পারে, আমন্ত্রণ শেষ হয়েছে বলে লাইনের পরে লগ করা কিছু খুঁজে বের করে। ব্যাকগ্রাউন্ড অ্যাক্টিভিটি কখনও কখনও কোডের গভীরে চাপা পড়ে যেতে পারে, বিশেষ করে যখন অ্যাসিঙ্ক্রোনাস অপারেশন যেমন কলব্যাক বা টাইমার উপস্থিত থাকে। আপনি ফাংশনটি বন্ধ করার আগে সমস্ত অ্যাসিঙ্ক্রোনাস অপারেশন শেষ হয়েছে তা নিশ্চিত করতে আপনার কোড পর্যালোচনা করুন।

সর্বদা অস্থায়ী ফাইল মুছে দিন

অস্থায়ী ডিরেক্টরিতে স্থানীয় ডিস্ক স্টোরেজ একটি ইন-মেমরি ফাইল সিস্টেম। আপনি যে ফাইলগুলি লেখেন সেগুলি আপনার ফাংশনের জন্য উপলব্ধ মেমরি ব্যবহার করে এবং কখনও কখনও আহ্বানের মধ্যে টিকে থাকে। এই ফাইলগুলি স্পষ্টভাবে মুছে ফেলতে ব্যর্থ হলে শেষ পর্যন্ত মেমরির বাইরের ত্রুটি এবং পরবর্তী ঠান্ডা শুরু হতে পারে।

আপনি GCP কনসোলের ফাংশনের তালিকায় এটি নির্বাচন করে এবং মেমরি ব্যবহারের প্লট বেছে নিয়ে একটি পৃথক ফাংশন দ্বারা ব্যবহৃত মেমরি দেখতে পারেন।

অস্থায়ী ডিরেক্টরির বাইরে লেখার চেষ্টা করবেন না এবং ফাইল পাথ তৈরি করতে প্ল্যাটফর্ম/ওএস-স্বাধীন পদ্ধতি ব্যবহার করতে ভুলবেন না।

পাইপলাইনিং ব্যবহার করে বড় ফাইল প্রসেস করার সময় আপনি মেমরির প্রয়োজনীয়তা কমাতে পারেন। উদাহরণস্বরূপ, আপনি একটি রিড স্ট্রিম তৈরি করে, একটি স্ট্রিম-ভিত্তিক প্রক্রিয়ার মাধ্যমে পাস করে এবং সরাসরি ক্লাউড স্টোরেজে আউটপুট স্ট্রীম লিখে ক্লাউড স্টোরেজে একটি ফাইল প্রক্রিয়া করতে পারেন।

টুলস

এই বিভাগটি ক্লাউড ফাংশনগুলি বাস্তবায়ন, পরীক্ষা এবং ইন্টারঅ্যাক্ট করার জন্য সরঞ্জামগুলি কীভাবে ব্যবহার করতে হয় তার নির্দেশিকা প্রদান করে৷

স্থানীয় উন্নয়ন

ফাংশন স্থাপনে কিছুটা সময় লাগে, তাই স্থানীয়ভাবে আপনার ফাংশনের কোড পরীক্ষা করা প্রায়শই দ্রুত হয়।

Firebase ডেভেলপাররা Firebase CLI ক্লাউড ফাংশন এমুলেটর ব্যবহার করতে পারেন।

ইমেল পাঠাতে Sendgrid ব্যবহার করুন

ক্লাউড ফাংশন পোর্ট 25-এ আউটবাউন্ড সংযোগের অনুমতি দেয় না, তাই আপনি একটি SMTP সার্ভারে অ-সুরক্ষিত সংযোগ করতে পারবেন না। ইমেল পাঠানোর প্রস্তাবিত উপায় হল SendGrid ব্যবহার করা। আপনি Google Compute Engine-এর জন্য একটি ইনস্ট্যান্স টিউটোরিয়াল থেকে পাঠানো ইমেল-এ ইমেল পাঠানোর জন্য অন্যান্য বিকল্প খুঁজে পেতে পারেন।

কর্মক্ষমতা

এই বিভাগে কর্মক্ষমতা অপ্টিমাইজ করার জন্য সর্বোত্তম অনুশীলন বর্ণনা করে।

নির্ভরতাকে বুদ্ধিমানের সাথে ব্যবহার করুন

যেহেতু ফাংশন স্টেটলেস, এক্সিকিউশন এনভায়রনমেন্ট প্রায়শই স্ক্র্যাচ থেকে শুরু করা হয় ( কোল্ড স্টার্ট হিসাবে পরিচিত সময়)। যখন একটি ঠান্ডা শুরু হয়, তখন ফাংশনের বিশ্বব্যাপী প্রেক্ষাপট মূল্যায়ন করা হয়।

যদি আপনার ফাংশনগুলি মডিউলগুলি আমদানি করে, তবে সেই মডিউলগুলির জন্য লোডের সময় একটি কোল্ড স্টার্টের সময় আমন্ত্রণ বিলম্বিত করতে পারে৷ নির্ভরতা সঠিকভাবে লোড করে এবং আপনার ফাংশন ব্যবহার করে না এমন নির্ভরতা লোড না করে আপনি এই লেটেন্সি, সেইসাথে আপনার ফাংশন স্থাপনের জন্য প্রয়োজনীয় সময় কমাতে পারেন।

ভবিষ্যতের আহ্বানে বস্তুগুলিকে পুনরায় ব্যবহার করতে বিশ্বব্যাপী ভেরিয়েবল ব্যবহার করুন

কোনো গ্যারান্টি নেই যে ক্লাউড ফাংশনের অবস্থা ভবিষ্যতের আহ্বানের জন্য সংরক্ষণ করা হবে। যাইহোক, ক্লাউড ফাংশন প্রায়ই পূর্ববর্তী আহ্বানের কার্যকরী পরিবেশকে পুনর্ব্যবহার করে। আপনি যদি বৈশ্বিক সুযোগে একটি পরিবর্তনশীল ঘোষণা করেন, তাহলে এর মান পুনরায় গণনা না করেই পরবর্তী আহ্বানে পুনরায় ব্যবহার করা যেতে পারে।

এইভাবে আপনি বস্তুগুলি ক্যাশে করতে পারেন যা প্রতিটি ফাংশন আহ্বানে পুনরায় তৈরি করা ব্যয়বহুল হতে পারে। এই ধরনের বস্তুগুলিকে ফাংশন বডি থেকে গ্লোবাল স্কোপে স্থানান্তর করার ফলে উল্লেখযোগ্য কর্মক্ষমতা উন্নতি হতে পারে। নিম্নলিখিত উদাহরণটি প্রতি ফাংশন ইনস্ট্যান্সে শুধুমাত্র একবার একটি ভারী বস্তু তৈরি করে এবং প্রদত্ত উদাহরণে পৌঁছানো সমস্ত ফাংশন আহ্বান জুড়ে এটি ভাগ করে:

console.log('Global scope');
const perInstance = heavyComputation();
const functions = require('firebase-functions');

exports.function = functions.https.onRequest((req, res) => {
    console.log('Function invocation');
    const perFunction = lightweightComputation();

    res.send(`Per instance: ${perInstance}, per function: ${perFunction}`);
});

গ্লোবাল স্কোপে নেটওয়ার্ক সংযোগ, লাইব্রেরি রেফারেন্স এবং API ক্লায়েন্ট অবজেক্ট ক্যাশে করা বিশেষভাবে গুরুত্বপূর্ণ। উদাহরণের জন্য নেটওয়ার্কিং অপ্টিমাইজ করা দেখুন।

গ্লোবাল ভেরিয়েবলের অলস সূচনা করুন

আপনি যদি বৈশ্বিক সুযোগে ভেরিয়েবল শুরু করেন, তাহলে ইনিশিয়ালাইজেশন কোডটি সর্বদা একটি কোল্ড স্টার্ট ইনভোকেশনের মাধ্যমে কার্যকর করা হবে, আপনার ফাংশনের লেটেন্সি বাড়িয়ে দেবে। কিছু কিছু ক্ষেত্রে, এটি একটি try / catch ব্লকে যথাযথভাবে পরিচালনা না করা হলে কল করা পরিষেবাগুলির মাঝে মাঝে টাইমআউট হয়ে যায়। যদি কিছু অবজেক্ট সমস্ত কোড পাথে ব্যবহার না করা হয়, তাহলে চাহিদা অনুযায়ী অলসভাবে শুরু করার কথা বিবেচনা করুন:

const functions = require('firebase-functions');
let myCostlyVariable;

exports.function = functions.https.onRequest((req, res) => {
    doUsualWork();
    if(unlikelyCondition()){
        myCostlyVariable = myCostlyVariable || buildCostlyVariable();
    }
    res.status(200).send('OK');
});

এটি বিশেষভাবে গুরুত্বপূর্ণ যদি আপনি একটি ফাইলে বেশ কয়েকটি ফাংশন সংজ্ঞায়িত করেন এবং বিভিন্ন ফাংশন বিভিন্ন ভেরিয়েবল ব্যবহার করে। আপনি অলস ইনিশিয়ালাইজেশন ব্যবহার না করলে, আপনি ভেরিয়েবলের উপর রিসোর্স নষ্ট করতে পারেন যেগুলি আরম্ভ করা হয়েছে কিন্তু কখনই ব্যবহার করা হয়নি।

ন্যূনতম সংখ্যক দৃষ্টান্ত সেট করে ঠান্ডা শুরু কম করুন

ডিফল্টরূপে, ক্লাউড ফাংশন ইনকামিং অনুরোধের সংখ্যার উপর ভিত্তি করে দৃষ্টান্তের সংখ্যা স্কেল করে। ক্লাউড ফাংশনগুলিকে অনুরোধ পরিবেশনের জন্য প্রস্তুত থাকতে হবে এমন নূন্যতম সংখ্যক দৃষ্টান্ত সেট করে আপনি এই ডিফল্ট আচরণ পরিবর্তন করতে পারেন। একটি ন্যূনতম সংখ্যক দৃষ্টান্ত সেট করা আপনার আবেদনের ঠান্ডা শুরুকে হ্রাস করে। যদি আপনার আবেদনটি লেটেন্সি-সংবেদনশীল হয় তবে আমরা ন্যূনতম সংখ্যক দৃষ্টান্ত সেট করার পরামর্শ দিই।

এই রানটাইম বিকল্পগুলি সম্পর্কে আরও তথ্যের জন্য নিয়ন্ত্রণ স্কেলিং আচরণ দেখুন।

অতিরিক্ত সম্পদ

"Google ক্লাউড পারফরম্যান্স অ্যাটলাস" ভিডিও ক্লাউড ফাংশন কোল্ড বুট টাইম -এ পারফরম্যান্স অপ্টিমাইজ করার বিষয়ে আরও জানুন।