本文整理汇总了TypeScript中kafka-node.Producer.on方法的典型用法代码示例。如果您正苦于以下问题:TypeScript Producer.on方法的具体用法?TypeScript Producer.on怎么用?TypeScript Producer.on使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类kafka-node.Producer
的用法示例。
在下文中一共展示了Producer.on方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的TypeScript代码示例。
示例1: kit
kit('listens to a kafka topic', (done) => {
let recieved = 0;
let topic = 'gustavTest-listen';
let producer = new kafka.Producer(client);
producer.on('ready', () => {
producer.send([{
topic,
messages: ['hello']
}], handleErr);
});
producer.on('err', handleErr);
let kafObservable = gr.from(topic);
kafObservable.subscribe(item => {
recieved++;
expect(item, 'Recieved proper message').to.equal('hello');
expect(recieved, 'Correct number of runs').to.equal(1);
done();
},
handleErr);
});
示例2: to
to(topic: string, iO: Observable<any>): Subscription<any> {
let client = this.getClient();
let producer = new kafka.Producer(client);
let buffer = [];
let handleErr = err => {
if (err) { throw err; }
};
producer.on('ready', () => {
if (!buffer.length) { return; }
producer.send([{
topic: topic,
messages: buffer
}], handleErr);
});
return iO
// Things run faster overall with a little buffering
.bufferTime(50)
.subscribe(
msg => {
if (!msg.length) { return; }
for (let i = msg.length - 1; i >= 0; i--) {
msg[i] = typeof msg[i] === 'string' ? msg[i] : JSON.stringify(msg[i]);
}
if (!producer.ready) {
buffer = buffer.concat(msg);
return;
}
producer.send([{
topic: topic,
messages: msg
}], handleErr);
},
handleErr,
() => {
producer.send([{
topic: topic,
messages: ['__done']
}]);
}
);
}