Apache Kafka के साथ संदेश भेजना और प्राप्त करना Node.js

चरण 1: काफ्का लाइब्रेरी स्थापित करें Node.js

terminal अपनी Node.js प्रोजेक्ट निर्देशिका में a खोलें ।

लाइब्रेरी स्थापित करने के लिए निम्नलिखित कमांड चलाएँ kafkajs, Node.js इसके लिए एक लाइब्रेरी Apache Kafka:। npm install kafkajs

Producer चरण 2: संदेश भेजना Node.js

लाइब्रेरी आयात करें kafkajs और Kafka Broker कॉन्फ़िगरेशन परिभाषित करें:

const { Kafka } = require('kafkajs');  
  
const kafka = new Kafka({  
  clientId: 'your-client-id',  
  brokers: ['broker1:port1', 'broker2:port2'], // Replace with actual addresses and ports  
});  

संदेश भेजने के लिए a बनाएँ producer, और a पर संदेश भेजें topic:

const producer = kafka.producer();  
  
const sendMessage = async() => {  
  await producer.connect();  
  await producer.send({
    topic: 'your-topic',  
    messages: [{ value: 'Hello Kafka!' }],  
  });  
  await producer.disconnect();  
};  
  
sendMessage();  

चरण 3: Consumer इन के साथ संदेश प्राप्त करना Node.js

लाइब्रेरी आयात करें kafkajs और Kafka Broker कॉन्फ़िगरेशन परिभाषित करें(यदि पहले से नहीं किया गया है):

const { Kafka } = require('kafkajs');  
  
const kafka = new Kafka({  
  clientId: 'your-client-id',  
  brokers: ['broker1:port1', 'broker2:port2'], // Replace with actual addresses and ports  
});  

consumer किसी विशिष्ट से संदेश प्राप्त करने के लिए एक बनाएं topic:

const consumer = kafka.consumer({ groupId: 'your-group-id' });  
  
const consumeMessages = async() => {  
  await consumer.connect();  
  await consumer.subscribe({ topic: 'your-topic', fromBeginning: true });  
  
  await consumer.run({  
    eachMessage: async({ topic, partition, message }) => {  
      console.log(`Received message: ${message.value}`);  
    },  
  });  
};  
  
consumeMessages();  

नोट: 'your-client-id', 'broker1:port1', 'your-topic', और जैसे मानों को 'your-group-id' अपनी वास्तविक परियोजना जानकारी से बदलें ।

कॉन्फ़िगरेशन विकल्पों और कार्यक्षमताओं के बारे में अधिक जानकारी के लिए आधिकारिक दस्तावेज़ Apache Kafka और लाइब्रेरी का संदर्भ लेना सुनिश्चित करें। kafkajs