Skill

লগিং এবং মনিটরিং

ইউনিক্স/লিনাক্স (UNIX / LINUX) - Computer Programming

199

লগিং এবং মনিটরিং

লগিং এবং মনিটরিং কম্পিউটার সিস্টেমের কর্মক্ষমতা, নিরাপত্তা এবং অপারেশনাল কার্যক্রম ট্র্যাক এবং বিশ্লেষণ করার জন্য অত্যন্ত গুরুত্বপূর্ণ প্রক্রিয়া। লিনাক্স এবং ইউনিক্স সিস্টেমে লগিং এবং মনিটরিং টুলস ব্যবহার করে সিস্টেমের অবস্থার রিয়েল-টাইম নজরদারি করা এবং সমস্যাগুলি দ্রুত সমাধান করা সম্ভব।


লগিং (Logging)

লগিং হলো একটি প্রক্রিয়া যার মাধ্যমে সিস্টেমের বিভিন্ন কার্যক্রম বা ঘটনার তথ্য সংরক্ষিত হয়। এটি সিস্টেম প্রশাসকদের জন্য গুরুত্বপূর্ণ, কারণ এর মাধ্যমে সিস্টেমের কার্যকলাপ, ত্রুটি, এবং অন্যান্য গুরুত্বপূর্ণ ইভেন্টের ট্র্যাক রাখা যায়।

লিনাক্স/ইউনিক্স সিস্টেমে লগ ফাইলগুলি সাধারণত /var/log/ ডিরেক্টরিতে সংরক্ষিত থাকে। এখানে বিভিন্ন ধরনের লগ ফাইল থাকতে পারে, যেমন syslog, auth.log, dmesg, kern.log, ইত্যাদি।

1. লগ ফাইলের ধরন

  • /var/log/syslog: সিস্টেমের সাধারণ কার্যকলাপ এবং মেসেজ।
  • /var/log/auth.log: লগিন, অটেনটিকেশন, এবং নিরাপত্তা সংক্রান্ত ইভেন্ট।
  • /var/log/dmesg: কার্নেল সম্পর্কিত তথ্য এবং সিস্টেম বুট সময়ের মেসেজ।
  • /var/log/kern.log: কার্নেল সম্পর্কিত লগ।
  • /var/log/apt/history.log: APT প্যাকেজ ম্যানেজার দ্বারা ইনস্টল/অপডেট করা প্যাকেজ সম্পর্কিত তথ্য।

2. লগ দেখার কমান্ড

  • cat, less, more: লগ ফাইলের কন্টেন্ট দেখতে ব্যবহৃত হয়।

    cat /var/log/syslog
  • tail: শেষের কিছু লাইন দেখার জন্য ব্যবহৃত হয়। সাধারণত রিয়েল-টাইম মনিটরিংয়ের জন্য ব্যবহার করা হয়।

    tail -f /var/log/syslog
  • grep: নির্দিষ্ট শব্দ বা ইভেন্ট খুঁজে বের করার জন্য ব্যবহৃত হয়।

    grep "error" /var/log/syslog

3. লগ রোটেশন (Log Rotation)

লগ ফাইলের আকার বড় হয়ে যেতে পারে, যা সিস্টেমের পারফরম্যান্সে প্রভাব ফেলতে পারে। তাই লগ রোটেশন প্রক্রিয়া ব্যবহৃত হয়। এটি পুরানো লগ ফাইল আর্কাইভ করে এবং নতুন লগ ফাইল তৈরি করে।

লিনাক্সে logrotate টুলটি লগ রোটেশনের জন্য ব্যবহৃত হয়। এটি সাধারণত /etc/logrotate.conf বা /etc/logrotate.d/ ফোল্ডারে কনফিগার করা হয়।


মনিটরিং (Monitoring)

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

লিনাক্স/ইউনিক্স সিস্টেমে বিভিন্ন টুলস এবং কমান্ড রয়েছে যা সিস্টেমের বিভিন্ন মেট্রিক্স যেমন CPU ব্যবহার, মেমরি ব্যবহার, ডিস্ক ব্যবহার, নেটওয়ার্ক সংযোগ ইত্যাদি মনিটর করতে সহায়তা করে।

1. সিস্টেম রিসোর্স মনিটরিং

  • top: সিস্টেমের রিয়েল-টাইম পারফরম্যান্স দেখানোর জন্য একটি ইন্টারেক্টিভ কমান্ড। এটি CPU এবং মেমরি ব্যবহার মনিটর করে।

    top
  • htop: top এর একটি উন্নত সংস্করণ, যা আরও সহজে ব্যবহারযোগ্য এবং কাস্টমাইজযোগ্য।

    sudo apt install htop
    htop
  • free: সিস্টেমের মেমরি ব্যবহার সম্পর্কিত তথ্য দেখায়।

    free -h
  • vmstat: ভার্চুয়াল মেমরি, প্রসেস, ডিস্ক, এবং CPU সম্পর্কিত তথ্য প্রদান করে।

    vmstat 1

2. ডিস্ক মনিটরিং

  • df: ডিস্ক ব্যবহারের তথ্য প্রদর্শন করে। এটি মোট ডিস্ক স্পেস এবং ব্যবহৃত/অপ্রয়োজনীয় স্পেস দেখায়।

    df -h
  • du: ডিস্ক ব্যবহারের তথ্য নির্দিষ্ট ডিরেক্টরি বা ফাইলের জন্য দেখায়।

    du -sh /path/to/directory
  • iostat: ডিস্ক I/O কার্যকলাপ মনিটর করার জন্য ব্যবহৃত হয়।

    iostat

