Skill

Java Technologies উদাহরণ সহ Custom Logging গাইড ও নোট

293

Log4j হল একটি জনপ্রিয় লগিং ফ্রেমওয়ার্ক যা Java প্রোগ্রামে লগিং কার্যক্রম পরিচালনা করতে ব্যবহৃত হয়। এটি বিভিন্ন আউটপুট ফর্ম্যাটে লগিং করতে সক্ষম এবং কাস্টম লোগিং কনফিগারেশন তৈরি করতে সহায়তা করে। Log4j এর মাধ্যমে আপনি আপনার প্রোজেক্টে সহজে লগিং ব্যবস্থা স্থাপন করতে পারেন এবং সঠিক জায়গায় প্রয়োজনীয় তথ্য দেখতে পারেন।

এই টিউটোরিয়ালে, আমরা Log4j দিয়ে কাস্টম লগিং কনফিগারেশন এবং কাস্টম লগ মেসেজ তৈরি করার পদ্ধতি উদাহরণ সহ আলোচনা করব।


১. Log4j সেটআপ

Log4j ব্যবহার করার জন্য প্রথমে এটি আপনার প্রোজেক্টে ডিপেনডেন্সি হিসেবে যুক্ত করতে হবে। এখানে, আমরা Maven প্রোজেক্টে Log4j 2 কনফিগার করব, কারণ এটি Log4j এর উন্নত সংস্করণ।

Maven ডিপেনডেন্সি:

<dependencies>
    <!-- Log4j 2 API -->
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-api</artifactId>
        <version>2.14.1</version>
    </dependency>

    <!-- Log4j 2 Core -->
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-core</artifactId>
        <version>2.14.1</version>
    </dependency>

    <!-- Log4j 2 SLF4J Binding -->
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-slf4j-impl</artifactId>
        <version>2.14.1</version>
    </dependency>
</dependencies>

এই ডিপেনডেন্সিগুলি আপনার pom.xml ফাইলে যোগ করুন যাতে আপনার Maven প্রোজেক্টে Log4j 2 ইনস্টল হয়।


২. Log4j 2 কনফিগারেশন

Log4j 2 এর মাধ্যমে কাস্টম লগিং কনফিগার করার জন্য আপনাকে একটি কনফিগারেশন ফাইল তৈরি করতে হবে, সাধারণত log4j2.xml নামের একটি ফাইল। এই ফাইলের মাধ্যমে আপনি লগের আউটপুট কনফিগারেশন, লেভেল এবং ফর্ম্যাট নির্ধারণ করতে পারেন।

log4j2.xml কনফিগারেশন:

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="WARN">
    <!-- Appender configuration: Logs to console -->
    <Appenders>
        <Console name="Console" target="SYSTEM_OUT">
            <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %logger{36} - %msg%n"/>
        </Console>

        <!-- File appender: Logs to a file -->
        <File name="File" fileName="logs/application.log">
            <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %logger{36} - %msg%n"/>
        </File>
    </Appenders>

    <!-- Logger configuration: Root logger settings -->
    <Loggers>
        <Root level="debug">
            <AppenderRef ref="Console"/>
            <AppenderRef ref="File"/>
        </Root>

        <!-- Custom logger for a specific class -->
        <Logger name="com.example" level="info" additivity="false">
            <AppenderRef ref="Console"/>
        </Logger>
    </Loggers>
</Configuration>

এখানে:

  • Console Appender: কনসোলে লগ আউটপুট করার জন্য।
  • File Appender: লগ আউটপুট ফাইলে সংরক্ষণের জন্য, যেখানে application.log ফাইলে লগ লেখা হবে।
  • PatternLayout: লগের আউটপুট ফরম্যাট নির্ধারণ করে।
  • Logger: নির্দিষ্ট ক্লাসের জন্য লগ লেভেল কনফিগার করা হয় (যেমন com.example এর জন্য info লেভেল)।

৩. Custom Logging উদাহরণ

Log4j 2 ব্যবহার করে আপনি কাস্টম লগিং ফাংশন তৈরি করতে পারেন। নীচে একটি উদাহরণ দেওয়া হলো যেখানে কাস্টম লগ বার্তা, লেভেল এবং আউটপুট ফরম্যাট কনফিগার করা হয়েছে।

CustomLogger.java:

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

public class CustomLogger {
    // Create a logger instance
    private static final Logger logger = LogManager.getLogger(CustomLogger.class);

