Academy

ইলাস্টিকসার্চ (ElasticSearch)

Latest Technologies | NCTB BOOK

Elasticsearch হলো একটি ওপেন সোর্স, ডিস্ট্রিবিউটেড অনুসন্ধান ইঞ্জিন যা মূলত বিশাল পরিমাণের ডেটা দ্রুত অনুসন্ধান ও বিশ্লেষণ করার জন্য ডিজাইন করা হয়েছে। এটি Apache Lucene এর উপর ভিত্তি করে নির্মিত এবং JSON ফরম্যাটে ডেটা সংরক্ষণ করে। Elasticsearch বিশেষভাবে বড় ডেটাসেট এবং রিয়েল-টাইম ডেটা বিশ্লেষণের জন্য জনপ্রিয়।


Elasticsearch: একটি বিস্তারিত গাইড

Elasticsearch হলো একটি ওপেন সোর্স, ডিস্ট্রিবিউটেড নথি অনুসন্ধান ইঞ্জিন যা বিশাল পরিমাণের ডেটা দ্রুত এবং দক্ষতার সাথে অনুসন্ধান করতে ব্যবহৃত হয়। এটি Apache Lucene এর উপরে নির্মিত এবং এটি JSON ডেটা ফরম্যাটে তথ্য সংরক্ষণ করে। Elasticsearch সাধারণত লগ ব্যবস্থাপনা, বিশ্লেষণ এবং মাইক্রোসার্ভিস আর্কিটেকচারে ব্যবহৃত হয়।

১. Elasticsearch কি?

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

১.১ Elasticsearch এর মূল বৈশিষ্ট্য

  • রিয়েল-টাইম অনুসন্ধান: ডেটা ইনডেক্স করার সাথে সাথে তা অনুসন্ধানযোগ্য হয়।
  • স্কেলেবল: বড় ডেটাসেট সহজেই পরিচালনা করতে পারে।
  • নিষ্ক্রিয়: Elasticsearch RESTful API এর মাধ্যমে যোগাযোগ করে।
  • অনার্কি: ডেটা JSON ফরম্যাটে সংরক্ষণ করে।

১.২কিভাবে কাজ করে

Elasticsearch ডেটাকে ইনডেক্স করে এবং একটি শক্তিশালী অনুসন্ধান ইঞ্জিনের মাধ্যমে ব্যবহারকারীদের অনুসন্ধান প্রশ্নের উত্তর প্রদান করে। এটি ডেটা সার্চ এবং বিশ্লেষণে কার্যকরী সমাধান সরবরাহ করে।

 

২. Elasticsearch আর্কিটেকচার

Elasticsearch একটি ক্লাস্টার ভিত্তিক আর্কিটেকচার নিয়ে গঠিত। এর মূল উপাদানগুলো হলো:

২.১ ক্লাস্টার

একটি Elasticsearch ক্লাস্টার হলো এক বা একাধিক নোডের সমন্বয় যা একসাথে কাজ করে। ক্লাস্টার একটি ইউনিক ক্লাস্টার আইডি দ্বারা চিহ্নিত হয়।

২.২ নোড

একটি নোড হলো একটি একক Elasticsearch ইনস্টেন্স যা ক্লাস্টারের অংশ। এটি বিভিন্ন ধরনের হতে পারে:

  • ডেটা নোড: মূলত ডেটা সংরক্ষণ ও অনুসন্ধান করে।
  • মাস্টার নোড: ক্লাস্টারের অবস্থা পরিচালনা করে।
  • প্রক্সি নোড: ক্লাস্টারের অন্য নোডের সাথে যোগাযোগের জন্য ব্যবহৃত হয়।

২.৩ ইনডেক্স

একটি ইনডেক্স হলো একটি সংকলন নথি যা একই ধরনের ডেটা ধারণ করে। প্রতিটি ইনডেক্স একটি ইউনিক নাম দ্বারা চিহ্নিত হয়।

২.৪ ডকুমেন্ট

ডকুমেন্ট হলো একটি JSON অবজেক্ট যা ইনডেক্সের মধ্যে সংরক্ষিত হয়। এটি Elasticsearch এ প্রধান ডেটা একক।

২.৫ শার্ড

একটি ইনডেক্স একাধিক শার্ডে বিভক্ত হতে পারে, যা ডেটা বিতরণের জন্য ব্যবহৃত হয়। প্রতিটি শার্ড একটি স্বতন্ত্র নোডে থাকতে পারে।

৩. Elasticsearch এর ব্যবহার

৩.১ ইনস্টলেশন

Elasticsearch ইনস্টল করতে নিম্নলিখিত পদক্ষেপ অনুসরণ করুন:

Java ইনস্টল করুন: Elasticsearch Java এ তৈরি, তাই JDK ইনস্টল করা আবশ্যক। (Java 11 বা 17)

sudo apt-get install openjdk-11-jdk

