Flume Source এর বেসিক ধারণা

অ্যাপাচি ফ্লুম (Apache Flume) - Big Data and Analytics

378

অ্যাপাচি ফ্লুম (Apache Flume) একটি শক্তিশালী ডেটা ইনজেস্ট টুল যা বিশেষভাবে বড় পরিমাণের লগ ডেটা সংগ্রহ এবং বিভিন্ন ডেটা স্টোরেজ সিস্টেমে পাঠানোর জন্য ব্যবহৃত হয়। ফ্লুমের সোর্স (Source) হল সেই উপাদান যা ডেটা সংগ্রহের কাজটি সম্পাদন করে। এই অংশটি ফ্লুমের আর্কিটেকচারের অন্যতম গুরুত্বপূর্ণ উপাদান।


সোর্স (Source) কী?

সোর্স হল ফ্লুমের প্রথম উপাদান যা বিভিন্ন ডেটা উৎস থেকে ডেটা গ্রহণ করে। এটি ডেটাকে ইভেন্ট (Event) আকারে রূপান্তরিত করে এবং চ্যানেলে (Channel) প্রেরণ করে। সোর্স বিভিন্ন ধরনের হতে পারে, যেমন লগ ফাইল, সোশ্যাল মিডিয়া স্ট্রিম, অথবা কাস্টম ডেটা উৎস।


সোর্সের ভূমিকা

  1. ডেটা সংগ্রহ: সোর্স বিভিন্ন উৎস থেকে ডেটা সংগ্রহ করে।
  2. ইভেন্ট রূপান্তর: সংগৃহীত ডেটাকে ইভেন্টে রূপান্তরিত করে।
  3. চ্যানেলে প্রেরণ: ইভেন্টগুলোকে চ্যানেলে প্রেরণ করে যাতে সিঙ্ক (Sink) এগুলো গ্রহণ করতে পারে।

সোর্সের ধরন

ফ্লুম বিভিন্ন ধরনের সোর্স সাপোর্ট করে, যার মধ্যে কিছু প্রধান সোর্সের ধরন নিচে দেওয়া হল:

১. স্পুলডির সোর্স (SpoolDir Source)

  • ব্যবহার: নির্দিষ্ট ডিরেক্টরিতে থাকা ফাইলগুলোকে পড়ে ডেটা সংগ্রহ করে।
  • উদাহরণ: লগ ফাইল সংগ্রহ।
  • কনফিগারেশন উদাহরণ:

    agent.sources.source1.type = spooldir
    agent.sources.source1.spoolDir = /var/logs
    

২. এক্সেক সোর্স (Exec Source)

  • ব্যবহার: কমান্ড লাইন কমান্ড চালিয়ে তার আউটপুট থেকে ডেটা সংগ্রহ করে।
  • উদাহরণ: স্ক্রিপ্টের আউটপুট সংগ্রহ।
  • কনফিগারেশন উদাহরণ:

    agent.sources.source1.type = exec
    agent.sources.source1.command = tail -F /var/log/syslog
    

৩. নেটক্যাট সোর্স (Netcat Source)

  • ব্যবহার: নির্দিষ্ট পোর্টে আসা নেটওয়ার্ক ট্র্যাফিক থেকে ডেটা সংগ্রহ করে।
  • উদাহরণ: রিয়েল-টাইম লগ ডেটা সংগ্রহ।
  • কনফিগারেশন উদাহরণ:

    agent.sources.source1.type = netcat
    agent.sources.source1.bind = 0.0.0.0
    agent.sources.source1.port = 44444
    

৪. অব্রো সোর্স (Avro Source)

  • ব্যবহার: Avro RPC সাপোর্ট করে, যা ক্লায়েন্ট সার্ভার আর্কিটেকচারে ব্যবহৃত হয়।
  • উদাহরণ: ডিস্ট্রিবিউটেড সিস্টেম থেকে ডেটা সংগ্রহ।
  • কনফিগারেশন উদাহরণ:

    agent.sources.source1.type = avro
    agent.sources.source1.bind = 0.0.0.0
    agent.sources.source1.port = 4141
    

সোর্স কনফিগারেশন

সোর্স কনফিগার করার জন্য ফ্লুমের কনফিগারেশন ফাইল (যেমন flume.conf) এ সোর্স সংক্রান্ত সেটিংস নির্ধারণ করতে হয়। একটি সাধারণ সোর্স কনফিগারেশনের উদাহরণ নিচে দেওয়া হল:

# এজেন্টের নাম নির্ধারণ
agent1.sources = source1
agent1.channels = channel1
agent1.sinks = sink1

# সোর্স কনফিগারেশন
agent1.sources.source1.type = spooldir
agent1.sources.source1.spoolDir = /var/logs

# চ্যানেল কনফিগারেশন
agent1.channels.channel1.type = memory
agent1.channels.channel1.capacity = 1000
agent1.channels.channel1.transactionCapacity = 100

# সিঙ্ক কনফিগারেশন
agent1.sinks.sink1.type = hdfs
agent1.sinks.sink1.hdfs.path = hdfs://namenode/flume/logs
agent1.sinks.sink1.hdfs.fileType = DataStream

# সোর্স, সিঙ্ক এবং চ্যানেলের মধ্যে সংযোগ স্থাপন
agent1.sources.source1.channels = channel1
agent1.sinks.sink1.channel = channel1

সোর্সের ইন্টারসেপ্টর (Interceptor)