3. নেটওয়ার্ক মনিটরিং

  • netstat: সক্রিয় নেটওয়ার্ক সংযোগ এবং তাদের স্ট্যাটাস দেখায়।

    netstat -tuln
  • ss: netstat এর উন্নত সংস্করণ, যা দ্রুত এবং আরও দক্ষভাবে সক্রিয় সংযোগ এবং সোকেট মনিটর করে।

    ss -tuln
  • iftop: নেটওয়ার্ক ট্রাফিকের রিয়েল-টাইম মনিটরিংয়ের জন্য ব্যবহৃত হয়।

    sudo apt install iftop
    sudo iftop

4. প্রসেস মনিটরিং

  • ps: সিস্টেমে চলমান প্রসেসগুলি দেখার জন্য ব্যবহৃত হয়।

    ps aux
  • pgrep: নির্দিষ্ট প্রক্রিয়া অনুসন্ধান করতে ব্যবহৃত হয়।

    pgrep nginx
  • kill: চলমান প্রসেস বন্ধ করার জন্য ব্যবহৃত হয়।

    kill [প্রসেস ID]

মনিটরিং টুলস

লিনাক্সে কিছু উন্নত মনিটরিং টুলসও রয়েছে যা সিস্টেমের বিভিন্ন মেট্রিক্স এবং ইভেন্টের রিয়েল-টাইম ড্যাশবোর্ড প্রদান করে।

1. Nagios:

Nagios একটি জনপ্রিয় ওপেন সোর্স সিস্টেম মনিটরিং টুল, যা সার্ভার এবং নেটওয়ার্ক সার্ভিস মনিটর করতে ব্যবহৃত হয়। এটি রিয়েল-টাইম অ্যালার্ম এবং রিপোর্ট প্রদান করতে পারে।

  • ব্যবহার:
    Nagios ইনস্টল করার জন্য অফিসিয়াল ডকুমেন্টেশন অনুসরণ করা উচিত।

2. Zabbix:

Zabbix একটি শক্তিশালী সিস্টেম মনিটরিং টুল যা ইন্টারফেসে রিয়েল-টাইম সিস্টেম মেট্রিক্স, ট্র্যাফিক এবং অন্যান্য তথ্য দেখায়।

  • ব্যবহার:
    Zabbix সার্ভার ইনস্টল এবং কনফিগার করা অত্যন্ত সহজ।

3. Prometheus & Grafana:

Prometheus হল একটি সিস্টেম মনিটরিং টুল যা ডেটা সংগ্রহ এবং সংরক্ষণ করে, এবং Grafana ব্যবহার করে আপনি তা চমৎকার ড্যাশবোর্ডে প্রদর্শন করতে পারেন।

  • ব্যবহার:
    Prometheus এবং Grafana ইন্টিগ্রেশন মাধ্যমে আরও উন্নত মনিটরিং সিস্টেম তৈরি করা যায়।

সারসংক্ষেপ

লগিং এবং মনিটরিং সিস্টেমের কার্যক্ষমতা এবং নিরাপত্তা নিশ্চিত করতে অত্যন্ত গুরুত্বপূর্ণ। লগিং ব্যবহারের মাধ্যমে সিস্টেমের গুরুত্বপূর্ণ ইভেন্ট ট্র্যাক করা যায় এবং মনিটরিংয়ের মাধ্যমে সিস্টেমের পারফরম্যান্স এবং রিসোর্স ব্যবহারের রিয়েল-টাইম অবস্থা দেখা যায়। এই টুলস এবং কমান্ডগুলি সিস্টেম অ্যাডমিনিস্ট্রেটরদের সিস্টেমের স্বাস্থ্য বজায় রাখতে এবং সমস্যাগুলি দ্রুত সমাধান করতে সহায়ক।

Content added By

লগ ফাইলের ধারণা এবং লগিং সিস্টেম

লগ ফাইল হল এমন একটি ফাইল যেখানে সফটওয়্যার, সিস্টেম, বা অ্যাপ্লিকেশন দ্বারা ঘটিত বিভিন্ন ঘটনার (events) বা ক্রিয়াকলাপের বিবরণ রেকর্ড করা হয়। এগুলি সাধারণত ডায়াগনস্টিক বা ট্রাবলশুটিং তথ্য ধারণ করে এবং সিস্টেম অ্যাডমিনিস্ট্রেটর বা ডেভেলপারদের জন্য গুরুত্বপূর্ণ। লগিং সিস্টেম হল সেই কাঠামো বা প্রক্রিয়া যা লগ ফাইলগুলির সৃষ্টি, সংগ্রহ, বিশ্লেষণ এবং সংরক্ষণ পরিচালনা করে।


১. লগ ফাইলের ধারণা

লগ ফাইল একটি সাধারণ টেক্সট ফাইল যা প্রোগ্রাম, সার্ভার বা অপারেটিং সিস্টেমের কাজের সময় ঘটে যাওয়া ক্রিয়াকলাপ এবং ত্রুটি সম্পর্কে তথ্য ধারণ করে। এই ফাইলগুলো সিস্টেমের বিভিন্ন কাজের জন্য অপরিহার্য, কারণ এগুলো বিভিন্ন ঘটনা, সমস্যার সমাধান, সিস্টেম পর্যবেক্ষণ এবং কর্মক্ষমতা ট্র্যাক করতে সহায়ক।

