Stack Trace Logging করা

Java Technologies - লগ4জে (log4j) - Log4j এবং Exception Logging
188

Log4j হল একটি শক্তিশালী এবং জনপ্রিয় লগিং ফ্রেমওয়ার্ক যা Java প্রোগ্রামিং ভাষায় লগিং ব্যবস্থাপনা করতে ব্যবহৃত হয়। লগ4জে আপনাকে সহজে বিভিন্ন স্তরের লগ তৈরি করতে এবং ফাইল, কনসোল বা অন্যান্য আউটপুট স্ট্রীমে লগিং করতে সাহায্য করে। এর অন্যতম গুরুত্বপূর্ণ বৈশিষ্ট্য হল Stack Trace Logging যা বিশেষ করে Exception এর বিস্তারিত তথ্য লগ করার জন্য ব্যবহৃত হয়।

Stack Trace Logging সাধারণত ত্রুটির (exception) ধরন, তার স্ট্যাক ট্রেস এবং এর মাধ্যমে কোন কোড লাইনে সমস্যা হচ্ছে তা জানাতে সহায়ক। এতে আপনি ত্রুটির উৎস সনাক্ত করতে পারবেন এবং আপনার অ্যাপ্লিকেশনের ডিবাগিং সহজ হবে।

এই টিউটোরিয়ালে, আমরা দেখব কীভাবে log4j ব্যবহার করে Stack Trace Logging করা যায়।


১. Log4j এর মাধ্যমে Exception এবং Stack Trace Logging

Log4j তে Exception বা Stack Trace লগ করতে হলে, আপনাকে লগ মেসেজের সাথে Throwable অবজেক্ট পাস করতে হবে। এটি সাধারণত logger.error(), logger.warn() অথবা logger.info() মেথডের মাধ্যমে করা হয়, যেখানে দ্বিতীয় প্যারামিটার হিসেবে Exception পাস করা হয়।

উদাহরণ:

import org.apache.log4j.Logger;

public class Log4jStackTraceExample {
    private static final Logger logger = Logger.getLogger(Log4jStackTraceExample.class);

    public static void main(String[] args) {
        try {
            // Some code that throws an exception
            int result = 10 / 0; // ArithmeticException
        } catch (ArithmeticException e) {
            // Logging the exception with stack trace
            logger.error("An error occurred: ", e);
        }
    }
}

এখানে, যখন ArithmeticException ঘটবে, তখন এটি logger.error() মেথডের মাধ্যমে লগ করা হবে, এবং Stack Trace সহ ত্রুটির বিস্তারিত তথ্য কনসোলে বা ফাইলে আউটপুট হবে।

উদাহরণ আউটপুট:

ERROR Log4jStackTraceExample - An error occurred: 
java.lang.ArithmeticException: / by zero
    at Log4jStackTraceExample.main(Log4jStackTraceExample.java:9)

এখানে, Stack Trace সম্পূর্ণ ত্রুটির স্থান এবং তার বিস্তারিত বর্ণনা দেখাচ্ছে, যা ডেভেলপারদের ত্রুটির উৎস সনাক্ত করতে সাহায্য করে।


২. Log4j Configuration for Stack Trace Logging

log4j.properties বা log4j2.xml কনফিগারেশন ফাইল ব্যবহার করে আপনি লগ আউটপুট কনফিগার করতে পারেন, যেখানে Stack Trace স্বয়ংক্রিয়ভাবে আউটপুট হবে।

Example: log4j.properties Configuration

log4j.rootLogger=ERROR, console, file

# Console appender
log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

# File appender
log4j.appender.file=org.apache.log4j.FileAppender
log4j.appender.file.File=application.log
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

এখানে, console appender এবং file appender কনফিগার করা হয়েছে। লগ আউটপুটের প্যাটার্ন হিসেবে %-5p লগ লেভেল, %c{1} ক্লাসের নাম এবং %L লাইনের নাম দেখাবে।


৩. Log4j2 এর মাধ্যমে Stack Trace Logging

Log4j2 একটি উন্নত ভার্সন যা উন্নত পারফরম্যান্স এবং কাস্টমাইজেশনের সুবিধা প্রদান করে। এটি log4j2.xml ফাইলের মাধ্যমে কনফিগার করা যায়।

Example: log4j2.xml Configuration

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="WARN">
    <Appenders>
        <Console name="Console" target="SYSTEM_OUT">
            <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %logger{36} - %msg%n%throwable"/>
        </Console>
        <File name="File" fileName="logs/application.log">
            <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %logger{36} - %msg%n%throwable"/>
        </File>
    </Appenders>

    <Loggers>
        <Root level="error">
            <AppenderRef ref="Console"/>
            <AppenderRef ref="File"/>
        </Root>
    </Loggers>
</Configuration>

এখানে, %throwable প্যাটার্নটি Stack Trace লগ করার জন্য ব্যবহৃত হয়েছে। এটি লগ মেসেজের পরে Throwable (যেমন Exception) এর স্ট্যাক ট্রেস আউটপুট করবে।


৪. Stack Trace Logging with Different Log Levels

Log4j তে আপনি ERROR, WARN, INFO, DEBUG সহ বিভিন্ন লগ স্তরের মাধ্যমে Stack Trace লগ করতে পারেন। তবে, ERROR লেভেল সাধারণত ত্রুটির ক্ষেত্রে ব্যবহার হয়।

Example with WARN Level:

import org.apache.log4j.Logger;

public class Log4jStackTraceWarnExample {
    private static final Logger logger = Logger.getLogger(Log4jStackTraceWarnExample.class);

    public static void main(String[] args) {
        try {
            // Some code that throws an exception
            String text = null;
            System.out.println(text.length()); // NullPointerException
        } catch (NullPointerException e) {
            // Logging the exception with stack trace at WARN level
            logger.warn("A warning occurred: ", e);
        }
    }
}

এখানে, WARN লেভেলে NullPointerException এর Stack Trace লগ হচ্ছে।


৫. Custom Log Formatting for Stack Trace

আপনি যদি লগ ফরম্যাট কাস্টমাইজ করতে চান, তবে PatternLayout ব্যবহার করে লগ আউটপুটের ফরম্যাট নির্ধারণ করতে পারেন। যেমন:

log4j.appender.console.layout.ConversionPattern=%d{ISO8601} [%t] %-5p %c{1}:%L - %m%n%throwable

এখানে, %throwable কনফিগারেশনটি Stack Trace দেখানোর জন্য ব্যবহৃত হচ্ছে এবং লগ মেসেজের পরে Throwable এর স্ট্যাক ট্রেস প্রদর্শিত হবে।


সারাংশ

Stack Trace Logging একটি গুরুত্বপূর্ণ কার্যকারিতা যা Log4j তে Exception এবং ত্রুটির তথ্য সহ স্ট্যাক ট্রেস লগ করার জন্য ব্যবহৃত হয়। Log4j বা Log4j2 কনফিগারেশন ফাইলে আপনি PatternLayout এবং %throwable ব্যবহার করে স্ট্যাক ট্রেস লগ করতে পারেন। এতে, ত্রুটির সূত্র চিহ্নিত করা সহজ হয় এবং ডিবাগিং প্রক্রিয়া দ্রুত হয়। ERROR এবং WARN লেভেল ব্যবহার করে Exception এবং Stack Trace লগ করা হয়, যা উন্নত ডিবাগিং এবং সমস্যা সমাধানে সহায়ক।


Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...