अपाचे काफ्का - सरल निर्माता उदाहरण
जावा क्लाइंट का उपयोग करके संदेशों को प्रकाशित करने और उपभोग करने के लिए एक एप्लिकेशन बनाएं। कफका उत्पादक ग्राहक में निम्नलिखित एपीआई के होते हैं।
काफ्काप्रोड्यूसर एपीआई
आइए इस खंड में काफ्का निर्माता एपीआई के सबसे महत्वपूर्ण सेट को समझते हैं। काफ्काप्रोड्यूसर एपीआई का मध्य भाग काफ्काप्रोड्यूसर
वर्ग है। KafkaProducer वर्ग निम्न विधियों के साथ अपने निर्माता में एक Kafka दलाल को जोड़ने का विकल्प प्रदान करता है।
KafkaProducer वर्ग संदेश भेजने के लिए एक विषय के लिए अतुल्यकालिक भेजने की विधि प्रदान करता है। भेजें () का हस्ताक्षर इस प्रकार है
producer.send(new ProducerRecord<byte[],byte[]>(topic,
partition, key1, value1) , callback);
ProducerRecord - निर्माता भेजे जाने के लिए रिकॉर्ड के एक बफर का प्रबंधन करता है।
Callback सर्वर द्वारा रिकॉर्ड को स्वीकार किए जाने पर निष्पादित करने के लिए उपयोगकर्ता द्वारा आपूर्ति की जाने वाली कॉलबैक (शून्य कोई कॉलबैक इंगित करता है)।
KafkaProducer वर्ग वास्तव में पूरा हो गया है पहले से भेजे गए संदेशों को सुनिश्चित करने के लिए एक फ्लश विधि प्रदान करता है। फ्लश विधि का सिंटैक्स इस प्रकार है -
public void flush()
KafkaProducer वर्ग पार्टीशन विधि प्रदान करता है, जो किसी दिए गए विषय के लिए विभाजन मेटाडेटा प्राप्त करने में मदद करता है। यह कस्टम विभाजन के लिए उपयोग किया जा सकता है। इस विधि का हस्ताक्षर इस प्रकार है -
public Map metrics()
यह निर्माता द्वारा बनाए गए आंतरिक मैट्रिक्स का नक्शा लौटाता है।
सार्वजनिक शून्य पास () - KafkaProducer वर्ग सभी पहले भेजे गए अनुरोधों को पूरा होने तक करीब विधि ब्लॉक प्रदान करता है।
निर्माता एपीआई
निर्माता एपीआई का मध्य भाग निर्माता
वर्ग है। निर्माता वर्ग निम्नलिखित तरीकों से अपने कंस्ट्रक्टर में काफ्का दलाल को जोड़ने का विकल्प प्रदान करता है।
निर्माता वर्ग
निर्माता वर्ग को भेजने की विधि प्रदान करता है send निम्नलिखित हस्ताक्षर का उपयोग करके या तो एकल या कई विषयों के लिए संदेश।
public void send(KeyedMessaget<k,v> message)
- sends the data to a single topic,par-titioned by key using either sync or async producer.
public void send(List<KeyedMessage<k,v>>messages)
- sends data to multiple topics.
Properties prop = new Properties();
prop.put(producer.type,”async”)
ProducerConfig config = new ProducerConfig(prop);
निर्माता दो प्रकार के होते हैं - Sync तथा Async।
समान API कॉन्फ़िगरेशन सिंक
निर्माता पर भी लागू होता है । उनके बीच का अंतर एक सिंक निर्माता है जो सीधे संदेश भेजता है, लेकिन पृष्ठभूमि में संदेश भेजता है। जब आप उच्च थ्रूपुट चाहते हैं, तो Async निर्माता को प्राथमिकता दी जाती है। पिछली रिलीज में 0.8 की तरह, एक async निर्माता के पास त्रुटि हैंडलर को पंजीकृत करने के लिए भेजने () के लिए कॉलबैक नहीं है। यह केवल वर्तमान रिलीज़ में 0.9 में उपलब्ध है।
सार्वजनिक शून्य के करीब ()
निर्माता वर्ग प्रदान करता है close सभी काफ्का ब्रो-केर्स के लिए निर्माता पूल कनेक्शन बंद करने की विधि।
कॉन्फ़िगरेशन सेटिंग्स
प्रोड्यूसर एपीआई की मुख्य कॉन्फ़िगरेशन सेटिंग्स बेहतर अंडर-स्टैंडिंग के लिए निम्न तालिका में सूचीबद्ध हैं -
S.No | कॉन्फ़िगरेशन सेटिंग्स और विवरण |
---|---|
1 | client.id निर्माता आवेदन की पहचान करता है |
2 | producer.type या तो सिंक या async |
3 | acks एक्स कॉन्फिगरेशन, निर्माता के अनुरोधों के तहत मापदंड को नियंत्रित करता है, जो कि पूरी तरह से कटा हुआ है। |
4 | retries यदि निर्माता अनुरोध विफल हो जाता है, तो स्वचालित रूप से विशिष्ट मूल्य के साथ पुन: प्रयास करें। |
5 | bootstrap.servers दलालों की बूटस्ट्रैपिंग सूची। |
6 | linger.ms यदि आप अनुरोधों की संख्या को कम करना चाहते हैं तो आप linger.ms को कुछ मूल्य से अधिक के लिए सेट कर सकते हैं। |
7 | key.serializer धारावाहिक इंटरफ़ेस के लिए कुंजी। |
8 | value.serializer धारावाहिक इंटरफ़ेस के लिए मूल्य। |
9 | batch.size बफर आकार। |
10 | buffer.memory बफ़रिंग के लिए निर्माता को उपलब्ध स्मृति की कुल मात्रा को नियंत्रित करता है। |
निर्माता निर्माता एपीआई
ProducerRecord एक कुंजी / मान युग्म है, जो निम्न हस्ताक्षर का उपयोग करके विभाजन, कुंजी और मूल्य जोड़े के साथ रिकॉर्ड बनाने के लिए Kafka क्लस्टर के लिए भेजा जाता है ।roducerRecord वर्ग निर्माता।
public ProducerRecord (string topic, int partition, k key, v value)
Topic - उपयोगकर्ता परिभाषित विषय नाम जो रिकॉर्ड करने के लिए संलग्न होगा।
Partition - विभाजन की गिनती
Key - कुंजी जो रिकॉर्ड में शामिल होगी।
- Value - रिकॉर्ड सामग्री
public ProducerRecord (string topic, k key, v value)
ProducerRecord क्लास कंस्ट्रक्टर का उपयोग कुंजी, मूल्य जोड़े और विभाजन के बिना रिकॉर्ड बनाने के लिए किया जाता है।
Topic - रिकॉर्ड असाइन करने के लिए एक विषय बनाएं।
Key - रिकॉर्ड के लिए कुंजी।
Value - रिकॉर्ड सामग्री।
public ProducerRecord (string topic, v value)
ProducerRecord वर्ग विभाजन और कुंजी के बिना एक रिकॉर्ड बनाता है।
Topic - एक विषय बनाएँ।
Value - रिकॉर्ड सामग्री।
ProducerRecord वर्ग विधियों को निम्न तालिका में सूचीबद्ध किया गया है -
S.No | क्लास के तरीके और विवरण |
---|---|
1 | public string topic() विषय रिकॉर्ड के लिए अपील करेंगे। |
2 | public K key() कुंजी जिसे रिकॉर्ड में शामिल किया जाएगा। यदि ऐसी कोई कुंजी नहीं है, तो नल को फिर से चालू कर दिया जाएगा। |
3 | public V value() सामग्री रिकॉर्ड करें। |
4 | partition() रिकॉर्ड के लिए विभाजन की गणना |
SimpleProducer आवेदन
एप्लिकेशन बनाने से पहले, सबसे पहले ZooKeeper और Kafka ब्रोकर शुरू करें और फिर टॉपिक कमांड का उपयोग करके Kafka ब्रोकर में अपना विषय बनाएं। उसके बाद Sim-pleProducer.java
नाम से एक java class बनाएँ
और निम्नलिखित कोडिंग में टाइप करें।
//import util.properties packages
import java.util.Properties;
//import simple producer packages
import org.apache.kafka.clients.producer.Producer;
//import KafkaProducer packages
import org.apache.kafka.clients.producer.KafkaProducer;
//import ProducerRecord packages
import org.apache.kafka.clients.producer.ProducerRecord;
//Create java class named “SimpleProducer”
public class SimpleProducer {
public static void main(String[] args) throws Exception{
// Check arguments length value
if(args.length == 0){
System.out.println("Enter topic name”);
return;
}
//Assign topicName to string variable
String topicName = args[0].toString();
// create instance for properties to access producer configs
Properties props = new Properties();
//Assign localhost id
props.put("bootstrap.servers", “localhost:9092");
//Set acknowledgements for producer requests.
props.put("acks", “all");
//If the request fails, the producer can automatically retry,
props.put("retries", 0);
//Specify buffer size in config
props.put("batch.size", 16384);
//Reduce the no of requests less than 0
props.put("linger.ms", 1);
//The buffer.memory controls the total amount of memory available to the producer for buffering.
props.put("buffer.memory", 33554432);
props.put("key.serializer",
"org.apache.kafka.common.serializa-tion.StringSerializer");
props.put("value.serializer",
"org.apache.kafka.common.serializa-tion.StringSerializer");
Producer<String, String> producer = new KafkaProducer
<String, String>(props);
for(int i = 0; i < 10; i++)
producer.send(new ProducerRecord<String, String>(topicName,
Integer.toString(i), Integer.toString(i)));
System.out.println(“Message sent successfully”);
producer.close();
}
}
Compilation - आवेदन निम्नलिखित आदेश का उपयोग करके संकलित किया जा सकता है।
javac -cp “/path/to/kafka/kafka_2.11-0.9.0.0/lib/*” *.java
Execution - एप्लिकेशन को निम्न कमांड का उपयोग करके निष्पादित किया जा सकता है।
java -cp “/path/to/kafka/kafka_2.11-0.9.0.0/lib/*”:. SimpleProducer <topic-name>
Output
Message sent successfully
To check the above output open new terminal and type Consumer CLI command to receive messages.
>> bin/kafka-console-consumer.sh --zookeeper localhost:2181 —topic <topic-name> —from-beginning
1
2
3
4
5
6
7
8
9
10
सरल उपभोक्ता उदाहरण
अब तक हमने काफ्का क्लस्टर को संदेश भेजने के लिए एक निर्माता बनाया है। अब कफका क्लस्टर के रूप में संदेशों का उपभोग करने के लिए एक उपभोक्ता बनाते हैं। KafkaConsumer API का उपयोग काफ्का क्लस्टर के संदेशों का उपभोग करने के लिए किया जाता है। KafkaConsumer वर्ग निर्माता नीचे परिभाषित किया गया है।
public KafkaConsumer(java.util.Map<java.lang.String,java.lang.Object> configs)
configs - कंज्यूमर कॉन्फिग का मैप लौटाएं।
KafkaConsumer वर्ग में निम्नलिखित महत्वपूर्ण विधियां हैं जो नीचे दी गई तालिका में सूचीबद्ध हैं।
S.No | विधि और विवरण |
---|---|
1 | public java.util.Set<TopicPar-tition> assignment() वर्तमान में con-sumer द्वारा निर्दिष्ट विभाजन का सेट प्राप्त करें। |
2 | public string subscription() डायनामिक रूप से हस्ताक्षरित विभाजन प्राप्त करने के लिए विषयों की दी गई सूची की सदस्यता लें। |
3 | public void sub-scribe(java.util.List<java.lang.String> topics, ConsumerRe-balanceListener listener) डायनामिक रूप से हस्ताक्षरित विभाजन प्राप्त करने के लिए विषयों की दी गई सूची की सदस्यता लें। |
4 | public void unsubscribe() विभाजन की दी गई सूची से विषयों को अनसब्सक्राइब करें। |
5 | public void sub-scribe(java.util.List<java.lang.String> topics) डायनामिक रूप से हस्ताक्षरित विभाजन प्राप्त करने के लिए विषयों की दी गई सूची की सदस्यता लें। यदि विषयों की दी गई सूची खाली है, तो इसे सदस्यता समाप्त () के समान माना जाता है। |
6 | public void sub-scribe(java.util.regex.Pattern pattern, ConsumerRebalanceLis-tener listener) तर्क पैटर्न नियमित अभिव्यक्ति के प्रारूप में सदस्यता पैटर्न को संदर्भित करता है और श्रोता तर्क को सदस्यता पैटर्न से सूचनाएं मिलती हैं। |
7 | public void as-sign(java.util.List<TopicParti-tion> partitions) मैन्युअल रूप से ग्राहक को विभाजन की एक सूची सौंपें। |
8 | poll() सब्स्क्राइब / असाइन किए गए API में से किसी एक का उपयोग करके निर्दिष्ट किए गए विषयों या विभाजनों के लिए डेटा प्राप्त करें। यदि डेटा के लिए मतदान से पहले विषयों की सदस्यता नहीं ली जाती है, तो यह त्रुटि लौटाएगा। |
9 | public void commitSync() विषयों और विभाजनों की सभी उप-स्क्राइब सूची के लिए अंतिम सर्वेक्षण () के अंतिम प्रतिबद्ध पर लौट आए। एक ही ऑपरेशन को कमिशन () के लिए लागू किया जाता है। |
10 | public void seek(TopicPartition partition, long offset) वर्तमान ऑफ़सेट मान प्राप्त करें जो उपभोक्ता अगले पोल () विधि पर उपयोग करेगा। |
1 1 | public void resume() रुके हुए विभाजन फिर से शुरू करें। |
12 | public void wakeup() उपभोक्ता जागो। |
ConsumerRecord API
ConsumerRecord API का उपयोग काफ्का क्लस्टर से रिकॉर्ड प्राप्त करने के लिए किया जाता है। इस एपीआई में एक विषय का नाम, विभाजन संख्या, जिसमें से रिकॉर्ड प्राप्त किया जा रहा है और एक ऑफसेट जो कि काफ्का विभाजन में रिकॉर्ड को इंगित करता है। ConsumerRecord वर्ग का उपयोग विशिष्ट विषय नाम, विभाजन गणना और <कुंजी, मान> जोड़े के साथ एक उपभोक्ता रिकॉर्ड बनाने के लिए किया जाता है। इसके निम्नलिखित हस्ताक्षर हैं।
public ConsumerRecord(string topic,int partition, long offset,K key, V value)
Topic - काफ्का क्लस्टर से प्राप्त उपभोक्ता रिकॉर्ड का विषय नाम।
Partition - विषय के लिए विभाजन।
Key - रिकॉर्ड की कुंजी, यदि कोई कुंजी मौजूद नहीं है तो शून्य वापस कर दी जाएगी।
Value - रिकॉर्ड सामग्री।
ConsumerRecords API
ConsumerRecords API, ConsumerRecord के कंटेनर के रूप में कार्य करता है। इस API का उपयोग किसी विशेष विषय के लिए प्रति विभाजन ConsumerRecord की सूची को रखने के लिए किया जाता है। इसका कंस्ट्रक्टर नीचे परिभाषित किया गया है।
public ConsumerRecords(java.util.Map<TopicPartition,java.util.List
<Consumer-Record>K,V>>> records)
TopicPartition - किसी विशेष विषय के लिए विभाजन का नक्शा लौटाएं।
Records - ConsumerRecord की सूची लौटाएं।
ConsumerRecords वर्ग में निम्नलिखित तरीके परिभाषित हैं।
S.No | तरीके और विवरण |
---|---|
1 | public int count() सभी विषयों के लिए रिकॉर्ड की संख्या। |
2 | public Set partitions() इस रिकॉर्ड सेट में डेटा के साथ विभाजन का सेट (यदि कोई डेटा वापस नहीं किया गया था तो सेट खाली है)। |
3 | public Iterator iterator() Iterator आपको एक संग्रह के माध्यम से चक्र प्राप्त करने में सक्षम बनाता है, तत्वों को प्राप्त करना या फिर से बढ़ना। |
4 | public List records() दिए गए विभाजन के रिकॉर्ड की सूची प्राप्त करें। |
कॉन्फ़िगरेशन सेटिंग्स
उपभोक्ता क्लाइंट API मुख्य कॉन्फ़िगरेशन सेटिंग्स के लिए कॉन्फ़िगरेशन सेटिंग्स नीचे सूचीबद्ध हैं -
S.No | सेटिंग्स और विवरण |
---|---|
1 | bootstrap.servers दलालों की बूटस्ट्रैपिंग सूची। |
2 | group.id एक समूह के लिए एक व्यक्तिगत उपभोक्ता असाइन करता है। |
3 | enable.auto.commit यदि मान सत्य है, तो ऑफ़सेट के लिए ऑटो कमिट सक्षम करें, अन्यथा प्रतिबद्ध नहीं है। |
4 | auto.commit.interval.ms वापसी कितनी बार उपभोग किए गए ऑफ़सेट्स को चिड़ियाघरकीपर को लिखा जाता है। |
5 | session.timeout.ms इंगित करता है कि संदेश देने और जारी रखने के लिए कफ़्का कितने मिलिसेक का इंतजार करेगी (कबूलने या लिखने के लिए) अनुरोध का जवाब देने के लिए। |
SimpleConsumer आवेदन
निर्माता के आवेदन के चरण यहां समान हैं। सबसे पहले, अपने चिड़ियाघरकीपर और काफ्का दलाल को शुरू करें। फिर SimpleCon-sumer.java
नाम के जावा वर्ग के साथ एक SimpleConsumer
एप्लिकेशन बनाएं
और निम्नलिखित कोड टाइप करें।
import java.util.Properties;
import java.util.Arrays;
import org.apache.kafka.clients.consumer.KafkaConsumer;
import org.apache.kafka.clients.consumer.ConsumerRecords;
import org.apache.kafka.clients.consumer.ConsumerRecord;
public class SimpleConsumer {
public static void main(String[] args) throws Exception {
if(args.length == 0){
System.out.println("Enter topic name");
return;
}
//Kafka consumer configuration settings
String topicName = args[0].toString();
Properties props = new Properties();
props.put("bootstrap.servers", "localhost:9092");
props.put("group.id", "test");
props.put("enable.auto.commit", "true");
props.put("auto.commit.interval.ms", "1000");
props.put("session.timeout.ms", "30000");
props.put("key.deserializer",
"org.apache.kafka.common.serializa-tion.StringDeserializer");
props.put("value.deserializer",
"org.apache.kafka.common.serializa-tion.StringDeserializer");
KafkaConsumer<String, String> consumer = new KafkaConsumer
<String, String>(props);
//Kafka Consumer subscribes list of topics here.
consumer.subscribe(Arrays.asList(topicName))
//print the topic name
System.out.println("Subscribed to topic " + topicName);
int i = 0;
while (true) {
ConsumerRecords<String, String> records = con-sumer.poll(100);
for (ConsumerRecord<String, String> record : records)
// print the offset,key and value for the consumer records.
System.out.printf("offset = %d, key = %s, value = %s\n",
record.offset(), record.key(), record.value());
}
}
}
Compilation - आवेदन निम्नलिखित आदेश का उपयोग करके संकलित किया जा सकता है।
javac -cp “/path/to/kafka/kafka_2.11-0.9.0.0/lib/*” *.java
Execution − एप्लिकेशन को निम्नलिखित कमांड का उपयोग करके निष्पादित किया जा सकता है
java -cp “/path/to/kafka/kafka_2.11-0.9.0.0/lib/*”:. SimpleConsumer <topic-name>
Input- निर्माता CLI खोलें और विषय पर कुछ संदेश भेजें। आप 'हैलो कंज्यूमर' के रूप में स्माइल इनपुट डाल सकते हैं।
Output - निम्नलिखित आउटपुट होगा।
Subscribed to topic Hello-Kafka
offset = 3, key = null, value = Hello Consumer