ইন্টারসেপ্টর হল এমন একটি উপাদান যা সোর্স থেকে চ্যানেলে ডেটা প্রেরণের আগে ডেটা মডিফাই বা ফিল্টার করতে ব্যবহৃত হয়। এটি ডেটার মান উন্নত করতে বা অপ্রয়োজনীয় ডেটা বাদ দিতে সাহায্য করে।

  • উদাহরণ: ইভেন্টের টাইমস্ট্যাম্প যোগ করা বা নির্দিষ্ট প্যাটার্ন অনুযায়ী ডেটা ফিল্টার করা।
  • কনফিগারেশন উদাহরণ:

    agent.sources.source1.interceptors = i1
    agent.sources.source1.interceptors.i1.type = timestamp
    agent.sources.source1.interceptors.i1.preserveExisting = false
    

সোর্সের কার্যপ্রণালী (Source Workflow)

  1. ডেটা সংগ্রহ: সোর্স নির্দিষ্ট উৎস থেকে ডেটা সংগ্রহ করে।
  2. ইভেন্ট রূপান্তর: সংগ্রহ করা ডেটাকে ইভেন্টে রূপান্তরিত করে।
  3. ইন্টারসেপ্টর প্রক্রিয়া (যদি থাকে): ইভেন্টে প্রয়োজনীয় পরিবর্তন বা ফিল্টারিং করা হয়।
  4. চ্যানেলে প্রেরণ: ইভেন্টগুলোকে চ্যানেলে প্রেরণ করা হয়।
  5. সিঙ্কের মাধ্যমে ডেটা স্থানান্তর: চ্যানেল থেকে সিঙ্ক ইভেন্ট গ্রহণ করে এবং টার্গেট সিস্টেমে ডেটা পাঠায়।

সোর্সের সুবিধা এবং সীমাবদ্ধতা

সুবিধাসমূহ:

  • বিভিন্ন উৎস সমর্থন: ফ্লুম বিভিন্ন ধরনের ডেটা উৎস থেকে ডেটা সংগ্রহ করতে পারে।
  • রিলায়েবিলিটি: ফ্লুমের চ্যানেল ব্যবস্থাপনা ডেটা লস প্রতিরোধ করে।
  • কাস্টমাইজেশন: ব্যবহারকারীরা কাস্টম সোর্স তৈরি করতে পারে নির্দিষ্ট চাহিদা অনুযায়ী।

সীমাবদ্ধতাসমূহ:

  • কনফিগারেশন জটিলতা: জটিল সোর্স কনফিগারেশন পরিচালনা করা কিছু ক্ষেত্রে কঠিন হতে পারে।
  • পারফরম্যান্স: অত্যন্ত বড় ডেটা ভলিউমে পারফরম্যান্স সমস্যা হতে পারে যদি সঠিকভাবে টিউন না করা হয়।

সারাংশ

সোর্স (Source) হল অ্যাপাচি ফ্লুমের একটি মূল উপাদান যা বিভিন্ন ডেটা উৎস থেকে ডেটা সংগ্রহ করে। এটি ডেটাকে ইভেন্ট আকারে রূপান্তরিত করে এবং চ্যানেলের মাধ্যমে সিঙ্কে প্রেরণ করে। ফ্লুমের সোর্স বিভিন্ন ধরনের হতে পারে এবং এটি কনফিগারেশন এবং ইন্টারসেপ্টরের মাধ্যমে ডেটা মডিফিকেশন বা ফিল্টারিং করার ক্ষমতা রাখে। সোর্সের কার্যকরী ডিজাইন ফ্লুমকে বড় ডেটা ইকোসিস্টেমে একটি নির্ভরযোগ্য ডেটা ইনজেস্ট টুল হিসেবে প্রতিষ্ঠিত করেছে।

Content added By

অ্যাপাচি ফ্লুম (Apache Flume) একটি শক্তিশালী ডেটা ইনজেস্ট টুল যা বিশেষ করে লগ ডেটা সংগ্রহ এবং বিভিন্ন ডেটা স্টোরেজ সিস্টেমে প্রেরণের জন্য ব্যবহৃত হয়। ফ্লুমের সোর্স (Source) হলো সেই উপাদান যা ডেটা সংগ্রহের প্রক্রিয়ার শুরু বিন্দু হিসেবে কাজ করে। এই অংশটি ফ্লুমের ডেটা ফ্লোতে অত্যন্ত গুরুত্বপূর্ণ ভূমিকা পালন করে।


Flume Source এর সংজ্ঞা

সোর্স (Source) হলো ফ্লুমের প্রথম উপাদান যা বিভিন্ন ডেটা উত্স (Data Sources) থেকে ইনপুট গ্রহণ করে এবং তা ইভেন্ট (Event) হিসেবে রূপান্তরিত করে। সোর্স ফ্লুমের ডেটা ইনজেস্টেশনের প্রধান মাধ্যম হিসেবে কাজ করে, যা ডেটাকে চ্যানেলে পাঠানোর আগে প্রাথমিক প্রক্রিয়াকরণ সম্পন্ন করে।


Flume Source এর ধরন

