লগিং কোড ডিবাগিং এবং মনিটরিং এর জন্য একটি গুরুত্বপূর্ণ টুল। Cloud Functions আপনাকে এর লগার SDK, কাস্টম গুগল Cloud Logging , অথবা ওয়েব ডেভেলপমেন্টের জন্য console অবজেক্ট স্ট্যান্ডার্ড ব্যবহারের বিকল্প দেয়।
লগ লেখা
যদিও বেশিরভাগ পরিস্থিতিতে Cloud Functions লগার SDK সুপারিশ করা হয়, আপনি নিম্নলিখিত কারণগুলির জন্য অন্য বিকল্পগুলির মধ্যে একটি বেছে নিতে পারেন:
- আপনার একটি বিদ্যমান কোড বেস আছে এবং আপনি
console.logথেকে রিফ্যাক্টর করতে পছন্দ করেন না। - আপনি Cloud Logging (পূর্বে স্ট্যাকড্রাইভার লগিং) এর সাথে পরিচিত এবং কাস্টম লগিংয়ের জন্য এটি ব্যবহার করতে পছন্দ করেন।
Cloud Functions লগার SDK ব্যবহার করা
Cloud Functions লগার SDK একটি স্ট্যান্ডার্ড ইন্টারফেস প্রদান করে যার api console.log স্টেটমেন্টের অনুরূপ এবং অন্যান্য লগ লেভেল সমর্থন করে। আপনি স্ট্রাকচার্ড ডেটা সহ ইভেন্ট লগ করতে এই SDK ব্যবহার করতে পারেন, যা বিশ্লেষণ এবং পর্যবেক্ষণকে সহজ করে তোলে।
লগার SDK ওয়াইল্ডকার্ড আমদানির অংশ হিসেবে লগ এন্ট্রি সমর্থন করে। উদাহরণস্বরূপ:
const functions = require("firebase-functions/v1");
functions.logger.log("Hello from info. Here's an object:", someObj);
বিকল্পভাবে, আপনি পৃথক রপ্তানি ব্যবহার করতে পারেন। এই উদাহরণে লগের সাথে সংযুক্ত স্ট্রাকচার্ড ডেটাকে শেষ যুক্তি হিসেবে দেখানো হয়েছে:
const { warn } = require("firebase-functions/logger");
// Attach structured data to the log as the last argument.
warn("This is a 'WARNING' severity message with some metadata.", {
key1: 'val1',
key2: 'val2'
});
-
logger.log()কমান্ডের INFO লগ লেভেল থাকে। -
logger.info()কমান্ডের INFO লগ লেভেল থাকে। -
logger.warn()কমান্ডের WARNING লগ লেভেল থাকে। -
logger.error()কমান্ডের ERROR লগ লেভেল থাকে। - অভ্যন্তরীণ সিস্টেম বার্তাগুলিতে DEBUG লগ স্তর থাকে।
logger.write() দিয়ে, আপনি লগ এন্ট্রি লিখতে পারেন, CRITICAL , ALERT , এবং EMERGENCY এর লগ তীব্রতার মাত্রা যোগ করতে পারেন। LogSeverity দেখুন।
কাস্টম Cloud Logging লগ
লগার SDK সহ Cloud Functions লগগুলি Cloud Logging দ্বারা সমর্থিত। আপনি Node.js এর জন্য Cloud Logging লাইব্রেরি ব্যবহার করে স্ট্রাকচার্ড ডেটা সহ ইভেন্টগুলি লগ করতে পারেন, যা বিশ্লেষণ এবং পর্যবেক্ষণকে সহজ করে তোলে।
const { Logging } = require('@google-cloud/logging');
// ...
// Instantiate the logging SDK. The project ID will
// be automatically inferred from the Cloud Functions environment.
const logging = new Logging();
const log = logging.log('my-custom-log-name');
// This metadata is attached to each log entry. This specifies a fake
// Cloud Function called 'Custom Metrics' in order to make your custom
// log entries appear in the Cloud Functions logs viewer.
const METADATA = {
resource: {
type: 'cloud_function',
labels: {
function_name: 'CustomMetrics',
region: 'us-central1'
}
}
};
// ...
// Data to write to the log. This can be a JSON object with any properties
// of the event you want to record.
const data = {
event: 'my-event',
value: 'foo-bar-baz',
// Optional 'message' property will show up in the Firebase
// console and other human-readable logging surfaces
message: 'my-event: foo-bar-baz'
};
// Write to the log. The log.write() call returns a Promise if you want to
// make sure that the log was written successfully.
const entry = log.entry(METADATA, data);
log.write(entry);
console.log ব্যবহার করে
কোনও ফাংশন থেকে লগিং করার জন্য প্রস্তাবিত সমাধান হল আপনার প্ল্যাটফর্মের জন্য লগার SDK ব্যবহার করা। Node.js এর মাধ্যমে, আপনি console.log এবং console.error এর মতো স্ট্যান্ডার্ড জাভাস্ক্রিপ্ট লগিং কল ব্যবহার করতে পারেন, তবে স্ট্যান্ডার্ড পদ্ধতিগুলি সঠিকভাবে কাজ করার জন্য প্রথমে আপনাকে একটি বিশেষ মডিউলের প্রয়োজন হবে:
require("firebase-functions/logger/compat");
একবার আপনার লগার সামঞ্জস্যতা মডিউলটি প্রয়োজন হয়ে গেলে, আপনি আপনার কোডে স্বাভাবিকভাবে console.log() পদ্ধতিগুলি ব্যবহার করতে পারেন:
exports.helloError = functions.https.onRequest((request, response) => {
console.log('I am a log entry!');
response.send('Hello World...');
});
-
console.log()কমান্ডের INFO লগ লেভেল থাকে। -
console.info()কমান্ডের INFO লগ লেভেল থাকে। -
console.warn()কমান্ডের ERROR লগ লেভেল থাকে। -
console.error()কমান্ডের ERROR লগ লেভেল থাকে। - অভ্যন্তরীণ সিস্টেম বার্তাগুলিতে DEBUG লগ স্তর থাকে।
লগ দেখা হচ্ছে
Cloud Functions লগগুলি Google Cloud কনসোল , Cloud Logging UI, অথবা firebase কমান্ড-লাইন টুলের মাধ্যমে দেখা যাবে।
ফায়ারবেস সিএলআই ব্যবহার করা
firebase টুল দিয়ে লগ দেখতে, functions:log কমান্ডটি ব্যবহার করুন:
firebase functions:log
একটি নির্দিষ্ট ফাংশনের লগ দেখতে, ফাংশনের নামটি একটি আর্গুমেন্ট হিসেবে প্রদান করুন:
firebase functions:log --only <FUNCTION_NAME>
লগ দেখার সম্পূর্ণ বিকল্পের জন্য, functions:log জন্য সাহায্য দেখুন :
firebase help functions:log
Google Cloud কনসোল ব্যবহার করে
আপনি Google Cloud কনসোলে ফাংশনের লগ দেখতে পারেন।
Cloud Logging UI ব্যবহার করা
আপনি Cloud Logging UI-তে Cloud Functions লগ দেখতে পারেন।
লগ বিশ্লেষণ করা হচ্ছে
Cloud Logging লগ বিশ্লেষণ সরঞ্জামগুলির একটি শক্তিশালী স্যুট অফার করে যা আপনি আপনার Cloud Functions পর্যবেক্ষণ করতে ব্যবহার করতে পারেন।
চার্ট এবং সতর্কতা
একবার আপনি আপনার ফাংশনগুলি নিরীক্ষণের জন্য লগ-ভিত্তিক মেট্রিক্স তৈরি করার পরে, আপনি এই মেট্রিক্সের উপর ভিত্তি করে চার্ট এবং সতর্কতা তৈরি করতে পারেন। উদাহরণস্বরূপ, সময়ের সাথে সাথে লেটেন্সি কল্পনা করার জন্য আপনি একটি চার্ট তৈরি করতে পারেন, অথবা যদি কোনও নির্দিষ্ট ত্রুটি খুব ঘন ঘন ঘটে তবে আপনাকে জানানোর জন্য একটি সতর্কতা তৈরি করতে পারেন।
চার্টে লগ-ভিত্তিক মেট্রিক্স কীভাবে ব্যবহার করবেন এবং সতর্কতা নীতি সম্পর্কে বিস্তারিত তথ্যের জন্য চার্ট এবং সতর্কতা তৈরি করা দেখুন।