    public static void main(String[] args) {
        // Log messages with different levels
        logger.debug("This is a debug message");
        logger.info("This is an info message");
        logger.warn("This is a warning message");
        logger.error("This is an error message");
        logger.fatal("This is a fatal message");

        // Custom logging with dynamic messages
        String user = "Alice";
        logger.info("User {} has logged in", user);
    }
}

এখানে:

  • LogManager.getLogger(CustomLogger.class) ব্যবহার করে একটি logger তৈরি করা হয়েছে।
  • বিভিন্ন লেভেলের লগ (debug, info, warn, error, fatal) ব্যবহার করা হয়েছে।
  • কাস্টম বার্তা লগ করা হয়েছে যেখানে user এর নাম প্লেসহোল্ডারে প্রবেশ করানো হয়েছে।

আউটপুট (Console):

2024-12-22 15:30:00 [main] DEBUG CustomLogger - This is a debug message
2024-12-22 15:30:00 [main] INFO  CustomLogger - This is an info message
2024-12-22 15:30:00 [main] WARN  CustomLogger - This is a warning message
2024-12-22 15:30:00 [main] ERROR CustomLogger - This is an error message
2024-12-22 15:30:00 [main] FATAL CustomLogger - This is a fatal message
2024-12-22 15:30:00 [main] INFO  CustomLogger - User Alice has logged in

৪. Log4j 2 এবং Performance Optimization

Log4j 2 এর সাহায্যে আপনি কাস্টম লগিং ফাংশন ব্যবহার করে প্রোগ্রামের পারফরম্যান্স উন্নত করতে পারেন। এটি asynchronous logging সাপোর্ট করে, যা পারফরম্যান্সের জন্য খুবই উপকারী।

Asynchronous Logging উদাহরণ:

<AsyncAppender name="AsyncConsole">
    <AppenderRef ref="Console"/>
</AsyncAppender>

এখানে, AsyncAppender ব্যবহার করে কনসোল আউটপুট অ্যাসিঙ্ক্রোনাসভাবে চালানো হয়েছে, যা পারফরম্যান্স বাড়ায় এবং লগ লেখার সময়ে মূল থ্রেড ব্লক হওয়ার ঝুঁকি কমায়।


৫. Log4j 2 এর অন্যান্য কাস্টম ফিচার

  • RollingFileAppender: লোগ ফাইলের আকার বড় হলে এটি নতুন ফাইল তৈরি করতে সহায়তা করে।
  • PatternLayout: লগ আউটপুট কাস্টম ফরম্যাট নির্ধারণ করতে এটি ব্যবহার করা হয় (যেমন, টাইমস্ট্যাম্প, লেভেল, থ্রেড নাম, লগারের নাম ইত্যাদি)।
  • Filters: কাস্টম ফিল্টার ব্যবহার করে নির্দিষ্ট লেভেল বা অন্য কোনো শর্তে লগ মেসেজ ফিল্টার করা যায়।

RollingFileAppender উদাহরণ:

<Appenders>
    <RollingFile name="RollingFile" fileName="logs/app.log" filePattern="logs/app-%d{MM-dd-yyyy}.log">
        <PatternLayout>
            <Pattern>%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %logger{36} - %msg%n</Pattern>
        </PatternLayout>
        <Policies>
            <TimeBasedTriggeringPolicy interval="1" modulate="true"/>
        </Policies>
    </RollingFile>
</Appenders>

এখানে, RollingFileAppender ব্যবহার করে একটি নতুন ফাইল তৈরির প্যাটার্ন কনফিগার করা হয়েছে।


সারাংশ

Log4j 2 একটি অত্যন্ত শক্তিশালী লগিং ফ্রেমওয়ার্ক যা আপনার Java প্রোগ্রামে কাস্টম লগিং সিস্টেম তৈরি করতে সাহায্য করে। Custom Logging ফিচার ব্যবহার করে আপনি বিভিন্ন লগ লেভেল এবং আউটপুট কনফিগার করতে পারেন এবং কাস্টম বার্তা লগিং করতে পারেন। এটি পারফরম্যান্সের উন্নতির জন্য Asynchronous Logging, RollingFileAppender, এবং অন্যান্য কাস্টম কনফিগারেশন প্রদান করে।


Content added By
Promotion

Are you sure to start over?

Loading...