Elasticsearch ডাউনলোড করুন: অফিসিয়াল ওয়েবসাইট থেকে Elasticsearch ডাউনলোড করুন।

ইনস্টলেশন সম্পন্ন করুন:

tar -xzf elasticsearch-7.x.x.tar.gz
cd elasticsearch-7.x.x

Elasticsearch চালু করুন:

./bin/elasticsearch

৩.২ ডেটা ইনডেক্স করা

Elasticsearch এ ডেটা ইনডেক্স করার জন্য, HTTP PUT বা POST কমান্ড ব্যবহার করা হয়। উদাহরণস্বরূপ:

PUT /my_index/_doc/1
{
  "title": "Elasticsearch Basics",
  "author": "ChatGPT",
  "content": "Elasticsearch is a powerful search engine."
}

৩.৩ ডেটা অনুসন্ধান

Elasticsearch এ ডেটা অনুসন্ধানের জন্য HTTP GET কমান্ড ব্যবহার করুন:

GET /my_index/_search
{
  "query": {
    "match": {
      "content": "powerful"
    }
  }
}

৪. Elasticsearch এর Query DSL

Elasticsearch এর অনুসন্ধান ক্ষমতা Query DSL (Domain Specific Language) এর মাধ্যমে সম্পন্ন হয়। এটি JSON ফরম্যাটে অনুসন্ধান প্রশ্ন তৈরি করতে ব্যবহৃত হয়।

৪.১ বিভিন্ন ধরনের অনুসন্ধান

ম্যাচ অনুসন্ধান:

{
  "query": {
    "match": {
      "title": "Basics"
    }
  }
}

বুলিয়ান অনুসন্ধান:

{
  "query": {
    "bool": {
      "must": [
        { "match": { "author": "ChatGPT" } },
        { "match": { "content": "powerful" } }
      ]
    }
  }
}

ফিল্টার অনুসন্ধান:

{
  "query": {
    "bool": {
      "filter": {
        "term": {
          "author": "ChatGPT"
        }
      }
    }
  }
}

৫. Elasticsearch ক্লাস্টার পরিচালনা

৫.১ ক্লাস্টার স্ট্যাটাস দেখা

ক্লাস্টারের বর্তমান অবস্থা দেখতে:

GET /_cluster/health

৫.২ ইনডেক্স মুছা

একটি ইনডেক্স মুছতে:

DELETE /my_index

৫.৩ ডেটা মুছা

ডেটা মুছতে:

DELETE /my_index/_doc/1

৬. Elasticsearch এর ব্যবহার ক্ষেত্র

লগ বিশ্লেষণ: Elasticsearch লগ ফাইল বিশ্লেষণ করতে ব্যবহার করা হয়। এটি বিভিন্ন সূত্র থেকে ডেটা সংগ্রহ করে এবং তা বিশ্লেষণ করে।

ডেটা বিশ্লেষণ: এটি ব্যবসায়িক তথ্য বিশ্লেষণ করতে ব্যবহৃত হয়, যেমন বিক্রয় পরিসংখ্যান, গ্রাহক বিশ্লেষণ ইত্যাদি।

অনুসন্ধান ইঞ্জিন: এটি একটি পূর্ণাঙ্গ অনুসন্ধান ইঞ্জিন হিসেবে ব্যবহৃত হয়, যেখানে ডেটা দ্রুত অনুসন্ধান করা যায়।

বিপণন বিশ্লেষণ: বিপণন কার্যক্রম এবং ক্যাম্পেইন বিশ্লেষণে সহায়তা করে।

৭. Elasticsearch এর সুবিধা

  • স্কেলেবিলিটি: Elasticsearch বড় ডেটাসেট পরিচালনা করতে সক্ষম।
  • রিয়েল-টাইম প্রক্রিয়াকরণ: ডেটা অনুসন্ধান এবং বিশ্লেষণ বাস্তব সময়ে করা যায়।
  • লজিক্যাল ও সমৃদ্ধ অনুসন্ধান: এটি কাস্টম অনুসন্ধান প্রশ্ন তৈরির জন্য JSON ফরম্যাট ব্যবহার করে।
  • RESTful API: ব্যবহারকারীরা HTTP API এর মাধ্যমে Elasticsearch এর সাথে যোগাযোগ করতে পারেন।

৮. উপসংহার

Elasticsearch হলো একটি শক্তিশালী অনুসন্ধান ইঞ্জিন যা দ্রুত এবং দক্ষতার সাথে ডেটা অনুসন্ধান এবং বিশ্লেষণ করতে সাহায্য করে। এটি বিভিন্ন ক্ষেত্রে ব্যবহৃত হয় এবং ডেভেলপারদের জন্য একটি অপরিহার্য টুল। যদি আপনি Elasticsearch সম্পর্কে আরো বিস্তারিত জানতে চান বা নির্দিষ্ট কিছু বিষয়ে আলোচনা করতে চান, তাহলে নির্দিধায় জিজ্ঞেস করুন!

Promotion