當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript Producer.on方法代碼示例

本文整理匯總了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);
  });
開發者ID:jonesnc,項目名稱:gustav,代碼行數:25,代碼來源:GKafka.ts

示例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']
        }]);
      }
    );
  }
開發者ID:jonesnc,項目名稱:gustav,代碼行數:47,代碼來源:GustavKafka.ts


注:本文中的kafka-node.Producer.on方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。