লগ ফাইলের উদাহরণ:

  1. অ্যাপ্লিকেশন লগ: যেখানে সফটওয়্যার বা অ্যাপ্লিকেশনটির কার্যক্রমের তথ্য রেকর্ড হয়।
  2. সিস্টেম লগ: সিস্টেমের সমস্ত ক্রিয়া এবং ত্রুটির তথ্য থাকে। যেমন, অপারেটিং সিস্টেম বুট, শাটডাউন, এবং অন্যান্য কাজ।
  3. সার্ভার লগ: যেমন, ওয়েব সার্ভারের লগ ফাইল যা HTTP অনুরোধ, ত্রুটি, এবং অন্যান্য কার্যকলাপ রেকর্ড করে।

২. লগিং সিস্টেম

লগিং সিস্টেম হল একটি কাঠামো যা লগ ফাইল তৈরি এবং পরিচালনা করার জন্য ব্যবহৃত হয়। এর মধ্যে লগ ফাইলের রেকর্ডিং, অ্যাক্সেস, সংরক্ষণ এবং পরবর্তী বিশ্লেষণ অন্তর্ভুক্ত থাকে।

লগিং সিস্টেমের কিছু গুরুত্বপূর্ণ উপাদান হল:

  1. লগ স্তর (Log Levels):
    লগ স্তরগুলি বিভিন্ন গুরুত্ব এবং প্রাধান্যের সাথে লগ বার্তা শ্রেণীবদ্ধ করার জন্য ব্যবহৃত হয়। এর মধ্যে নিম্নলিখিত স্তরগুলি অন্তর্ভুক্ত থাকে:
    • TRACE: সবচেয়ে বিস্তারিত লগ তথ্য।
    • DEBUG: ডিবাগিং তথ্য, যা বিকাশ বা পরীক্ষার সময় গুরুত্বপূর্ণ।
    • INFO: সাধারণ তথ্য, যা সিস্টেমের স্বাভাবিক কার্যক্রম বর্ণনা করে।
    • WARN: সতর্কতা, যা কিছু অস্বাভাবিক পরিস্থিতি নির্দেশ করে কিন্তু সিস্টেমে প্রভাব ফেলছে না।
    • ERROR: ত্রুটি বা সমস্যা, যা সিস্টেমের কাজকে বাধাগ্রস্ত করতে পারে।
    • FATAL: গুরুতর ত্রুটি যা সিস্টেমের কাজকে সম্পূর্ণভাবে ব্যাহত করে।
  2. লগ রোটেশন (Log Rotation):
    লগ ফাইলগুলি সময়ের সাথে বড় হতে থাকে, তাই পুরানো লগ ফাইলগুলি রোটেট (প্রবাহিত) করা প্রয়োজন। লগ রোটেশন একটি প্রক্রিয়া যা পুরানো লগ ফাইলকে আর্কাইভ করে, নতুন ফাইল তৈরি করে এবং ডিস্ক স্পেস রক্ষা করে।

    কমান্ড উদাহরণ:

    • Logrotate: এটি একটি জনপ্রিয় টুল যা লিনাক্স সিস্টেমে লগ ফাইলের রোটেশন পরিচালনা করতে ব্যবহৃত হয়। logrotate কনফিগারেশন ফাইলে আপনি লগ ফাইলের আকার, রোটেশন সময়সীমা ইত্যাদি সেট করতে পারেন।
  3. লগ ফাইল ফরম্যাট:
    লগ ফাইলগুলি সাধারণত পঠনযোগ্য টেক্সট ফরম্যাটে থাকে, তবে কিছু ক্ষেত্রে বাইনারি ফরম্যাটেও থাকতে পারে। প্রতিটি লগ এন্ট্রি সাধারণত সময় স্ট্যাম্প, লগ স্তর, ত্রুটি বা বার্তার বিবরণ, এবং কখনও কখনও ব্যবহৃত আইপি ঠিকানা বা ইউজার আইডি অন্তর্ভুক্ত থাকে।

    উদাহরণ:

    2024-11-11 12:34:56 INFO User 'alice' logged in from 192.168.1.10
  4. লগিং ফ্রেমওয়ার্ক:
    বিভিন্ন প্রোগ্রামিং ভাষায় লগিং ব্যবস্থাপনা করতে বিভিন্ন লগিং ফ্রেমওয়ার্ক এবং লাইব্রেরি থাকে। উদাহরণস্বরূপ:
    • Java: Log4j, SLF4J
    • Python: logging মডিউল
    • Node.js: winston, bunyan
  5. লগ ফাইল সংগ্রহ:
    বড় পরিসরে, বিশেষত ডিস্ট্রিবিউটেড সিস্টেমে, লগ ফাইলগুলি একক অবস্থান বা সার্ভারে সংগ্রহ করা হয় এবং সেগুলি বিশ্লেষণের জন্য কেন্দ্রীয় লগিং সিস্টেমে পাঠানো হয়। এটি সিস্টেম অ্যাডমিনিস্ট্রেটরদের এবং ডেভেলপারদের লগ গুলি সহজে অ্যাক্সেস এবং বিশ্লেষণ করতে সাহায্য করে।

    উদাহরণস্বরূপ:

    • ELK Stack (Elasticsearch, Logstash, Kibana): একটি জনপ্রিয় লগ বিশ্লেষণ প্ল্যাটফর্ম।
    • Splunk: একটি শক্তিশালী লগ ব্যবস্থাপনা এবং বিশ্লেষণ সরঞ্জাম।

৩. লিনাক্সে লগ ফাইল এবং লগিং সিস্টেম

