Apache Flink এ DataStream API এবং DataSet API হল দুটি গুরুত্বপূর্ণ API যা বড় ডেটা প্রক্রিয়াকরণের জন্য ব্যবহৃত হয়। এই API গুলো ডেটা প্রসেসিংয়ের জন্য বিভিন্ন ধরনের অপারেশন এবং কার্যকারিতা প্রদান করে। চলুন, এই দুই API এর ধারণা এবং তাদের ব্যবহারের বিস্তারিত আলোচনা করি।
DataStream API হল Flink এর স্ট্রিমিং ডেটা প্রক্রিয়াকরণের জন্য ডিজাইন করা API। এটি একটি রিয়েল-টাইম ডেটা প্রবাহ পরিচালনার জন্য ব্যবহৃত হয় এবং অসীম ডেটা স্ট্রিমের সাথে কাজ করতে সক্ষম।
import org.apache.flink.api.common.functions.MapFunction;
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
import org.apache.flink.streaming.api.datastream.DataStream;
public class DataStreamExample {
public static void main(String[] args) throws Exception {
final StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
DataStream<String> inputStream = env.socketTextStream("localhost", 9999); // Socket Stream Source
DataStream<String> processedStream = inputStream
.map(new MapFunction<String, String>() {
@Override
public String map(String value) {
return "Processed: " + value;
}
});
processedStream.print(); // Print the processed stream
env.execute("DataStream Example");
}
}
DataSet API হল Flink এর ব্যাচ ডেটা প্রক্রিয়াকরণের জন্য ডিজাইন করা API। এটি সীমিত (finite) ডেটা সেটের সাথে কাজ করে এবং কার্যকরভাবে ব্যাচ অপারেশন পরিচালনা করতে সক্ষম।
import org.apache.flink.api.java.ExecutionEnvironment;
import org.apache.flink.api.java.DataSet;
public class DataSetExample {
public static void main(String[] args) throws Exception {
final ExecutionEnvironment env = ExecutionEnvironment.getExecutionEnvironment();
DataSet<String> inputDataSet = env.fromElements("Flink", "Spark", "Hadoop"); // Sample DataSet
DataSet<String> processedDataSet = inputDataSet
.map(value -> "Processed: " + value);
processedDataSet.print(); // Print the processed DataSet
env.execute("DataSet Example");
}
}
Feature | DataStream API | DataSet API |
---|---|---|
Data Type | Unbounded (Infinite) Streams | Bounded (Finite) Datasets |
Processing Type | Real-time (Stream Processing) | Batch Processing |
Use Case | Streaming Analytics, Real-time ETL | Batch Data Analysis, ETL |
State Management | Supports Stateful Processing | Stateless by default |
Processing Guarantees | Exactly-once / At-least-once | Exactly-once |
Apache Flink এর DataStream API এবং DataSet API ডেটা প্রক্রিয়াকরণের জন্য অত্যন্ত কার্যকরী এবং শক্তিশালী টুল। DataStream API রিয়েল-টাইম ডেটা স্ট্রিম প্রক্রিয়াকরণের জন্য ডিজাইন করা হয়েছে, যেখানে DataSet API ব্যাচ ডেটা প্রক্রিয়াকরণের জন্য ব্যবহৃত হয়। এই API গুলো ব্যবহার করে আপনি বিভিন্ন ধরনের ডেটা প্রবাহ এবং বিশ্লেষণ কার্যক্রম পরিচালনা করতে পারবেন, যা বৃহৎ ডেটা সেটের সাথে কাজ করার সময় অত্যন্ত সহায়ক।
Read more