Java:
লগিং

কিভাবে:

এখানে জাভায় java.util.logging প্যাকেজ ব্যবহার করে লগিং শুরু করার একটি সহজ উপায় দেওয়া হলো।

import java.util.logging.Logger;
import java.util.logging.Level;

public class AppLogging {
    private final static Logger LOGGER = Logger.getLogger(Logger.GLOBAL_LOGGER_NAME);

    public static void main(String[] args) {
        LOGGER.info("Logging an INFO-level message");

        try {
            int division = 10 / 0;
        } catch (ArithmeticException e) {
            LOGGER.log(Level.SEVERE, "Exception occur", e);
        }
    }
}

এটি প্রায় এইরকম আউটপুট উৎপাদন করবে:

জুলাই 03, 2023 2:00:00 PM AppLogging main
INFO: Logging an INFO-level message
জুলাই 03, 2023 2:00:00 PM AppLogging main
SEVERE: Exception occur
java.lang.ArithmeticException: / by zero
    at AppLogging.main(AppLogging.java:10)

গভীর দৃষ্টিপাত

জাভায় লগিং অনেক বিকশিত হয়েছে। ঐতিহাসিকভাবে, লগিং ছিল অধিকতর অনানুষ্ঠানিক, সিস্টেম আউটপুটস এবং স্ব-নির্মিত মেকানিজমের সাথে। তবে, মানদণ্ডীকরণের প্রয়োজন Log4j এবং SLF4J এর মতো লগিং APIs-এ নিয়ে এসেছে। java.util.logging প্যাকেজটি নিজেই JDK 1.4-এ প্রবর্তিত হয়েছিল, মেসেজ লগ করার একটি মানদণ্ডীকৃত উপায় প্রদান করে।

java.util.logging (JUL) এর বিকল্প হিসেবে Log4j 2 এবং SLF4J রয়েছে। যদিও JUL জাভার ভিতরে বিল্ট-ইন এবং অতিরিক্ত নির্ভরতা ছাড়াই কাজ করে, Log4j 2 এবং SLF4J উন্নত বৈশিষ্ট্য অফার করে যেমন লগিং কনফিগারেশনের উপর আরও নির্ণায়ক নিয়ন্ত্রণ, অ্যাসিঙ্ক্রোনাস লগিং, এবং উত্তম পারফরম্যান্স।

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

আরও দেখুন