LINUX সিস্টেমে অনেক প্রকারের লগ ফাইল থাকে এবং এগুলি /var/log/ ডিরেক্টরিতে সংরক্ষিত হয়। কিছু গুরুত্বপূর্ণ লিনাক্স লগ ফাইলের মধ্যে:

  1. /var/log/syslog: সিস্টেমের সাধারণ লগ ফাইল, যেখানে সিস্টেম এবং অ্যাপ্লিকেশন সম্পর্কিত তথ্য রেকর্ড হয়।
  2. /var/log/auth.log: ইউজার লগইন এবং অন্যান্য নিরাপত্তা সম্পর্কিত তথ্য।
  3. /var/log/messages: সাধারণ সিস্টেমের বার্তা এবং ত্রুটি তথ্য।
  4. /var/log/kern.log: কার্নেল সম্পর্কিত লগ ফাইল।
  5. /var/log/dmesg: বুট সময়ে সিস্টেমের মেসেজ লগ।

৪. লগ ফাইল বিশ্লেষণ এবং মনিটরিং

  1. tail কমান্ড: একটি লগ ফাইলে শেষের কয়েকটি লাইন দেখতে ব্যবহৃত হয়।

    tail -f /var/log/syslog
  2. grep কমান্ড: লগ ফাইলের মধ্যে নির্দিষ্ট তথ্য অনুসন্ধান করতে ব্যবহৃত হয়।

    grep "error" /var/log/syslog
  3. less কমান্ড: লগ ফাইলের মধ্যে সহজভাবে নেভিগেট করতে ব্যবহৃত হয়।

    less /var/log/syslog

সারসংক্ষেপ

  • লগ ফাইল সিস্টেমের কার্যক্রম, ত্রুটি, এবং অন্যান্য গুরুত্বপূর্ণ তথ্য ধারণ করে এবং এটি সিস্টেম অ্যাডমিনিস্ট্রেটরদের জন্য ডায়াগনস্টিক তথ্য সরবরাহ করে।
  • লগিং সিস্টেম একটি কাঠামো যা লগ ফাইল তৈরি, রোটেট, এবং বিশ্লেষণ করতে ব্যবহৃত হয়।
  • লগ ফাইলের মধ্যে লগ স্তর, লগ রোটেশন, এবং ফরম্যাট সহ বিভিন্ন বৈশিষ্ট্য থাকে।
  • LINUX সিস্টেমে /var/log/ ডিরেক্টরিতে লগ ফাইলগুলি সংরক্ষিত থাকে এবং সেগুলি বিশ্লেষণের জন্য কমান্ড-লাইন টুলস যেমন tail, grep, less ব্যবহার করা হয়।

এগুলি লগ ফাইল এবং লগিং সিস্টেমের মূল ধারণা, যা সিস্টেম মনিটরিং, ডায়াগনস্টিক এবং নিরাপত্তা উদ্দেশ্যে গুরুত্বপূর্ণ।

Content added By

লগ ফাইল দেখা এবং বিশ্লেষণ: /var/log

/var/log ডিরেক্টরি UNIX এবং LINUX সিস্টেমে সিস্টেম, অ্যাপ্লিকেশন এবং সার্ভিসগুলির লগ ফাইল সংরক্ষণ করার জন্য ব্যবহৃত হয়। এই লগ ফাইলগুলি সিস্টেম প্রশাসকদের জন্য অত্যন্ত গুরুত্বপূর্ণ, কারণ এগুলি সিস্টেমের কার্যক্রম, ত্রুটি, এবং অন্যান্য গুরুত্বপূর্ণ তথ্যের রেকর্ড রাখে। লগ ফাইল বিশ্লেষণ করা সিস্টেমের সমস্যা চিহ্নিতকরণ এবং সমাধানে সহায়ক।


/var/log ডিরেক্টরি

/var/log হল সিস্টেম লগের জন্য একটি গুরুত্বপূর্ণ ডিরেক্টরি। এখানে বিভিন্ন ধরনের লগ ফাইল থাকে যা সিস্টেমের কার্যক্রম এবং ত্রুটি সম্পর্কে তথ্য সরবরাহ করে। কিছু সাধারণ লগ ফাইল যা /var/log ডিরেক্টরিতে থাকে:

  • /var/log/syslog বা /var/log/messages: সিস্টেমের সাধারণ লগ, যেখানে সিস্টেমের অন্যান্য কার্যক্রমের রেকর্ড থাকে।
  • /var/log/auth.log: সিস্টেমের নিরাপত্তা এবং প্রমাণীকরণ সম্পর্কিত লগ, যেমন লগইন প্রচেষ্টা, sudo ব্যবহার, এবং অন্যান্য নিরাপত্তা সম্পর্কিত ঘটনা।
  • /var/log/cron: ক্রন জবের লগ, যেখানে শিডিউল করা স্ক্রিপ্ট এবং কাজের তথ্য থাকে।
  • /var/log/dmesg: বুট লগ, যেখানে সিস্টেমের বুট সময়ে ডিভাইস, মডিউল লোডিং এবং হার্ডওয়্যার সম্পর্কিত তথ্য থাকে।
  • /var/log/boot.log: সিস্টেম বুট সম্পর্কিত লগ।
  • /var/log/apt: প্যাকেজ ম্যানেজার (যেমন apt) দ্বারা পরিচালিত ইনস্টলেশন এবং আপডেট সম্পর্কিত লগ (উবুন্টু/ডেবিয়ান ভিত্তিক সিস্টেমে)।
  • /var/log/httpd/ বা /var/log/nginx/: ওয়েব সার্ভারের লগ ফাইল (যেমন Apache বা Nginx)।

লগ ফাইল দেখা

লগ ফাইলগুলি দেখতে এবং বিশ্লেষণ করতে কিছু সাধারণ কমান্ড রয়েছে:

1. cat কমান্ড:

