[英]Read a kafka topic and expose the data via Rest API for prometheus to scrape ( Nodejs)
我已經使用 kafkajs 公開了從 kafka 主題讀取的數據,這些數據將通過 http 端點公開,以便普羅米修斯抓取數據。 但我無法公開來自 kafka 主題的數據。 我寫過這樣的生產者和消費者
生產者.js
// import the `Kafka` instance from the kafkajs library
const {
Kafka,
logLevel
} = require("kafkajs")
const fs = require("fs");
const path = require("path");
// the client ID lets kafka know who's producing the messages
const clientId = "my-app"
// we can define the list of brokers in the cluster
const brokers = ["localhost:9092"]
// this is the topic to which we want to write messages
const topic = "message-log"
// initialize a new kafka client and initialize a producer from it
const kafka = new Kafka({
clientId,
brokers,
// logLevel: logLevel.INFO
})
const producer = kafka.producer({})
// we define an async function that writes a new message each second
const produce = async () => {
await producer.connect()
// after the produce has connected, we start an interval timer
try {
// send a message to the configured topic with
// the key and value formed from the current value of `i`
await producer.send({
topic,
acks: 1,
messages: [{
key: "metrics on premise",
value: fs.readFileSync(path.join(__dirname,'metrics.txt'), 'utf8'),
}, ],
})
// if the message is written successfully, log it and increment `i`
console.log("writes: #####################")
} catch (err) {
console.error("could not write message " + err)
}
}
module.exports = produce
索引.js
const produce = require("./produce")
const consume = require("./consume")
const fs = require("fs");
const path = require("path");
const express = require('express')
const app = express()
const port = 3003
app.get('/metrics', async (req, res) => {
//res.send(fs.readFileSync(path.join(__dirname,'topic_message.txt'), 'utf8'))
consume(res).catch(err => {
console.error("Error in consumer: ", err)
})
})
app.listen(port, () => {
console.log(`Example app listening at http://localhost:${port}`)
})
// call the `produce` function and log an error if it occurs
produce().catch((err) => {
console.error("error in producer: ", err)
})
下面是消費者 Consumer.js
const {
Kafka,
logLevel
} = require("kafkajs")
const fs = require("fs");
const path = require("path");
const clientId = "my-app"
const brokers = ["localhost:9092"]
const topic = "message-log"
const kafka = new Kafka({
clientId,
brokers,
// logCreator: customLogger,
// logLevel: logLevel.DEBUG,
})
const consumer = kafka.consumer({
groupId: clientId,
minBytes: 5,
maxBytes: 1e6,
// wait for at most 3 seconds before receiving new data
maxWaitTimeInMs: 3000,
});
const consume = async (res) => {
// first, we wait for the client to connect and subscribe to the given topic
let myString = "";
await consumer.connect()
await consumer.subscribe({
topic,
fromBeginning: true
})
await consumer.run({
// this function is called every time the consumer gets a new message
eachMessage: ({
message
}) => {
console.log("Message received ###############################################################################");
res.send(message.value);
},
})
setTimeout(async () => {
await consumer.disconnect();
}, 2000);
}
module.exports = consume
當我點擊 api 時,我無法將消費的消息發送到 API
除非您以某種方式通過流式傳輸 HTTP 響應或使用 websockets(您不在此代碼中)進行抓取,否則我不確定這是一個好方法。
如果您真的想將 Kafka 記錄發送到 Prometheus,請通過消費者的 PushGateway 發送它們,而不是使用同步的 HTTP 抓取
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.