ফ্লুম বিভিন্ন ধরনের সোর্স সমর্থন করে, যা বিভিন্ন ডেটা উত্স থেকে ডেটা সংগ্রহ করতে সক্ষম। প্রধান সোর্সের ধরন নিম্নরূপ:

  1. SpoolDir Source:
    • বিবরণ: নির্দিষ্ট ডিরেক্টরি (স্পুলডিরেক্টরি) থেকে ফাইল পড়ে ডেটা সংগ্রহ করে।
    • ব্যবহার: লগ ফাইল ম্যানেজমেন্ট যেখানে নতুন ফাইল যুক্ত হলে ফ্লুম তা পড়ে।
    • উদাহরণ:

      agent.sources.source1.type = spooldir
      agent.sources.source1.spoolDir = /var/logs
      
  2. Exec Source:
    • বিবরণ: একটি কমান্ড বা স্ক্রিপ্ট চালায় এবং এর আউটপুট থেকে ডেটা সংগ্রহ করে।
    • ব্যবহার: কাস্টম কমান্ড আউটপুট সংগ্রহের জন্য।
    • উদাহরণ:

      agent.sources.source1.type = exec
      agent.sources.source1.command = tail -F /var/log/syslog
      
  3. Netcat Source:
    • বিবরণ: নেটওয়ার্ক থেকে টেক্সট ডেটা গ্রহণ করে, সাধারণত TCP বা UDP প্রোটোকল ব্যবহার করে।
    • ব্যবহার: রিয়েল-টাইম ডেটা স্ট্রিমিং যেমন সার্ভার লগগুলি।
    • উদাহরণ:

      agent.sources.source1.type = netcat
      agent.sources.source1.bind = localhost
      agent.sources.source1.port = 44444
      
  4. Avro Source:
    • বিবরণ: Avro RPC প্রোটোকল ব্যবহার করে ডেটা গ্রহণ করে, যা ক্লায়েন্ট-সার্ভার মডেলে কাজ করে।
    • ব্যবহার: ডিস্ট্রিবিউটেড সিস্টেমে ডেটা সংগ্রহের জন্য।
    • উদাহরণ:

      agent.sources.source1.type = avro
      agent.sources.source1.bind = 0.0.0.0
      agent.sources.source1.port = 4141
      
  5. HTTP Source:
    • বিবরণ: HTTP প্রোটোকল ব্যবহার করে ডেটা গ্রহণ করে।
    • ব্যবহার: ওয়েব অ্যাপ্লিকেশন বা API থেকে ডেটা সংগ্রহের জন্য।
    • উদাহরণ:

      agent.sources.source1.type = http
      agent.sources.source1.port = 8080
      
  6. Syslog Source:
    • বিবরণ: Syslog প্রোটোকল ব্যবহার করে লগ ডেটা সংগ্রহ করে।
    • ব্যবহার: সিস্টেম এবং নেটওয়ার্ক ডিভাইস থেকে লগ সংগ্রহের জন্য।
    • উদাহরণ:

      agent.sources.source1.type = syslogtcp
      agent.sources.source1.port = 514
      

Flume Source কিভাবে কাজ করে

সোর্সের কাজের প্রক্রিয়া নিম্নরূপ:

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

Flume Source এর কনফিগারেশন উদাহরণ

নিচে SpoolDir সোর্সের একটি সাধারণ কনফিগারেশন উদাহরণ দেয়া হল:

# এজেন্টের নাম নির্ধারণ
agent1.sources = source1
agent1.channels = channel1
agent1.sinks = sink1

# সোর্স কনফিগারেশন
agent1.sources.source1.type = spooldir
agent1.sources.source1.spoolDir = /var/logs

# চ্যানেল কনফিগারেশন
agent1.channels.channel1.type = memory
agent1.channels.channel1.capacity = 1000

# সোর্স এবং সিঙ্ককে চ্যানেলে সংযুক্ত করা
agent1.sources.source1.channels = channel1
agent1.sinks.sink1.channel = channel1

# সিঙ্ক কনফিগারেশন
agent1.sinks.sink1.type = hdfs
agent1.sinks.sink1.hdfs.path = hdfs://namenode/flume/logs
agent1.sinks.sink1.hdfs.fileType = DataStream

এই কনফিগারেশনে:

  • SpoolDir সোর্স /var/logs ডিরেক্টরি থেকে ফাইল পড়বে।
  • ডেটা মেমরি চ্যানেল channel1 এ সংরক্ষিত হবে।
  • সিঙ্ক HDFS তে ডেটা প্রেরণ করবে।

Flume Source এর ব্যবহারিক উদাহরণ

  1. লগ ফাইল থেকে ডেটা সংগ্রহ:
    • Scenario: ওয়েব সার্ভারের লগ ফাইলগুলি সংগ্রহ করে HDFS এ সংরক্ষণ।
    • সোর্স: SpoolDir সোর্স /var/log/httpd/ ডিরেক্টরি থেকে ফাইল পড়বে।
    • উদাহরণ:

      agent1.sources.source1.type = spooldir
      agent1.sources.source1.spoolDir = /var/log/httpd/
      
  2. রিয়েল-টাইম লগ স্ট্রিমিং:
    • Scenario: রিয়েল-টাইমে লগ ডেটা সংগ্রহ করে Kafka তে পাঠানো।
    • সোর্স: Netcat সোর্স TCP পোর্ট 44444 থেকে ডেটা গ্রহণ করবে।
    • উদাহরণ:

      agent1.sources.source1.type = netcat
      agent1.sources.source1.bind = localhost
      agent1.sources.source1.port = 44444
      
  3. HTTP API থেকে ডেটা সংগ্রহ:
    • Scenario: ওয়েব অ্যাপ্লিকেশন থেকে HTTP POST রিকোয়েস্টের মাধ্যমে ডেটা গ্রহণ।
    • সোর্স: HTTP সোর্স পোর্ট 8080 এ ডেটা গ্রহণ করবে।
    • উদাহরণ:

      agent1.sources.source1.type = http
      agent1.sources.source1.port = 8080
      

সারাংশ

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

Content added By

অ্যাপাচি ফ্লুম (Apache Flume) একটি শক্তিশালী ডেটা ইনজেস্ট টুল যা বিভিন্ন উৎস থেকে ডেটা সংগ্রহ এবং প্রেরণের জন্য বিভিন্ন ধরনের সোর্স (Source) সমর্থন করে। এই অংশে আমরা ExecSource, AvroSource, এবং SyslogSource সম্পর্কে বিস্তারিতভাবে আলোচনা করবো।