cat কমান্ডটি ফাইলের পূর্ণ বিষয়বস্তু একবারে দেখতে ব্যবহৃত হয়। তবে লগ ফাইলগুলি সাধারণত বড় হয়ে থাকে, তাই এটি সব সময় কার্যকর নয়।

কমান্ড উদাহরণ:

cat /var/log/syslog

এটি /var/log/syslog ফাইলের সমস্ত কন্টেন্ট দেখাবে।

2. less বা more কমান্ড:

less এবং more কমান্ডগুলি লম্বা লগ ফাইলগুলি পেজ বাই পেজ দেখার জন্য ব্যবহৃত হয়।

কমান্ড উদাহরণ:

less /var/log/syslog

এটি /var/log/syslog ফাইলটি পেজ বাই পেজ দেখাবে এবং আপনি স্ক্রোল করতে পারবেন।

3. tail কমান্ড:

tail কমান্ডটি ফাইলের শেষের কয়েকটি লাইন দেখতে ব্যবহৃত হয়, যা সাধারণত লগ ফাইলের সর্বশেষ এন্ট্রি বা ত্রুটি দেখানোর জন্য ব্যবহৃত হয়।

কমান্ড উদাহরণ:

tail /var/log/syslog

এটি /var/log/syslog ফাইলের শেষ ১০টি লাইন দেখাবে (ডিফল্টভাবে ১০টি লাইন দেখায়)।

4. tail -f কমান্ড:

tail -f কমান্ডটি লাইভ লগ মনিটরিংয়ের জন্য ব্যবহৃত হয়। এটি নতুন লগ এন্ট্রি আসলে তা রিয়েল-টাইমে দেখায়।

কমান্ড উদাহরণ:

tail -f /var/log/syslog

এটি /var/log/syslog ফাইলের নতুন এন্ট্রিগুলি রিয়েল-টাইমে দেখাবে।

5. grep কমান্ড:

grep কমান্ডটি লগ ফাইলের মধ্যে নির্দিষ্ট শব্দ বা প্যাটার্ন খোঁজার জন্য ব্যবহৃত হয়। এটি ত্রুটি বা নির্দিষ্ট ঘটনাগুলি দ্রুত খুঁজে বের করতে সহায়ক।

কমান্ড উদাহরণ:

grep "error" /var/log/syslog

এটি /var/log/syslog ফাইলের মধ্যে error শব্দের সমস্ত ঘটনার জন্য অনুসন্ধান করবে।

grep "login" /var/log/auth.log

এটি /var/log/auth.log ফাইলে login সম্পর্কিত সমস্ত এন্ট্রি খুঁজে বের করবে।

6. journalctl কমান্ড (systemd ব্যবহৃত সিস্টেমের জন্য):

journalctl হল systemd ভিত্তিক সিস্টেমের জন্য একটি শক্তিশালী লগ ভিউয়ার। এটি সিস্টেমের সমস্ত লগ দেখার জন্য ব্যবহৃত হয়।

কমান্ড উদাহরণ:

journalctl

এটি systemd সিস্টেমের সমস্ত লগ দেখাবে।

journalctl -u apache2

এটি apache2 সেবার লগ দেখাবে।


লগ ফাইল বিশ্লেষণ

লগ ফাইল বিশ্লেষণ করতে কিছু সাধারণ টিপস:

  1. ত্রুটি চিহ্নিতকরণ:
    • error এবং failed মতো শব্দগুলি খুঁজে বের করুন যাতে সিস্টেমের কোনো সমস্যা চিহ্নিত করা যায়।
    • grep কমান্ড ব্যবহার করে নির্দিষ্ট ত্রুটির প্যাটার্ন খুঁজে বের করুন (যেমন grep "error" /var/log/syslog)।
  2. প্রবণতা চিহ্নিতকরণ:
    • লগ ফাইল বিশ্লেষণের মাধ্যমে, আপনি সিস্টেমের প্রতি সময়ে কতটা চাপ বা লোড হচ্ছে তা দেখতে পারেন এবং কোন সময়ের মধ্যে সিস্টেমে সমস্যা বেশি হচ্ছে তা চিহ্নিত করতে পারেন।
  3. সুরক্ষা বিশ্লেষণ:
    • /var/log/auth.log বা /var/log/secure ফাইলগুলি নিরাপত্তা সম্পর্কিত ঘটনা যেমন লগইন প্রচেষ্টা, sudo ব্যবহারের তথ্য প্রদান করে, যা সিস্টেমে সুরক্ষার বিষয়ে বিশ্লেষণ করতে সাহায্য করে।
  4. সার্ভিস ট্রাবলশুটিং:
    • /var/log/syslog বা /var/log/messages ফাইলগুলি সিস্টেমের সার্ভিস বা ডেমনের (যেমন Apache, Nginx, MySQL) কাজের তথ্য ধারণ করে। এগুলি যাচাই করে আপনি সার্ভিসগুলির কার্যকারিতা বিশ্লেষণ করতে পারেন।

সারসংক্ষেপ

  • /var/log ডিরেক্টরি সিস্টেমের বিভিন্ন লগ ফাইল ধারণ করে, যা সিস্টেম অ্যাডমিনিস্ট্রেটরদের জন্য গুরুত্বপূর্ণ।
  • tail এবং tail -f কমান্ড দিয়ে আপনি লগ ফাইলের সর্বশেষ এন্ট্রি দেখতে পারেন বা লাইভ লগ মনিটর করতে পারেন।
  • grep কমান্ডের মাধ্যমে আপনি নির্দিষ্ট শব্দ বা প্যাটার্ন অনুসন্ধান করতে পারেন।
  • journalctl হল systemd সিস্টেমে ব্যবহৃত একটি শক্তিশালী লগ ভিউয়ার।

