রুবিতে লগের সাথে কাজ করা
লগিং হল প্রাথমিক কাজগুলির মধ্যে একটি যা একটি অ্যাপ্লিকেশন সাধারণত সম্বোধন করে। লগ ব্যবহার করা হয় যখন আপনার প্রয়োজন হয়, উদাহরণস্বরূপ,
- আপনার অ্যাপের ভিতরে কী ঘটছে তা দেখুন,
- তাদের মনিটর করুন, অথবা
- কিছু নির্দিষ্ট ডেটার জন্য মেট্রিক্স সংগ্রহ করুন।
একটি নতুন প্রোগ্রামিং ভাষা শেখার সময়, তথ্য লগ করার প্রথম সুস্পষ্ট বাছাই হল নেটিভ মেকানিজম। এটি সাধারণত সহজ, নথিভুক্ত এবং সমগ্র সম্প্রদায় জুড়ে ভালভাবে ছড়িয়ে পড়ে৷
লগ ডেটা কোম্পানি, ব্যবসা এবং আপনি যে অ্যাপ্লিকেশনের সাথে কাজ করছেন তার উপর নির্ভর করে অনেক পরিবর্তিত হয়। অতএব, আপনি এবং আপনার দল যে লগিং সমাধানটি বেছে নিয়েছেন তা কীভাবে এর সামগ্রিক ব্যবহারকে প্রভাবিত করবে তা বোঝা খুবই গুরুত্বপূর্ণ৷
এই নিবন্ধে, আমরা রুবি এবং রেলের জন্য লগিং করার উপলব্ধ বিকল্পগুলির মাধ্যমে একটি যাত্রা করব, অন্তর্নির্মিতগুলি থেকে প্রিয় তৃতীয়-পক্ষের কমিউনিটি ফ্রেমওয়ার্ক পর্যন্ত। চলুন!
রুবির অন্তর্নির্মিত বিকল্পগুলি
লগিং পরিচালনা করার জন্য রুবি দুটি অন্তর্নির্মিত বিকল্পের সাথে আসে:প্রিন্টিং কমান্ড (বিশেষভাবে কমান্ড-লাইন পরিস্থিতির জন্য ডিজাইন করা হয়েছে) এবং লগার ক্লাস।
আসুন সেগুলিকে একটু অন্বেষণ করি৷
৷কনসোলে মুদ্রণ
রুবির কাছে কনসোলে পাঠ্য মুদ্রণের চারটি সাধারণ উপায় রয়েছে:puts , print , p , এবং pp .
puts পদ্ধতিতে আপনি যা পাস করেন তা মুদ্রণ করে, তার পরে একটি নতুন লাইন:
2.7.0 :001 > puts "Hey, I'm a log!"
Hey, I'm a log!
=> nil
print পদ্ধতি puts এর মত , তবে এটি সর্বদা to_s ব্যবহার করে আর্গুমেন্টকে স্ট্রিংয়ে রূপান্তর করে পদ্ধতি।
অবশেষে, p এবং pp উভয় পদ্ধতিই রূপান্তর না করেই আপনি যে কাঁচা বস্তুটি তাদের কাছে দিচ্ছেন তা মুদ্রণ করবে; একমাত্র পার্থক্য হল যে পরেরটি আউটপুটকে আরও ইন্ডেন্ট করে ফর্ম্যাট করে, যখন আগেরটি করে না৷
অ্যাপ্লিকেশন লগ
সার্ভারে চলমান অ্যাপ্লিকেশানগুলির জন্য, কনসোলে প্রিন্ট করার কোন মানে হয় না৷
৷
পরিবর্তে, আমরা Logger ব্যবহার করি ক্লাস, যা অনেক বেশি নমনীয়।
একটি "ডিবাগ" লগ প্রিন্ট করার জন্য আপনি কীভাবে এটি ব্যবহার করতে পারেন তা এখানে:
require "logger"
logger = Logger.new(STDOUT)
logger.debug("I'm a debug log")
আমরা লগগুলিকে একটি ফাইলে সংরক্ষণ করার জন্য এটিকে কনফিগার করতে পারি, অথবা আমরা চাইলে STDOUT এ প্রিন্ট করার পরিবর্তে একটি লগ এগ্রিগেটরে পাঠাতে পারি৷
যদি আপনি ভাবছেন, "ডিবাগ" একটি লগ স্তর। লগ স্তরগুলি আপনাকে সিস্টেমকে বলতে দেয় "এই লগ বার্তাটি একটি নির্দিষ্ট ধরণের ইভেন্টের সাথে সম্পর্কিত।" ছয়টি অন্তর্নির্মিত লগ স্তর রয়েছে:মারাত্মক, ত্রুটি, সতর্কতা, তথ্য, ডিবাগ এবং অজানা৷
logger.debug("I'm a debug log")
logger.info("I'm an info log")
logger.warn("I'm a warn log")
logger.error("I'm an error log: error message")
logger.fatal("I'm a fatal log")
যখন আমরা লগ আউটপুট দেখি, আমরা দেখতে পাই যে প্রতিটি লাইনে লগ লেভেল, প্রসেস আইডি এবং টাইমস্ট্যাম্প যুক্ত করা হয়েছে:

