अपाचे काफ्का - मूल संचालन

पहले हमें सिंगल नोड-सिंगल ब्रोकर कॉन्फ़िगरेशन लागू करना शुरू करते हैं और फिर हम अपने सेटअप को सिंगल नोड-मल्टीपल ब्रोकर्स कॉन्फ़िगरेशन में माइग्रेट करते हैं।

उम्मीद है कि आपने अब तक अपनी मशीन पर जावा, ज़ूकीपर और काफ्का स्थापित किया होगा। काफ्का क्लस्टर सेटअप में जाने से पहले, आपको अपना चिड़ियाघर कीपर शुरू करना होगा क्योंकि काफ्का क्लस्टर ज़ूकीपर का उपयोग करता है।

ZooKeeper प्रारंभ करें

एक नया टर्मिनल खोलें और निम्न कमांड टाइप करें -

bin/zookeeper-server-start.sh config/zookeeper.properties

काफ्का ब्रोकर शुरू करने के लिए, निम्न कमांड टाइप करें -

bin/kafka-server-start.sh config/server.properties

काफ्का ब्रोकर को शुरू करने के बाद, चिड़ियाघर कीपर टर्मिनल पर कमांड जेपी टाइप करें और आपको निम्नलिखित प्रतिक्रिया दिखाई देगी -

821 QuorumPeerMain
928 Kafka
931 Jps

अब आप टर्मिनल पर चलने वाले दो डेमन को देख सकते हैं जहां क्वोरमपेरमैन ज़ूकेर डेमन है और एक अन्य काफ्का डेमन है।

सिंगल नोड-सिंगल ब्रोकर कॉन्फ़िगरेशन

इस कॉन्फ़िगरेशन में आपके पास एक एकल ज़ूकीपर और ब्रोकर आईडी उदाहरण है। इसे कॉन्फ़िगर करने के चरण निम्नलिखित हैं -

Creating a Kafka Topic- Kafka सर्वर पर विषय बनाने के लिए kafka-topics.sh नाम की एक कमांड लाइन उपयोगिता प्रदान करता है । नया टर्मिनल खोलें और नीचे का उदाहरण लिखें।

Syntax

bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 1 
--partitions 1 --topic topic-name

Example

bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 1   
--partitions 1 --topic Hello-Kafka

हमने केवल हैलो-काफ्का नाम का एक विषय बनाया है जिसमें एक विभाजन और एक प्रतिकृति कारक है। उपरोक्त निर्मित आउटपुट निम्न आउटपुट के समान होगा -

Output- हैलो-काफ्का विषय बनाया

विषय बन जाने के बाद, आप काफ्का ब्रोकर टर्मिनल विंडो में नोटिफिकेशन प्राप्त कर सकते हैं और “/ tmp / kafka-log /” में निर्दिष्ट विषय के लिए लॉग इन कर सकते हैं।

विषयों की सूची

काफ्का सर्वर में विषयों की एक सूची प्राप्त करने के लिए, आप निम्नलिखित कमांड का उपयोग कर सकते हैं -

Syntax

bin/kafka-topics.sh --list --zookeeper localhost:2181

Output

Hello-Kafka

चूंकि हमने एक विषय बनाया है, यह केवल हैलो-काफ्का को सूचीबद्ध करेगा । मान लीजिए, यदि आप एक से अधिक विषय बनाते हैं, तो आपको विषय के नाम आउटपुट में मिलेंगे।

संदेश भेजने के लिए निर्माता शुरू करें

Syntax

bin/kafka-console-producer.sh --broker-list localhost:9092 --topic topic-name

उपरोक्त वाक्य रचना से, निर्माता कमांड लाइन क्लाइंट के लिए दो मुख्य मापदंडों की आवश्यकता होती है -

Broker-list- दलालों की सूची जिसे हम संदेश भेजना चाहते हैं। इस मामले में हमारे पास केवल एक दलाल है। Config / server.properties फ़ाइल में ब्रोकर पोर्ट आईडी है, क्योंकि हम जानते हैं कि हमारा ब्रोकर पोर्ट 9092 पर सुन रहा है, इसलिए आप इसे सीधे निर्दिष्ट कर सकते हैं।

विषय नाम - यहाँ विषय के नाम के लिए एक उदाहरण है।

Example