লগ ফাইলগুলি সিস্টেম প্রশাসকদের জন্য সিস্টেম মনিটরিং এবং সমস্যা সমাধানের জন্য অপরিহার্য টুল।

Content added By

সিস্টেম মনিটরিং টুল: top, htop, vmstat, iostat, dmesg

সিস্টেম মনিটরিং টুলগুলি ব্যবহারকারীদের তাদের সিস্টেমের স্বাস্থ্য, কার্যকারিতা এবং সম্পদ ব্যবহারের তথ্য প্রদর্শন করতে সাহায্য করে। এই টুলগুলির মাধ্যমে আপনি সিস্টেমের প্রসেস, মেমরি, সিপিইউ, ডিস্ক ব্যবহারের পরিস্থিতি, ইনপুট/আউটপুট স্ট্যাটাস এবং অন্যান্য সিস্টেমের মেট্রিকস সম্পর্কে বিস্তারিত তথ্য পেতে পারেন। কিছু জনপ্রিয় সিস্টেম মনিটরিং টুল হচ্ছে top, htop, vmstat, iostat, এবং **dmesg**। নিচে তাদের ব্যাখ্যা এবং ব্যবহার দেখানো হয়েছে।


1. top কমান্ড

top কমান্ড একটি রিয়েল-টাইম সিস্টেম মনিটরিং টুল যা সিস্টেমের প্রসেস, মেমরি ব্যবহার, সিপিইউ ব্যবহার, ডিস্ক ব্যবহার এবং অন্যান্য সিস্টেমের মেট্রিকস সম্পর্কে তথ্য প্রদান করে। এটি সিস্টেমের বর্তমান পরিস্থিতি সম্পর্কে দ্রুত এবং সাম্প্রতিক তথ্য দেখায়।

ব্যবহার:

top

এটি সিস্টেমের সব চলমান প্রসেসের তালিকা দেখাবে, তাদের ব্যবহার করা সিপিইউ, মেমরি, আই/ও (I/O) এবং অন্যান্য বিভিন্ন পরামিতি সহ।

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

top - 15:30:11 up  2:15,  3 users,  load average: 0.15, 0.25, 0.30
Tasks: 150 total,   1 running,  149 sleeping,   0 stopped,   0 zombie
%Cpu(s):  5.2 us,  2.4 sy,  0.0 ni, 91.4 id,  0.0 wa,  0.0 hi,  1.0 si,  0.0 st
MiB Mem :  8000.0 total,  1500.0 free,  3200.0 used,  3300.0 buff/cache
MiB Swap:  2000.0 total,  1800.0 free,   200.0 used.  4500.0 avail Mem
  • us (user): ব্যবহারকারী প্রক্রিয়া দ্বারা ব্যবহৃত সিপিইউ
  • sy (system): সিস্টেম বা ক্রীটিকাল প্রসেস দ্বারা ব্যবহৃত সিপিইউ
  • id (idle): অনুপস্থিত বা ফাঁকা সিপিইউ
  • wa (waiting): ডিস্ক বা I/O অপারেশনে অপেক্ষমাণ সিপিইউ

বিশেষ ফাংশনালিটি:

  • Shift + P: সিপিইউ ব্যবহার অনুসারে প্রসেস সাজান
  • Shift + M: মেমরি ব্যবহার অনুসারে প্রসেস সাজান
  • q: top থেকে বের হতে

2. htop কমান্ড

htop কমান্ড top এর একটি উন্নত সংস্করণ। এটি আরও ইন্টারঅ্যাকটিভ এবং ব্যবহারকারী বান্ধব ইন্টারফেস প্রদান করে, যেখানে রঙের মাধ্যমে সিপিইউ, মেমরি এবং অন্যান্য সিস্টেম রিসোর্সগুলি বিশ্লেষণ করা সহজ হয়। এটি একটি টেক্সট-ভিত্তিক GUI এর মতো কাজ করে এবং আপনাকে প্রসেস কিল বা অন্যান্য সিস্টেম রিসোর্স ম্যানেজমেন্ট অপারেশন করতে সহায়তা করে।

ব্যবহার:

htop

এটি top এর মতো একই ধরনের তথ্য প্রদান করে তবে আরও বেশি ইন্টারঅ্যাকটিভ এবং পরিষ্কারভাবে রঙের মাধ্যমে প্রদর্শিত হয়। htop টুলে আপনি মাউস দিয়ে কোনো প্রসেসে ক্লিক করে সেটি কিল করতে পারেন বা অন্যান্য নিয়ন্ত্রণ করতে পারেন।

বিশেষ ফাংশনালিটি:

  • F6: কাস্টম সার্টিং সিস্টেম (সিপিইউ, মেমরি, পিআইডি)
  • F9: প্রসেস কিল করার অপশন
  • F10: htop থেকে বের হতে

প্রতিস্থাপন: htop কমান্ড সাধারণত top এর চেয়ে বেশি শক্তিশালী এবং সুদৃশ্য ইন্টারফেস প্রদান করে, তাই এটি অনেক ব্যবহারকারী পছন্দ করেন।


3. vmstat কমান্ড

vmstat (Virtual Memory Statistics) কমান্ড একটি সিস্টেমের মেমরি, প্রসেসিং, এবং ইনপুট/আউটপুট কার্যক্রমের পরিসংখ্যান প্রদর্শন করে। এটি একটি খুবই গুরুত্বপূর্ণ টুল, যা সিস্টেমের কর্মক্ষমতা এবং অবস্থা দ্রুত পর্যবেক্ষণ করতে সাহায্য করে।