আরেকটি দুর্দান্ত বৈশিষ্ট্য হল আপনার Logger সেট করার ক্ষমতা একটি নির্দিষ্ট স্তরে বস্তু:
logger.level = Logger::WARN
আপনি যখন এটি করবেন, Logger শুধুমাত্র সতর্কিত করার সমান বা উচ্চতর লগগুলি পরিচালনা করবে৷ গুরুত্বের মধ্যে এটি উৎপাদনে খুবই উপযোগী, যেখানে আমরা আকার বা নিরাপত্তার কারণে "ডিবাগ" লগ সংরক্ষণ করতে চাই না।
এটি আউটপুট হওয়া উচিত:

আপনার লগ কাস্টমাইজ করা
আপনি যদি আপনার লগগুলি কাস্টমাইজ করতে চান তবে প্রচুর বিকল্প রয়েছে। তারিখ এবং সময় পরিবর্তন করতে, উদাহরণস্বরূপ, শুধুমাত্র ডিফল্টটি ওভাররাইট করুন:
logger.datetime_format = "%Y-%m-%d %H:%M"
এখানে আউটপুটের একটি উদাহরণ:
W, [2020-07-28 10:50#87786] WARN -- : I'm a warn log
date_time ফরম্যাট স্ট্যান্ডার্ড স্পেসিফিকেশন অনুসরণ করে, তাই এই ধরনের পরিবর্তন করার সময় এটি উল্লেখ করতে ভুলবেন না।
কখনও কখনও, যাইহোক, আপনাকে আপনার লগগুলির বিন্যাস সম্পূর্ণরূপে পরিবর্তন করতে হতে পারে৷ এই উদ্দেশ্যে, রুবি ফর্ম্যাটার ক্লাস প্রদান করে। এটি devs-কে Logger ডিফল্ট টেমপ্লেট ওভাররাইট করার অনুমতি দিয়ে কাজ করে লগ প্রিন্ট করতে ব্যবহার করে।
কল্পনা করুন যে আপনার অ্যাপটি একটি কেন্দ্রীভূত লগ বিশ্লেষণ টুল ব্যবহার করে এবং আপনার সমস্ত লগ name=value-এ প্রিন্ট করতে হবে বিন্যাস এটি হবে নতুন ফর্ম্যাটার কোড:
logger.formatter = proc do |severity, datetime, progname, msg|
date_format = datetime.strftime("%Y-%m-%d %H:%M:%S")
"date=[#{date_format}] severity=#{severity.ljust(5)} pid=##{Process.pid} message='#{msg}'\n"
end
এখানে, আমরা একটি proc ব্যবহার করছি সমস্ত লগ আটকাতে এবং পছন্দসই একটিতে প্রিন্ট করার ডিফল্ট উপায় পরিবর্তন করতে। এখন, আমাদের নিম্নলিখিত ফলাফল আছে:

কোডের মাত্র কয়েকটি লাইনের সাথে, আপনার সমস্ত অ্যাপ লগ এখন টুল দ্বারা সূচিত করা যেতে পারে৷
JSON এ লগ করা হচ্ছে
Formatter এর ক্ষমতা সহ হাতে, আপনি যে আউটপুট প্রকার চান তাতে আপনার লগগুলি কাস্টমাইজ করা সহজ। উদাহরণস্বরূপ, আমরা সেই বিন্যাসে আমাদের লগ আউটপুট করতে JSON মডিউল ব্যবহার করতে পারি।
require "json"
logger.formatter = proc do |severity, datetime, progname, msg|
date_format = datetime.strftime("%Y-%m-%d %H:%M:%S")
JSON.dump(date: "#{date_format}", severity:"#{severity.ljust(5)}", pid:"##{Process.pid}", message: msg) + "\n"
end
এবং, এখানে ফলস্বরূপ লগগুলি রয়েছে:

একটি ফাইলে লগ করা
আগে দেখা যায়, Logger কনস্ট্রাক্টর, প্রথম আর্গুমেন্ট হিসাবে, সেই জায়গাটি পায় যেখানে লগ সংরক্ষণ করা উচিত।
আপনি যদি একটি ফাইলে আপনার লগ সংরক্ষণ করতে চান, তাহলে শুধু তাই বলুন:
require 'logger'
logger = Logger.new('my_logs.log')
এটি একটি নতুন ফাইল my_logs.log তৈরি করবে৷ একই ফোল্ডারে যেখানে এই কোডটি ধারণকারী আপনার রুবি ফাইলটি অবস্থিত:

যাইহোক, ক্লাসটি একগুচ্ছ কাস্টম বিকল্পের অনুমতি দেয়, যেমন একটি ধারণ নীতি কনফিগারেশন। নিম্নলিখিত উদাহরণ নিন:
# Keep data for the current week.
Logger.new('my_weekly_logs.log', 'weekly')
# Keep data for today and the past 2 months.
Logger.new('my_latest_2_months_logs.log', 2, 'monthly')
# Restarts the log over when it exceeds 26GB in size.
Logger.new('my_custom_logs.log', 0, 20 * 1024 * 1024 * 1024)
দ্বিতীয় প্যারাম হিসাবে, Logger কত ঘন ঘন লগ রাখা বা মুছে ফেলা উচিত তার একটি সংজ্ঞা গ্রহণ করে।
প্রথম বস্তুতে, লগগুলি শুধুমাত্র এক সপ্তাহের জন্য রাখা হবে। দ্বিতীয়টি সেগুলিকে দুই মাসের জন্য সংরক্ষণ করবে, যখন সর্বশেষটি তৃতীয় প্যারামের উপর ভিত্তি করে ফাইলের আকার বিশ্লেষণ করবে (যেমন, যখনই এটি 20GB তে পৌঁছাবে, এটি বাতিল করা হবে)৷
রুবি অন রেলে লগ ইন করা
Logger এর বেশিরভাগ সুবিধা আমরা এখন পর্যন্ত দেখেছি সবগুলো রেল অ্যাপের সাথে ব্যবহার করা যায়। Logger এর রেল সংস্করণ রুবির নেটিভ ক্লাসের একটি সাধারণ এক্সটেনশন মাত্র।
তা ছাড়াও, devsকে একাধিক লগারে তাদের লগ সম্প্রচার করার অনুমতি দেওয়ার জন্য Rails একটি চমৎকার বৈশিষ্ট্য যোগ করে। এইভাবে, আপনি যদি একাধিক লগিং লাইব্রেরির সাথে কাজ করতে চান, তাহলে আপনি Rails logger এর মধ্যে তা করতে পারেন :
custom_logger = Logger.new(STDOUT)
Rails.logger.extend(ActiveSupport::Logger.broadcast(custom_logger))
আপনার লগগুলি কোথায় যাওয়া উচিত সে সম্পর্কে আপনার কিছু বুদ্ধিমত্তার প্রয়োজন হলে এটিও কার্যকর হতে পারে। আপনার অ্যাপের কিছু অংশের বিভিন্ন অবস্থানে বা বিভিন্ন ফরম্যাটে লগের প্রয়োজন হতে পারে।
একটি তৃতীয় পক্ষের লগিং ফ্রেমওয়ার্ক নির্বাচন করা
যদি রুবির অন্তর্নির্মিত লগার ঠিক আপনার যা প্রয়োজন তা না করে, আপনার কাছে বিকল্প রয়েছে৷
তৃতীয় পক্ষের লগিং ফ্রেমওয়ার্ক বাছাই করার ক্ষেত্রে প্রচুর বিকল্প রয়েছে। এর মধ্যে সবচেয়ে জনপ্রিয় হল Lograge। আসুন এটি একবার দেখে নেওয়া যাক!
লগ্রেজের সাথে প্রথম ধাপ
Lograge Rails অ্যাপের জন্য তৈরি করা হয়েছিল। আপনি যদি ভ্যানিলা রুবির সাথে কাজ করেন তবে এটি একটি ভাল পছন্দ নাও হতে পারে।
এটি ইনস্টল করতে, শুধুমাত্র নিম্নলিখিত রত্ন যোগ করুন:
bundle add lograge
তারপর, config/initializers/lograge.rb এ একটি নতুন কনফিগারেশন ফাইল তৈরি করুন নিম্নলিখিত কোড সহ:
Rails.application.configure do
config.lograge.enabled = true
config.lograge.custom_options = lambda do |event|
{ time: event.time }
end
end
এই কনফিগারেশন Lograge সক্ষম করে এবং একটি লগ, ফ্রেমওয়ার্কের একটি ইভেন্ট হিসাবে বিবেচিত, প্রিন্ট করার সময় নির্ধারণ করে৷
আপনি যখন Rails অ্যাপ শুরু করবেন এবং প্রথম এন্ডপয়েন্ট অ্যাক্সেস করবেন, Lograge অনুরোধের সারাংশ প্রিন্ট করবে। লগরেজ সেটআপের আগে এবং পরে লগের তুলনা করলে, নিচের মত কিছু দেখায়:

আবার, Lograge একটি রূপালী বুলেট নয়; এটা আসলে একটি খুব মতামত ফ্রেমওয়ার্ক. সুতরাং, আপনাকে সম্ভবত বিল্ট-ইন Logger এর সাথে এটি ব্যবহার করতে হবে (বা আপনার পছন্দের অন্যান্য কাঠামো)।
র্যাপিং আপ
শেষ পর্যন্ত, এটা আরও পরিষ্কার হয়ে যায় যে লগিং করা শুধুমাত্র আপনার প্রকল্পগুলির একটি গুরুত্বপূর্ণ অংশ নয় বরং এটি অত্যন্ত অবমূল্যায়িত। আপনি যে সরঞ্জামগুলি ব্যবহার করছেন তা আরও ভালভাবে বোঝার জন্য, সেগুলি স্থানীয় হোক না কেন, আপনাকে আরও ভাল ফলাফল অর্জন করতে সহায়তা করবে৷
একটি নতুন কাঠামো গ্রহণ করার জন্য সর্বদা প্রচুর পরীক্ষা পরিচালনা করতে ভুলবেন না। কখনও কখনও আপনার প্ল্যাটফর্ম ইতিমধ্যে দুর্দান্ত অন্তর্নির্মিত বিকল্পগুলির সাথে একত্রিত হয়ে আসে। যদি তা না হয়, তাহলে নির্ধারণ করুন যে এটি ইতিমধ্যে ভিতরে থাকা ফ্রেমওয়ার্কের সাথে একত্রিত অন্যান্য ফ্রেমওয়ার্ক ব্যবহারের অনুমতি দেয় কিনা৷
শুভকামনা!