当前位置: 首页>>代码示例>>TypeScript>>正文


TypeScript amqplib.Channel类代码示例

本文整理汇总了TypeScript中amqplib.Channel的典型用法代码示例。如果您正苦于以下问题:TypeScript Channel类的具体用法?TypeScript Channel怎么用?TypeScript Channel使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。


在下文中一共展示了Channel类的9个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的TypeScript代码示例。

示例1: consumeChannel

 private consumeChannel(channel: Channel): void {
     channel.consume(
         REPLY_QUEUE,
         (msg: Message) => this.responseEmitter.emit(msg.properties.correlationId, msg.content),
         {noAck: true}
     );
 }
开发者ID:db3dev,项目名称:amqp-rpc-client-controller,代码行数:7,代码来源:client.ts

示例2:

            .then((channel: Channel) => {
                self._channel = channel;

                // Assert Queue
                channel.assertQueue(
                    self.queueName,
                    { durable: false }
                );
                channel.prefetch(1);
                if (self.verboseOn) {
                    console.log(`Awaiting RPC Requests On: ${self.queueName}`);
                }

                // Consume Messages
                self.consumeChannel.apply(self, [channel, actionFunction]);

                return self._channel;
            });
开发者ID:db3dev,项目名称:amqp-rpc-server-controller,代码行数:18,代码来源:server.ts

示例3:

            .then((channel: Channel) => {
                self._channel = channel;
                channel.setMaxListeners(0);

                // Action to take when message received
                self.consumeChannel.apply(self, [channel]);

                return channel;
            });
开发者ID:db3dev,项目名称:amqp-rpc-client-controller,代码行数:9,代码来源:client.ts

示例4: consumeChannel

    private consumeChannel(
        channel: Channel,
        actionFunction: (message: any, responseCallback: Function) => {}
    ): void {
        channel.consume(
            this.queueName,
            (msg: Message) => {
                const decodedMessage = msg.content.toString();

                // Handle Received Message
                if (this.verboseOn) {
                    console.log(`RECEIVED FROM BROKER: ${decodedMessage}`);
                }
                actionFunction(JSON.parse(decodedMessage), (response: any, error?: Error) => {
                    if (!response && !error) {
                        error = new Error('Could not complete request.');
                    }

                    if (typeof response !== 'object') {
                        error = new Error('Response must be a JSON object.');
                    }

                    if (error) {
                        // Failed to handle message
                        channel.sendToQueue(
                            msg.properties.replyTo,
                            new Buffer(JSON.stringify(error)),
                            { correlationId: msg.properties.correlationId }
                        );
                    } else {
                        // Send back response
                        const outgoing: string = JSON.stringify(response);

                        if (this.verboseOn) {
                            console.log(`SENDING TO BROKER: ${outgoing}`);
                        }
                        channel.sendToQueue(
                            msg.properties.replyTo,
                            new Buffer(outgoing),
                            { correlationId: msg.properties.correlationId }
                        );
                    }

                    // Send Ack
                    channel.ack(msg);
                });
            }
        );
    }
开发者ID:db3dev,项目名称:amqp-rpc-server-controller,代码行数:49,代码来源:server.ts

示例5: Buffer

                actionFunction(JSON.parse(decodedMessage), (response: any, error?: Error) => {
                    if (!response && !error) {
                        error = new Error('Could not complete request.');
                    }

                    if (typeof response !== 'object') {
                        error = new Error('Response must be a JSON object.');
                    }

                    if (error) {
                        // Failed to handle message
                        channel.sendToQueue(
                            msg.properties.replyTo,
                            new Buffer(JSON.stringify(error)),
                            { correlationId: msg.properties.correlationId }
                        );
                    } else {
                        // Send back response
                        const outgoing: string = JSON.stringify(response);

                        if (this.verboseOn) {
                            console.log(`SENDING TO BROKER: ${outgoing}`);
                        }
                        channel.sendToQueue(
                            msg.properties.replyTo,
                            new Buffer(outgoing),
                            { correlationId: msg.properties.correlationId }
                        );
                    }

                    // Send Ack
                    channel.ack(msg);
                });
开发者ID:db3dev,项目名称:amqp-rpc-server-controller,代码行数:33,代码来源:server.ts

示例6: cancel

 public async cancel() {
   if (!this.isAcked) throw new Error('cannot cancel before ack')
   await this.channel.cancel(this.message.fields['consumerTag'])
   await this.channel.close()
   this.emit('cancel')
 }
开发者ID:bangbang93,项目名称:carrotmq,代码行数:6,代码来源:context.ts

示例7: reject

 public reject(requeue?: boolean) {
   this.checkAck()
   return this.channel.reject(this.message, requeue)
 }
开发者ID:bangbang93,项目名称:carrotmq,代码行数:4,代码来源:context.ts

示例8: nack

 public nack(allUpTo?: boolean, requeue?: boolean) {
   this.checkAck()
   return this.channel.nack(this.message, allUpTo, requeue)
 }
开发者ID:bangbang93,项目名称:carrotmq,代码行数:4,代码来源:context.ts

示例9: ack

 public ack(allUpTo?: boolean) {
   this.checkAck()
   return this.channel.ack(this.message, allUpTo)
 }
开发者ID:bangbang93,项目名称:carrotmq,代码行数:4,代码来源:context.ts


注:本文中的amqplib.Channel类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。