अपाचे काफ्का - मूल संचालन
पहले हमें सिंगल नोड-सिंगल ब्रोकर
कॉन्फ़िगरेशन लागू करना शुरू करते हैं और फिर हम अपने सेटअप को सिंगल नोड-मल्टीपल ब्रोकर्स कॉन्फ़िगरेशन में माइग्रेट करते हैं।
उम्मीद है कि आपने अब तक अपनी मशीन पर जावा, ज़ूकीपर और काफ्का स्थापित किया होगा। काफ्का क्लस्टर सेटअप में जाने से पहले, आपको अपना चिड़ियाघर कीपर शुरू करना होगा क्योंकि काफ्का क्लस्टर ज़ूकीपर का उपयोग करता है।
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 सच पर सेट नहीं है