ব্যবহার:

vmstat

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

procs -----------memory---------- ---swap-- -----io---- --system-- ----cpu----
 r  b   swpd   free   buff  cache   si  so   bi   bo   in   cs us sy id wa st
 1  0      0  35844  12256  34844    0   0   56   56   468  309  12  3  85  0  0
  • r: রানিং প্রসেসের সংখ্যা
  • b: ব্লক করা প্রসেস
  • swpd: সোয়াপ ব্যবহৃত
  • free: ফ্রি মেমরি
  • buff: বাফার্ড মেমরি
  • cache: ক্যাশ করা মেমরি
  • si: সোয়াপ ইন (swap in)
  • so: সোয়াপ আউট (swap out)
  • bi: ব্লক ইন (I/O)
  • bo: ব্লক আউট (I/O)
  • us, sy, id: সিপিইউ ব্যবহার

বিশেষ ফাংশনালিটি:

  • vmstat 1: প্রতি ১ সেকেন্ড পর পর রিফ্রেশ হওয়া পরিসংখ্যান

4. iostat কমান্ড

iostat (Input/Output Statistics) কমান্ড সিস্টেমের ডিস্ক এবং ইনপুট/আউটপুট কার্যক্রম সম্পর্কে পরিসংখ্যান প্রদর্শন করে। এটি ডিস্ক পারফরম্যান্স মনিটর করতে এবং সিস্টেমের ইনপুট/আউটপুট কাজের সময় বিশ্লেষণ করতে সাহায্য করে।

ব্যবহার:

iostat

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

Linux 4.15.0-54-generic (hostname)     01/01/2020     _x86_64_    (4 CPU)

Device            tps    kB_read/s   kB_wrtn/s   kB_read   kB_wrtn
sda              2.03        45.23        23.56   180920   94248
sdb              1.10         5.23         2.56    20932    9932
  • tps: ডিস্কে প্রতি সেকেন্ডে ট্রান্সফার করা অপারেশন
  • kB_read/s: প্রতি সেকেন্ডে পড়া কিলোবাইট
  • kB_wrtn/s: প্রতি সেকেন্ডে লেখা কিলোবাইট

বিশেষ ফাংশনালিটি:

  • iostat -x: বিস্তারিত পারফরম্যান্স পরিসংখ্যান দেখানোর জন্য
  • iostat -d 2: প্রতি ২ সেকেন্ড পর পর ডিস্ক স্ট্যাটাস দেখতে

5. dmesg কমান্ড

dmesg কমান্ড সিস্টেমের বুট লগ এবং কার্নেল মেসেজ দেখার জন্য ব্যবহৃত হয়। এটি সিস্টেম স্টার্টআপের সময়ে বা কার্নেল ইভেন্টগুলোর লগ প্রদর্শন করে, যেমন হার্ডওয়্যার সম্পর্কিত সমস্যা বা অন্যান্য সিস্টেমের তথ্য।

ব্যবহার:

dmesg

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

[    0.000000] Booting Linux on physical CPU 0x0
[    0.001234] Initializing cgroup subsys cpuset
[    0.002345] Initializing cgroup subsys cpu
[    0.003456] CPU: Intel(R) Core(TM) i7-8550U CPU @ 1

.80GHz

বিশেষ ফাংশনালিটি:

  • dmesg | grep error: লগে error শব্দের সাথে সম্পর্কিত মেসেজ খুঁজে বের করা
  • dmesg -T: সময় সহ লগের আউটপুট দেখানো

সারসংক্ষেপ

এই সিস্টেম মনিটরিং টুলগুলির মাধ্যমে আপনি সিস্টেমের পারফরম্যান্স, রিসোর্স ব্যবহারের পরিসংখ্যান এবং সিস্টেমের কার্যক্রম সম্পর্কে বিস্তারিত তথ্য পেতে পারেন। top এবং htop আপনাকে রিয়েল-টাইম প্রসেস মনিটরিং করতে সহায়ক, vmstat মেমরি ও প্রসেস পরিসংখ্যান প্রদান করে, iostat ডিস্ক পারফরম্যান্স পর্যালোচনা করতে সহায়ক, এবং dmesg সিস্টেম লগ দেখার জন্য ব্যবহৃত হয়।

Content added By

কমান্ড এবং বুট লগ দেখা

বুট লগ বা বুট মেসেজ হল সেই লগ ফাইলগুলি যা সিস্টেমের বুট হওয়ার সময় সমস্ত কার্যক্রম রেকর্ড করে। এই লগগুলি বিশেষভাবে সহায়ক হতে পারে যদি সিস্টেমের বুটের সময় কোনো সমস্যা দেখা দেয়। সিস্টেমের বুটের সময়ের কার্যক্রম এবং ত্রুটি সনাক্ত করতে বুট লগ দেখা অত্যন্ত গুরুত্বপূর্ণ।

1. বুট লগ কোথায় থাকে?

বুট লগ সাধারণত /var/log/ ডিরেক্টরির মধ্যে থাকে, যেখানে বেশ কয়েকটি লগ ফাইল সিস্টেমের কার্যক্রম এবং সিস্টেমের বিভিন্ন পরিষেবার তথ্য ধারণ করে।

সাধারণত বুট লগ ফাইলের নাম হতে পারে:

  • /var/log/dmesg
  • /var/log/boot.log
  • /var/log/syslog (Ubuntu/Debian সিস্টেমে)
  • /var/log/messages (CentOS/RHEL সিস্টেমে)