bin/kafka-console-producer.sh --broker-list localhost:9092 --topic Hello-Kafka

निर्माता स्टड से इनपुट पर इंतजार करेगा और काफ्का क्लस्टर में प्रकाशित करेगा। डिफ़ॉल्ट रूप से, प्रत्येक नई पंक्ति को एक नए संदेश के रूप में प्रकाशित किया जाता है फिर डिफ़ॉल्ट निर्माता गुण कॉन्फ़िगर / निर्माता में होते हैं । अब आप टर्मिनल में कुछ संदेश टाइप कर सकते हैं जैसा कि नीचे दिखाया गया है।

Output

$ bin/kafka-console-producer.sh --broker-list localhost:9092 
--topic Hello-Kafka[2016-01-16 13:50:45,931] 
WARN property topic is not valid (kafka.utils.Verifia-bleProperties)
Hello
My first message
My second message

संदेश प्राप्त करने के लिए उपभोक्ता शुरू करें

निर्माता के समान, डिफ़ॉल्ट उपभोक्ता गुण config / Consumer.proper-संबंधों फ़ाइल में निर्दिष्ट हैं । एक नया टर्मिनल खोलें और संदेशों का उपभोग करने के लिए नीचे दिए गए सिंटैक्स टाइप करें।

Syntax

bin/kafka-console-consumer.sh --zookeeper localhost:2181 —topic topic-name 
--from-beginning

Example

bin/kafka-console-consumer.sh --zookeeper localhost:2181 —topic Hello-Kafka 
--from-beginning

Output

Hello
My first message
My second message

अंत में, आप निर्माता के टर्मिनल से संदेश दर्ज कर सकते हैं और उन्हें उपभोक्ता के टर्मिनल में प्रदर्शित होते हुए देख सकते हैं। अब तक, आपके पास एकल ब्रोकर के साथ एकल नोड क्लस्टर पर बहुत अच्छी समझ है। आइए अब हम कई दलालों के कॉन्फ़िगरेशन पर चलते हैं।

सिंगल नोड-मल्टीपल ब्रोकर्स कॉन्फ़िगरेशन

कई ब्रोकर्स क्लस्टर सेटअप पर जाने से पहले, पहले अपना ज़ुकीपर सर्वर शुरू करें।

Create Multiple Kafka Brokers- हमारे पास पहले से ही con-अंजीर / server.properties में एक काफ्का ब्रोकर उदाहरण है। अब हमें कई ब्रोकर इंस्टेंसेस की आवश्यकता है, इसलिए मौजूदा server.prop-erties फाइल को दो नई कॉन्फिग फाइलों में कॉपी करें और इसे server-one.properties और server-two.prop-erties नाम दें। फिर दोनों नई फ़ाइलों को संपादित करें और निम्नलिखित परिवर्तन असाइन करें -

config / server-one.properties

# The id of the broker. This must be set to a unique integer for each broker.
broker.id=1
# The port the socket server listens on
port=9093
# A comma seperated list of directories under which to store log files
log.dirs=/tmp/kafka-logs-1

config / server-two.properties

# The id of the broker. This must be set to a unique integer for each broker.
broker.id=2
# The port the socket server listens on
port=9094
# A comma seperated list of directories under which to store log files
log.dirs=/tmp/kafka-logs-2

Start Multiple Brokers- तीन सर्वरों पर सभी परिवर्तन किए जाने के बाद, प्रत्येक ब्रोकर को एक-एक करके शुरू करने के लिए तीन नए टर्मिनल खोलें।

Broker1
bin/kafka-server-start.sh config/server.properties
Broker2
bin/kafka-server-start.sh config/server-one.properties
Broker3
bin/kafka-server-start.sh config/server-two.properties

अब हमारे पास मशीन पर चलने वाले तीन अलग-अलग दलाल हैं। टाइप करके सभी डेमों की जांच करने के लिए अपने आप से प्रयास करेंjps चिड़ियाघरकीपर टर्मिनल पर, फिर आपको प्रतिक्रिया दिखाई देगी।

एक विषय बनाना

आइए हम इस विषय के लिए तीन के रूप में प्रतिकृति कारक मान असाइन करें क्योंकि हमारे पास तीन अलग-अलग ब्रोकर चल रहे हैं। यदि आपके पास दो दलाल हैं, तो निर्दिष्ट प्रतिकृति मान दो होगा।