১. ExecSource

ExecSource ফ্লুমের একটি সোর্স যা কমান্ড বা স্ক্রিপ্টের আউটপুট থেকে ডেটা সংগ্রহ করে। এটি সাধারণত লগ ফাইল বা কমান্ড লাইন আউটপুট থেকে রিয়েল-টাইম ডেটা সংগ্রহের জন্য ব্যবহৃত হয়।

ExecSource-এর বৈশিষ্ট্য

  • কমান্ড রানের আউটপুট সংগ্রহ: নির্দিষ্ট কমান্ড বা স্ক্রিপ্ট চালিয়ে তার আউটপুট সংগ্রহ করে।
  • রিয়েল-টাইম ডেটা ইনজেস্ট: লাইভ ডেটা সংগ্রহের জন্য উপযুক্ত।
  • সরল কনফিগারেশন: সহজে কনফিগার করা যায়।

ExecSource কনফিগারেশন উদাহরণ

নিচের উদাহরণে, ExecSource ব্যবহার করে একটি কমান্ড চালানো হয়েছে যা সার্ভারের বর্তমান সময় দেখাবে এবং তা ফ্লুমের মাধ্যমে ইনজেস্ট করা হবে।

# এজেন্টের সোর্স, চ্যানেল এবং সিঙ্ক নির্ধারণ
agent1.sources = execSource
agent1.channels = memoryChannel
agent1.sinks = sink1

# ExecSource কনফিগারেশন
agent1.sources.execSource.type = exec
agent1.sources.execSource.command = /bin/date
agent1.sources.execSource.restart = true
agent1.sources.execSource.restartThrottle = 10000

# চ্যানেল কনফিগারেশন
agent1.channels.memoryChannel.type = memory
agent1.channels.memoryChannel.capacity = 1000
agent1.channels.memoryChannel.transactionCapacity = 100

# সিঙ্ক কনফিগারেশন
agent1.sinks.sink1.type = logger
agent1.sinks.sink1.channel = memoryChannel

# সোর্স এবং সিঙ্ককে চ্যানেলের সাথে সংযুক্ত করা
agent1.sources.execSource.channels = memoryChannel

ব্যবহার ক্ষেত্র

  • সার্ভারের রিসোর্স মনিটরিং ডেটা সংগ্রহ।
  • কাস্টম স্ক্রিপ্টের আউটপুট ইনজেস্ট।
  • রিয়েল-টাইম লগ ডেটা সংগ্রহ।

২. AvroSource

AvroSource একটি অত্যন্ত নমনীয় এবং স্কেলেবল সোর্স যা Avro RPC (Remote Procedure Call) প্রোটোকল ব্যবহার করে ডেটা গ্রহণ করে। এটি মূলত ডিস্ট্রিবিউটেড সিস্টেমগুলির মধ্যে ডেটা বিনিময়ের জন্য ব্যবহৃত হয়।

AvroSource-এর বৈশিষ্ট্য

  • RPC ভিত্তিক ডেটা ট্রান্সফার: ক্লায়েন্ট-সার্ভার মডেলে কাজ করে।
  • স্কেলেবিলিটি: উচ্চ পরিমাণের ডেটা ইনজেস্ট করতে সক্ষম।
  • রিলায়েবিলিটি: ডেটার নিরাপদ ট্রান্সফার নিশ্চিত করে।
  • ইন্টিগ্রেশন ক্ষমতা: বিভিন্ন ভাষায় লেখা ক্লায়েন্টদের সাথে সহজে সংযোগ স্থাপন করতে পারে।

AvroSource কনফিগারেশন উদাহরণ

নিচের উদাহরণে, AvroSource ব্যবহার করে একটি সার্ভিস চালু করা হয়েছে যা নির্দিষ্ট পোর্টে ডেটা গ্রহণ করবে।

# এজেন্টের সোর্স, চ্যানেল এবং সিঙ্ক নির্ধারণ
agent1.sources = avroSource
agent1.channels = memoryChannel
agent1.sinks = sink1

# AvroSource কনফিগারেশন
agent1.sources.avroSource.type = avro
agent1.sources.avroSource.bind = localhost
agent1.sources.avroSource.port = 4141

# চ্যানেল কনফিগারেশন
agent1.channels.memoryChannel.type = memory
agent1.channels.memoryChannel.capacity = 1000
agent1.channels.memoryChannel.transactionCapacity = 100

# সিঙ্ক কনফিগারেশন
agent1.sinks.sink1.type = hdfs
agent1.sinks.sink1.hdfs.path = hdfs://namenode/flume/avro
agent1.sinks.sink1.hdfs.fileType = DataStream

# সোর্স এবং সিঙ্ককে চ্যানেলের সাথে সংযুক্ত করা
agent1.sources.avroSource.channels = memoryChannel
agent1.sinks.sink1.channel = memoryChannel

ব্যবহার ক্ষেত্র

  • বিভিন্ন সার্ভার বা অ্যাপ্লিকেশন থেকে কেন্দ্রীয় ডেটা সংগ্রহ।
  • ডিস্ট্রিবিউটেড সিস্টেমের মধ্যে রিয়েল-টাইম ডেটা ট্রান্সফার।
  • মাইক্রোসার্ভিস আর্কিটেকচারে ডেটা বিনিময়।

৩. SyslogSource

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