2. dmesg কমান্ড

dmesg কমান্ড ব্যবহার করা হয় বুট লগের জন্য যেসব মেসেজ সিস্টেমের বুট চলাকালীন প্রিন্ট হয় তা দেখতে। এটি মূলত সিস্টেমের কোর (kernel) দ্বারা সৃষ্ট মেসেজ এবং ত্রুটি সম্পর্কিত তথ্য দেখায়।

ব্যবহার:

dmesg

এটি সিস্টেমের বুট এবং হার্ডওয়্যার সম্পর্কিত মেসেজগুলি দেখাবে। অনেক সময় এই মেসেজগুলি ডিভাইস, হার্ডওয়্যার সমস্যা এবং ত্রুটির তথ্য দেয়।

অপশন সহ ব্যবহার:

  • -T: টাইমস্ট্যাম্প সহ মানব-পঠনযোগ্য ফরম্যাটে আউটপুট দেখাবে।

    dmesg -T
  • -H: অধিক পাঠযোগ্য আউটপুট প্রদর্শন করবে (ব্যবহারকারী ইন্টারফেসে সহজ দেখতে)।

    dmesg -H
  • | less: অনেক লাইন হলে আউটপুট স্ক্রোল করতে।

    dmesg | less

3. /var/log/boot.log ফাইল

/var/log/boot.log ফাইলটি সিস্টেমের বুট সময়ে সমস্ত পরিষেবার স্টার্ট-আপ মেসেজ সংরক্ষণ করে। এটি বিশেষভাবে উপকারী যখন আপনি সিস্টেমের বুটের সময় কোনো সমস্যা চিহ্নিত করতে চান।

ব্যবহার:

cat /var/log/boot.log

এটি সিস্টেম বুট করার সময়ের সমস্ত মেসেজ দেখাবে, যেমন পরিষেবার স্টার্ট হওয়া, ত্রুটি, এবং সিস্টেমের অন্যান্য কার্যক্রম।

less ব্যবহার:

less /var/log/boot.log

এটি ফাইলটি স্ক্রলযোগ্যভাবে দেখাবে।


4. /var/log/syslog (Ubuntu/Debian সিস্টেমে)

/var/log/syslog ফাইলটি সিস্টেমের সাধারণ লগ যা সিস্টেমের বিভিন্ন কার্যক্রম এবং পরিষেবার মেসেজ ধারণ করে। Ubuntu বা Debian সিস্টেমে এই ফাইলটি সিস্টেমের বুট মেসেজও ধারণ করে।

ব্যবহার:

cat /var/log/syslog

এই ফাইলটি আপনাকে সিস্টেমের কার্যক্রম এবং বুট সম্পর্কিত মেসেজ প্রদান করবে।

less ব্যবহার:

less /var/log/syslog

এটি ফাইলের বিষয়বস্তু স্ক্রল করে দেখাবে।


5. /var/log/messages (CentOS/RHEL সিস্টেমে)

/var/log/messages ফাইলটি CentOS বা RHEL সিস্টেমের সিস্টেম বার্তা এবং বুট লগ ধারণ করে। এটি সাধারণত সিস্টেমের সমস্যা এবং কার্যক্রম সম্পর্কিত তথ্য দেয়।

ব্যবহার:

cat /var/log/messages

এই কমান্ডটি সিস্টেমের সমস্ত বার্তা এবং বুট সম্পর্কিত তথ্য দেখাবে।

less ব্যবহার:

less /var/log/messages

এটি আউটপুট স্ক্রলযোগ্যভাবে দেখাবে।


6. journalctl কমান্ড (Systemd সিস্টেমে)

Systemd সিস্টেমে, journalctl কমান্ড ব্যবহার করে আপনি সিস্টেম লগগুলি দেখতে পারেন, যার মধ্যে বুট লগও অন্তর্ভুক্ত থাকে।

ব্যবহার:

journalctl

এটি সিস্টেমের সমস্ত লগ দেখাবে। তবে যদি আপনি শুধুমাত্র বুট লগ দেখতে চান, তবে আপনি -b অপশন ব্যবহার করতে পারেন।

ব্যবহার:

journalctl -b

এই কমান্ডটি বর্তমান বুটের সাথে সম্পর্কিত সমস্ত লগ দেখাবে।

অপশন সহ ব্যবহার:

  • -b -1: পূর্ববর্তী বুট লগ দেখাতে।

    journalctl -b -1
  • -p: নির্দিষ্ট প্রাধিকার স্তরের লগ দেখতে (যেমন warning, err, info)।

    journalctl -p err

সারসংক্ষেপ

সিস্টেমের বুট লগ দেখতে বিভিন্ন কমান্ড ব্যবহার করা যেতে পারে, যেমন:

  • dmesg: বুট এবং হার্ডওয়্যার সম্পর্কিত মেসেজ দেখার জন্য।
  • /var/log/boot.log: বুট সময়ের সিস্টেম কার্যক্রম দেখতে।
  • /var/log/syslog: Ubuntu/Debian সিস্টেমে সিস্টেম লগ।
  • /var/log/messages: CentOS/RHEL সিস্টেমে সিস্টেম বার্তা।
  • journalctl: Systemd সিস্টেমের জন্য বুট এবং অন্যান্য লগ।

এই কমান্ডগুলো সিস্টেম অ্যাডমিনিস্ট্রেশন, ত্রুটি শনাক্তকরণ এবং সিস্টেমের কার্যক্রম মনিটর করার জন্য অত্যন্ত গুরুত্বপূর্ণ।

Content added By
Promotion

Are you sure to start over?

Loading...