Syntax

bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 3 
-partitions 1 --topic topic-name

Example

bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 3 
-partitions 1 --topic Multibrokerapplication

Output

created topic “Multibrokerapplication”

वर्णन करें आदेश जो दलाल वर्तमान बनाई विषय पर सुन रहा है जैसा कि नीचे दिखाया जाँच करने के लिए प्रयोग किया जाता है -

bin/kafka-topics.sh --describe --zookeeper localhost:2181 
--topic Multibrokerappli-cation

Output

bin/kafka-topics.sh --describe --zookeeper localhost:2181 
--topic Multibrokerappli-cation

Topic:Multibrokerapplication    PartitionCount:1 
ReplicationFactor:3 Configs:
   
Topic:Multibrokerapplication Partition:0 Leader:0 
Replicas:0,2,1 Isr:0,2,1

उपरोक्त आउटपुट से, हम यह निष्कर्ष निकाल सकते हैं कि पहली पंक्ति में सभी विभाजनों का सारांश दिया गया है, जो विषय का नाम, विभाजन गणना और प्रतिकृति कारक है जो हमने पहले से ही चुना है। दूसरी पंक्ति में, प्रत्येक नोड विभाजन के एक बेतरतीब ढंग से चयनित भाग के लिए नेता होगा।

हमारे मामले में, हम देखते हैं कि हमारा पहला दलाल (दलाल 0 के साथ) नेता है। तब प्रतिकृतियां: 0,2,1 का मतलब है कि सभी दलालों विषय को दोहराने अंत में Isr का सेट है में-सिंक प्रतिकृतियां। खैर, यह प्रतिकृतियों का सबसेट है जो वर्तमान में जीवित हैं और नेता द्वारा पकड़ा जाता है।

संदेश भेजने के लिए निर्माता शुरू करें

यह प्रक्रिया एकल ब्रोकर सेटअप की तरह ही रहती है।

Example

bin/kafka-console-producer.sh --broker-list localhost:9092 
--topic Multibrokerapplication

Output

bin/kafka-console-producer.sh --broker-list localhost:9092 --topic Multibrokerapplication
[2016-01-20 19:27:21,045] WARN Property topic is not valid (kafka.utils.Verifia-bleProperties)
This is single node-multi broker demo
This is the second message

संदेश प्राप्त करने के लिए उपभोक्ता शुरू करें

यह प्रक्रिया वैसी ही रहती है जैसी सिंगल ब्रोकर सेटअप में दिखाई जाती है।

Example

bin/kafka-console-consumer.sh --zookeeper localhost:2181 
—topic Multibrokerapplica-tion --from-beginning

Output

bin/kafka-console-consumer.sh --zookeeper localhost:2181 
—topic Multibrokerapplica-tion —from-beginning
This is single node-multi broker demo
This is the second message

मूल विषय संचालन

इस अध्याय में हम विभिन्न बुनियादी विषय संचालन पर चर्चा करेंगे।

एक विषय को संशोधित करना

जैसा कि आप पहले ही समझ गए हैं कि काफ्का क्लस्टर में एक विषय कैसे बनाया जाए। अब हम निम्न कमांड का उपयोग करके एक निर्मित विषय को संशोधित करते हैं

Syntax

bin/kafka-topics.sh —zookeeper localhost:2181 --alter --topic topic_name 
--parti-tions count

Example

We have already created a topic “Hello-Kafka” with single partition count and one replica factor. 
Now using “alter” command we have changed the partition count.
bin/kafka-topics.sh --zookeeper localhost:2181 
--alter --topic Hello-kafka --parti-tions 2

Output

WARNING: If partitions are increased for a topic that has a key, 
the partition logic or ordering of the messages will be affected
Adding partitions succeeded!

एक विषय हटाना

किसी विषय को हटाने के लिए, आप निम्न सिंटैक्स का उपयोग कर सकते हैं।

Syntax

bin/kafka-topics.sh --zookeeper localhost:2181 --delete --topic topic_name

Example

bin/kafka-topics.sh --zookeeper localhost:2181 --delete --topic Hello-kafka

Output

> Topic Hello-kafka marked for deletion

Note −इसका कोई प्रभाव नहीं पड़ेगा अगर delete.topic.enable सच पर सेट नहीं है