SyslogSource-এর বৈশিষ্ট্য

  • স্ট্যান্ডার্ড লোগিং প্রোটোকল: Syslog প্রোটোকল ব্যবহার করে ডেটা গ্রহণ।
  • নেটওয়ার্কের মাধ্যমে ডেটা সংগ্রহ: বিভিন্ন নেটওয়ার্ক ডিভাইস থেকে লোগ সংগ্রহ।
  • রিয়েল-টাইম ডেটা ইনজেস্ট: তাত্ক্ষণিক লোগ ডেটা সংগ্রহ ও প্রেরণ।
  • রিলায়েবিলিটি: সিস্টেম লোগ ডেটার নিরাপদ ট্রান্সফার নিশ্চিত করে।

SyslogSource কনফিগারেশন উদাহরণ

নিচের উদাহরণে, SyslogSource ব্যবহার করে একটি সোর্স কনফিগার করা হয়েছে যা নির্দিষ্ট পোর্টে Syslog মেসেজ গ্রহণ করবে।

# এজেন্টের সোর্স, চ্যানেল এবং সিঙ্ক নির্ধারণ
agent1.sources = syslogSource
agent1.channels = memoryChannel
agent1.sinks = sink1

# SyslogSource কনফিগারেশন
agent1.sources.syslogSource.type = syslog
agent1.sources.syslogSource.bind = 0.0.0.0
agent1.sources.syslogSource.port = 514

# চ্যানেল কনফিগারেশন
agent1.channels.memoryChannel.type = memory
agent1.channels.memoryChannel.capacity = 1000
agent1.channels.memoryChannel.transactionCapacity = 100

# সিঙ্ক কনফিগারেশন
agent1.sinks.sink1.type = hdfs
agent1.sinks.sink1.hdfs.path = hdfs://namenode/flume/syslog
agent1.sinks.sink1.hdfs.fileType = DataStream

# সোর্স এবং সিঙ্ককে চ্যানেলের সাথে সংযুক্ত করা
agent1.sources.syslogSource.channels = memoryChannel
agent1.sinks.sink1.channel = memoryChannel

ব্যবহার ক্ষেত্র

  • নেটওয়ার্ক ডিভাইস (যেমন রাউটার, সুইচ) থেকে সিস্টেম লোগ সংগ্রহ।
  • সার্ভার এবং অ্যাপ্লিকেশন লোগ ডেটা কেন্দ্রীয়ভাবে সংগ্রহ।
  • সিকিউরিটি এবং মনিটরিং টুলসের সাথে ইন্টিগ্রেশন।

সারাংশ

ExecSource, AvroSource, এবং SyslogSource ফ্লুমের বিভিন্ন সোর্সের উদাহরণ যা বিভিন্ন ধরনের ডেটা উৎস থেকে ডেটা সংগ্রহ এবং ইনজেস্ট করার জন্য ব্যবহৃত হয়। প্রতিটি সোর্সের নিজস্ব বৈশিষ্ট্য এবং কনফিগারেশন পদ্ধতি রয়েছে, যা ফ্লুমকে বিভিন্ন ডেটা পরিবেশে নমনীয়তা এবং কার্যকারিতা প্রদান করে। সঠিক সোর্স নির্বাচন করে ফ্লুমকে আপনার ডেটা ইনজেস্টেশন প্রয়োজনীয়তাগুলো পূরণে আরও কার্যকরীভাবে ব্যবহার করতে পারবেন।


আরও জানার জন্য

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

Content added By

অ্যাপাচি ফ্লুম (Apache Flume) এর মডুলার আর্কিটেকচার এবং উচ্চ কাস্টমাইজযোগ্যতার কারণে, ব্যবহারকারীরা প্রয়োজন অনুযায়ী কাস্টম সোর্স তৈরি করতে পারেন। কাস্টম সোর্স তৈরি করার মাধ্যমে আপনি Flume-কে আপনার নির্দিষ্ট ডেটা উৎস থেকে ডেটা সংগ্রহ করতে সক্ষম করে তুলতে পারেন যা Flume-এর ডিফল্ট সোর্স দ্বারা সরাসরি সমর্থিত নয়।

কাস্টম সোর্স কেন তৈরি করবেন?

  • নির্দিষ্ট ডেটা উৎস: যদি আপনার ডেটা উৎস Flume-এর ডিফল্ট সোর্সগুলিতে অন্তর্ভুক্ত না থাকে, যেমন একটি বিশেষ API বা ডেটাবেস।
  • কাস্টম ডেটা প্রক্রিয়াকরণ: ডেটা সংগ্রহের আগে বা পরে বিশেষ ধরনের প্রক্রিয়াকরণ বা ফিল্টারিং করতে।
  • উন্নত কন্ট্রোল: ডেটা সংগ্রহের উপর আরও নিয়ন্ত্রণ বা বিশেষ ফিচার যোগ করতে।

কাস্টম সোর্স তৈরি করার ধাপসমূহ

১. পরিবেশ প্রস্তুতি

কাস্টম সোর্স তৈরি করার জন্য আপনাকে Java প্রোগ্রামিং ভাষা এবং Flume-এর সোর্স ইন্টারফেস সম্পর্কে ধারণা থাকতে হবে। এছাড়াও, Maven বা Gradle ব্যবহার করে প্রোজেক্ট ম্যানেজমেন্ট করতে পারেন।

২. সোর্স ক্লাস তৈরি করা

Flume-এর সোর্স তৈরি করতে আপনাকে org.apache.flume.Source ইন্টারফেস ইমপ্লিমেন্ট করতে হবে এবং org.apache.flume.EventDrivenSource এবং org.apache.flume.Source এর অন্যান্য ইন্টারফেসসমূহ বাস্তবায়ন করতে হবে। সাধারণত, AbstractSource এবং Configurable ক্লাসগুলি এক্সটেন্ড করা হয়।

উদাহরণ: একটি কাস্টম সোর্স ক্লাস

package com.example.flume.source;

import org.apache.flume.*;
import org.apache.flume.conf.Configurable;
import org.apache.flume.source.AbstractSource;

public class CustomSource extends AbstractSource implements Configurable, EventDrivenSource {

    private String parameter;

    @Override
    public void configure(Context context) {
        // Flume কনফিগারেশন থেকে প্যারামিটার নেওয়া
        parameter = context.getString("custom.parameter", "default");
    }

    @Override
    public void start() {
        // সোর্স শুরু করার পূর্বে প্রয়োজনীয় সেটআপ
        super.start();
        // আপনার ডেটা সংগ্রহের লজিক এখানে যুক্ত করুন
    }

    @Override
    public void stop() {
        // সোর্স বন্ধ করার পূর্বে প্রয়োজনীয় ক্লিনআপ
        super.stop();
        // আপনার ক্লিনআপ লজিক এখানে যুক্ত করুন
    }

    // ডেটা সংগ্রহের মেথড
    private void collectData() {
        // উদাহরণ স্বরূপ, একটি ইভেন্ট তৈরি করা
        Event event = EventBuilder.withBody("Sample Data".getBytes());

        // ইভেন্ট Flume চ্যানেলে পাঠানো
        getChannelProcessor().processEvent(event);
    }
}

৩. সোর্স কনফিগারেশন ফাইল তৈরি করা

আপনার কাস্টম সোর্সকে Flume কনফিগারেশনে যুক্ত করতে আপনাকে flume-ng এর কনফিগারেশন ফাইলে সোর্সের ধরন এবং ক্লাসের নাম উল্লেখ করতে হবে।

উদাহরণ: Flume কনফিগারেশন (flume.conf)

# এজেন্টের নাম নির্ধারণ
agent1.sources = customSource
agent1.channels = memoryChannel
agent1.sinks = hdfsSink

# কাস্টম সোর্স কনফিগারেশন
agent1.sources.customSource.type = com.example.flume.source.CustomSource
agent1.sources.customSource.custom.parameter = customValue

# চ্যানেল কনফিগারেশন
agent1.channels.memoryChannel.type = memory
agent1.channels.memoryChannel.capacity = 1000
agent1.channels.memoryChannel.transactionCapacity = 100

# সোর্স এবং সিঙ্ককে চ্যানেলে বেঁধে দেওয়া
agent1.sources.customSource.channels = memoryChannel

# সিঙ্ক কনফিগারেশন
agent1.sinks.hdfsSink.type = hdfs
agent1.sinks.hdfsSink.hdfs.path = hdfs://namenode/flume/logs
agent1.sinks.hdfsSink.hdfs.fileType = DataStream

# সিঙ্ক এবং চ্যানেলকে সংযুক্ত করা
agent1.sinks.hdfsSink.channel = memoryChannel

৪. সোর্স প্যাকেজিং এবং ডিপ্লয়মেন্ট

আপনার কাস্টম সোর্স ক্লাসটি কম্পাইল করে একটি জার ফাইলে প্যাকেজ করুন এবং Flume-এর lib ডিরেক্টরিতে কপি করুন।

Maven উদাহরণ: pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" 
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 
         http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.example.flume</groupId>
    <artifactId>custom-flume-source</artifactId>
    <version>1.0-SNAPSHOT</version>
    <dependencies>
        <dependency>
            <groupId>org.apache.flume</groupId>
            <artifactId>flume-ng-core</artifactId>
            <version>1.9.0</version>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <!-- Maven Shade Plugin for creating uber-jar -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-shade-plugin</artifactId>
                <version>3.2.4</version>
                <executions>
                    <execution>
                        <phase>package</phase>
                        <goals>
                            <goal>shade</goal>
                        </goals>
                        <configuration>
                            <transformers>
                                <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                                    <mainClass>com.example.flume.source.CustomSource</mainClass>
                                </transformer>
                            </transformers>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
</project>

বিল্ড এবং জার তৈরি করা:

mvn clean package

উৎপন্ন জার ফাইলটি Flume-এর lib ডিরেক্টরিতে কপি করুন।

cp target/custom-flume-source-1.0-SNAPSHOT.jar /path/to/flume/lib/

৫. Flume এজেন্ট চালানো

Flume কনফিগারেশন ফাইলের মাধ্যমে আপনার কাস্টম সোর্স সহ এজেন্ট চালু করুন।

flume-ng agent --conf /path/to/flume/conf --conf-file /path/to/flume.conf --name agent1 -Dflume.root.logger=INFO,console

কাস্টম সোর্সের উন্নয়ন এবং টেস্টিং

১. উন্নয়নকালীন টেস্টিং

কাস্টম সোর্সের কোড লিখার সময় ইউনিট টেস্ট ব্যবহার করে নিশ্চিত করুন যে আপনার সোর্স সঠিকভাবে ইভেন্ট তৈরি করছে এবং চ্যানেলে পাঠাচ্ছে। JUnit বা TestNG ব্যবহার করতে পারেন।

২. ইন্টিগ্রেশন টেস্টিং

Flume এজেন্টে আপনার কাস্টম সোর্স সংযুক্ত করে ইন্টিগ্রেশন টেস্ট চালান। নিশ্চিত করুন যে ডেটা সোর্স থেকে সঠিকভাবে সংগ্রহ হচ্ছে এবং টার্গেট সিস্টেমে পৌঁছাচ্ছে।

কাস্টম সোর্সের সাধারণ সমস্যাসমূহ এবং সমাধান

  • কনফিগারেশন ত্রুটি: কনফিগারেশন ফাইলটি সঠিকভাবে সেটআপ করা হয়েছে কিনা পরীক্ষা করুন। সোর্স টাইপ এবং ক্লাসের নাম সঠিক কিনা নিশ্চিত করুন।
  • ডিপেন্ডেন্সি সমস্যা: সকল প্রয়োজনীয় ডিপেন্ডেন্সি সঠিকভাবে জার ফাইলে অন্তর্ভুক্ত করা হয়েছে কিনা পরীক্ষা করুন।
  • পারমিশন ইস্যু: ডেটা সোর্স এবং টার্গেট সিস্টেমের সাথে সংযোগ করার জন্য প্রয়োজনীয় পারমিশন আছে কিনা নিশ্চিত করুন।
  • লগিং: Flume-এর লগ ফাইল চেক করে কোন ত্রুটি বা সমস্যা সম্পর্কে বিস্তারিত তথ্য সংগ্রহ করুন।

সারাংশ

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

রিসোর্সসমূহ

আপনি যদি আরও বিস্তারিত বা নির্দিষ্ট কোনো উদাহরণ প্রয়োজন মনে করেন, তবে দয়া করে জানাবেন!

Content added By

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


ফ্লুম সোর্স (Flume Source) কী?

সোর্স (Source) হল ফ্লুমের সেই উপাদান যা বিভিন্ন ডেটা উৎস থেকে ডেটা সংগ্রহ করে এবং ফ্লুমের ইভেন্ট হিসেবে রূপান্তরিত করে। সোর্স ডেটা ইনজেস্টেশনের প্রথম ধাপ এবং এটি ফ্লুমের সাথে যোগাযোগ স্থাপন করে ডেটা গ্রহণ করে।


ফ্লুম সোর্সের ধরন

ফ্লুম বিভিন্ন ধরনের সোর্স প্রদান করে যা বিভিন্ন উৎস থেকে ডেটা সংগ্রহ করতে সক্ষম। প্রধানত নিম্নলিখিত সোর্সগুলো ব্যবহৃত হয়:

  1. ExecSource
  2. AvroSource
  3. SyslogSource
  4. SpoolDirSource
  5. NetcatSource
  6. JMSSource

এই বিভাগে আমরা ExecSource, AvroSource এবং SyslogSource সম্পর্কে বিস্তারিত জানব।


১. ExecSource

ExecSource একটি কমান্ড বা স্ক্রিপ্টের আউটপুট থেকে ডেটা সংগ্রহ করে। এটি সাধারণত এমন ক্ষেত্রে ব্যবহৃত হয় যেখানে ডেটা জেনারেটর কোন নির্দিষ্ট কমান্ডের আউটপুট হিসেবে থাকে, যেমন tail -f কমান্ডের মাধ্যমে লগ ফাইল মনিটর করা।

ExecSource এর বৈশিষ্ট্য

  • ফাংশনালিটি: নির্দিষ্ট কমান্ড বা স্ক্রিপ্টের আউটপুট পড়ে ডেটা সংগ্রহ করে।
  • ব্যবহার ক্ষেত্র: লগ ফাইল মনিটর করা, কমান্ড আউটপুট সংগ্রহ করা ইত্যাদি।
  • সীমাবদ্ধতা: কমান্ডের আউটপুট নির্ভর করে ডেটা সংগ্রহের স্থায়িত্ব।

ExecSource কনফিগারেশন উদাহরণ

# এজেন্টের সোর্স নির্ধারণ
agent.sources = execSource

# সোর্সের ধরন নির্ধারণ
agent.sources.execSource.type = exec

# কমান্ড নির্ধারণ (উদাহরণস্বরূপ, লগ ফাইল মনিটর করার জন্য tail কমান্ড)
agent.sources.execSource.command = tail -F /var/log/syslog

# সোর্সকে চ্যানেলের সাথে সংযুক্ত করা
agent.sources.execSource.channels = memoryChannel

২. AvroSource

AvroSource একটি ক্লায়েন্ট-সার্ভার মডেলে কাজ করে যেখানে সোর্স একটি সার্ভার হিসেবে কাজ করে এবং ক্লায়েন্ট থেকে ডেটা গ্রহণ করে। এটি সাধারণত ডিস্ট্রিবিউটেড সিস্টেমে ডেটা সংগ্রহের জন্য ব্যবহৃত হয়।

AvroSource এর বৈশিষ্ট্য

  • ফাংশনালিটি: Avro RPC ব্যবহার করে ডেটা গ্রহণ করে।
  • ব্যবহার ক্ষেত্র: ডিস্ট্রিবিউটেড ডেটা সংগ্রহ, বিভিন্ন সার্ভার থেকে ডেটা ইনজেস্ট করা।
  • সুবিধা: উচ্চ কার্যকারিতা এবং স্কেলেবিলিটি।

AvroSource কনফিগারেশন উদাহরণ

# এজেন্টের সোর্স নির্ধারণ
agent.sources = avroSource

# সোর্সের ধরন নির্ধারণ
agent.sources.avroSource.type = avro

# হোস্ট এবং পোর্ট নির্ধারণ (ডেটা গ্রহণের জন্য)
agent.sources.avroSource.bind = 0.0.0.0
agent.sources.avroSource.port = 4141

# সোর্সকে চ্যানেলের সাথে সংযুক্ত করা
agent.sources.avroSource.channels = memoryChannel

৩. SyslogSource

SyslogSource সিস্টেম লগ (Syslog) প্রোটোকল ব্যবহার করে ডেটা সংগ্রহ করে। এটি নেটওয়ার্ক ডিভাইস, সার্ভার এবং অন্যান্য সিস্টেম থেকে রিয়েল-টাইমে লগ ডেটা সংগ্রহের জন্য ব্যবহৃত হয়।

SyslogSource এর বৈশিষ্ট্য

  • ফাংশনালিটি: Syslog প্রোটোকল ব্যবহার করে ডেটা গ্রহণ করে।
  • ব্যবহার ক্ষেত্র: নেটওয়ার্ক ডিভাইস, সার্ভার লগ, রিয়েল-টাইম লগ মনিটরিং।
  • সুবিধা: স্ট্যান্ডার্ড প্রোটোকল ব্যবহার, সহজ ইন্টিগ্রেশন।

SyslogSource কনফিগারেশন উদাহরণ

# এজেন্টের সোর্স নির্ধারণ
agent.sources = syslogSource

# সোর্সের ধরন নির্ধারণ
agent.sources.syslogSource.type = syslog

# হোস্ট এবং পোর্ট নির্ধারণ (ডেটা গ্রহণের জন্য)
agent.sources.syslogSource.bind = 0.0.0.0
agent.sources.syslogSource.port = 514

# সোর্সকে চ্যানেলের সাথে সংযুক্ত করা
agent.sources.syslogSource.channels = memoryChannel

অন্যান্য সোর্সের সংক্ষিপ্ত বিবরণ

SpoolDirSource

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

NetcatSource

NetcatSource নেটওয়ার্কের মাধ্যমে TCP বা UDP প্রোটোকল ব্যবহার করে ডেটা গ্রহণ করে। এটি সাধারণত টেস্টিং এবং সহজ ডেটা ট্রান্সমিশনের জন্য ব্যবহৃত হয়।

JMSSource

JMSSource জাভা ম্যাসেজ সিস্টেম (JMS) থেকে ডেটা সংগ্রহ করে। এটি এন্টারপ্রাইজ লেভেলের অ্যাপ্লিকেশনে ব্যবহৃত হয় যেখানে JMS ব্রোকার ব্যবহার করা হয়।


ফ্লুম সোর্সের মাধ্যমে ডেটা সংগ্রহের প্রক্রিয়া

ফ্লুম সোর্সের মাধ্যমে ডেটা সংগ্রহের প্রক্রিয়া নিম্নরূপ:

  1. ডেটা উৎস থেকে ডেটা সংগ্রহ: সোর্স নির্দিষ্ট প্রোটোকল বা মেথড ব্যবহার করে ডেটা গ্রহণ করে।
  2. ইভেন্ট তৈরি: সংগ্রহকৃত ডেটাকে ফ্লুমের ইভেন্ট হিসেবে রূপান্তরিত করে।
  3. চ্যানেলে ডেটা স্থানান্তর: ইভেন্টগুলো চ্যানেলে পাঠানো হয়, যেখানে তা সাময়িকভাবে সংরক্ষিত থাকে।
  4. সিঙ্কের মাধ্যমে ডেটা প্রেরণ: চ্যানেল থেকে ডেটা সিঙ্কে প্রেরণ করা হয়, যা চূড়ান্ত গন্তব্যস্থল।

ফ্লুম সোর্সের ব্যবহারিক উদাহরণ

উদাহরণ ১: ExecSource দিয়ে লগ ফাইল মনিটর করা

# এজেন্টের সোর্স নির্ধারণ
agent.sources = execSource

# সোর্সের ধরন নির্ধারণ
agent.sources.execSource.type = exec

# লগ ফাইল মনিটর করার জন্য কমান্ড নির্ধারণ
agent.sources.execSource.command = tail -F /var/log/application.log

# সোর্সকে চ্যানেলের সাথে সংযুক্ত করা
agent.sources.execSource.channels = memoryChannel

উদাহরণ ২: AvroSource দিয়ে ডিস্ট্রিবিউটেড ডেটা সংগ্রহ

# এজেন্টের সোর্স নির্ধারণ
agent.sources = avroSource

# সোর্সের ধরন নির্ধারণ
agent.sources.avroSource.type = avro

# হোস্ট এবং পোর্ট নির্ধারণ
agent.sources.avroSource.bind = 0.0.0.0
agent.sources.avroSource.port = 4141

# সোর্সকে চ্যানেলের সাথে সংযুক্ত করা
agent.sources.avroSource.channels = memoryChannel

উদাহরণ ৩: SyslogSource দিয়ে রিয়েল-টাইম লগ সংগ্রহ

# এজেন্টের সোর্স নির্ধারণ
agent.sources = syslogSource

# সোর্সের ধরন নির্ধারণ
agent.sources.syslogSource.type = syslog

# হোস্ট এবং পোর্ট নির্ধারণ
agent.sources.syslogSource.bind = 0.0.0.0
agent.sources.syslogSource.port = 514

# সোর্সকে চ্যানেলের সাথে সংযুক্ত করা
agent.sources.syslogSource.channels = memoryChannel

সারাংশ

অ্যাপাচি ফ্লুমের সোর্স (Source) উপাদান ডেটা ইনজেস্টেশনের প্রথম ধাপ হিসেবে অত্যন্ত গুরুত্বপূর্ণ। বিভিন্ন ধরনের সোর্স যেমন ExecSource, AvroSource, এবং SyslogSource বিভিন্ন ডেটা উৎস থেকে কার্যকরভাবে ডেটা সংগ্রহ করতে সক্ষম। ফ্লুমের মডুলার ডিজাইন এবং কনফিগারেবিলিটি ফ্লুমকে বিভিন্ন ডেটা পরিবেশে ব্যবহারযোগ্য করে তোলে। সঠিক সোর্স নির্বাচন এবং কনফিগারেশনের মাধ্যমে, ফ্লুম বড় এবং জটিল ডেটা ইনজেস্টেশন প্রয়োজনীয়তাগুলো পূরণে সক্ষম।

Content added By
Promotion

Are you sure to start over?

Loading...