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


Python kombu.Producer方法代碼示例

本文整理匯總了Python中kombu.Producer方法的典型用法代碼示例。如果您正苦於以下問題:Python kombu.Producer方法的具體用法?Python kombu.Producer怎麽用?Python kombu.Producer使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在kombu的用法示例。


在下文中一共展示了kombu.Producer方法的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: __init__

# 需要導入模塊: import kombu [as 別名]
# 或者: from kombu import Producer [as 別名]
def __init__(self, name=None):
        if app.config['DEBUG']:
            setup_logging(loglevel='DEBUG', loggers=[''])

        self.connection = BrokerConnection(AMQP_URL)
        try:
            self.connection.connect()
        except Exception as e:
            LOG.error('Failed to connect to AMQP transport %s: %s', AMQP_URL, e)
            raise RuntimeError

        self.channel = self.connection.channel()
        self.exchange_name = AMQP_TOPIC

        self.exchange = Exchange(name=self.exchange_name, type='fanout', channel=self.channel)
        self.producer = Producer(exchange=self.exchange, channel=self.channel)

        super(FanoutPublisher, self).__init__(name)

        LOG.info('Configured fanout publisher on topic "%s"', AMQP_TOPIC) 
開發者ID:alerta,項目名稱:alerta-contrib,代碼行數:22,代碼來源:alerta_amqp.py

示例2: test

# 需要導入模塊: import kombu [as 別名]
# 或者: from kombu import Producer [as 別名]
def test(url):
    from kombu import Exchange, Queue, Connection, Consumer, Producer
    task_queue = Queue('tasks', exchange=Exchange('celery', type='direct'), routing_key='tasks')
    # 生產者
    with Connection(url) as conn:
        with conn.channel() as channel:
            producer = Producer(channel)
            producer.publish({'hello': 'world'},
                             retry=True,
                             exchange=task_queue.exchange,
                             routing_key=task_queue.routing_key,
                             declare=[task_queue])

    def get_message(body, message):
        print("receive message: %s" % body)
        # message.ack()

    # 消費者
    with Connection(url) as conn:
        with conn.channel() as channel:
            consumer = Consumer(channel, queues=task_queue, callbacks=[get_message, ], prefetch_count=10)
            consumer.consume(no_ack=True) 
開發者ID:DataIntegrationAlliance,項目名稱:data_integration_celery,代碼行數:24,代碼來源:check.py

示例3: connect

# 需要導入模塊: import kombu [as 別名]
# 或者: from kombu import Producer [as 別名]
def connect(self, exchange, channel):  # pragma: no cover
        """
        Readies the StorageNotify for publishing notification messages by
        setting up a kombu.Producer.

        :param exchange: The exchange for publishing notifications.
        :type exchange: kombu.Exchange
        :param channel: The channel to bind to.
        :type channel: kombu.transport.base.StdChannel
        """
        name = self.__class__.__name__
        self.logger.debug('Connecting {}'.format(name))

        self._queue = kombu.Queue(exchange=exchange, channel=channel)
        self._queue.declare()

        self._producer = kombu.Producer(channel, exchange) 
開發者ID:projectatomic,項目名稱:commissaire,代碼行數:19,代碼來源:notify.py

示例4: producer

# 需要導入模塊: import kombu [as 別名]
# 或者: from kombu import Producer [as 別名]
def producer(self):
        return Producer(self.connection) 
開發者ID:KubeOperator,項目名稱:KubeOperator,代碼行數:4,代碼來源:logger.py

示例5: send

# 需要導入模塊: import kombu [as 別名]
# 或者: from kombu import Producer [as 別名]
def send(self):

        try:
            # Connection
            conn = Connection(self.broker)

            # Channel
            channel = conn.channel()

            # Exchange
            task_exchange = Exchange(self._exchange_name,
                                     type=self._queue_type)

            # Queues
            if self._queue_name:
                queue = Queue(name=self._queue_name, channel=channel,
                              exchange=task_exchange,
                              routing_key=self._routing_key)
                queue.declare()

            # Producer
            producer = Producer(exchange=task_exchange, channel=channel,
                                routing_key=self._routing_key)

            # Send message
            for message in self._msgs:
                serialized_message = json.dumps(message, ensure_ascii=False)
                producer.publish(serialized_message)

            conn.close()

        except Exception, e:

            self.log.error(
                u'QueueManagerError - Error on sending objects from queue.')
            self.log.debug(e)
            raise Exception(
                'QueueManagerError - Error on sending objects to queue.') 
開發者ID:globocom,項目名稱:GloboNetworkAPI,代碼行數:40,代碼來源:queue_manager.py

示例6: get_producer

# 需要導入模塊: import kombu [as 別名]
# 或者: from kombu import Producer [as 別名]
def get_producer(self, handler, routing_key=None):
        return kombu.Producer(
            handler.channel,
            exchange=handler.exchanges[handler.exchange],
            routing_key=handler.routing_key if routing_key is None else routing_key,
            serializer='json'
        ) 
開發者ID:depop,項目名稱:celery-message-consumer,代碼行數:9,代碼來源:base.py

示例7: sender

# 需要導入模塊: import kombu [as 別名]
# 或者: from kombu import Producer [as 別名]
def sender(url):
    logger.info("start sender")
    with Connection(url) as conn:
        with conn.channel() as channel:
            # producer = Producer(channel)
            producer = channel.Producer()

            while True:
                message = time.strftime('%H:%M:%S', time.localtime())
                producer.publish(
                    body=message,
                    retry=True,
                    exchange='celery',
                    routing_key='rkeytest'
                )
                logger.info('send message: %s' % message)

                while True:
                    # 檢查隊列,以重新得到消息計數
                    queue = channel.queue_declare(queue='queuetest', passive=True)
                    messageCount = queue.message_count
                    logger.info('messageCount: %d' % messageCount)
                    if messageCount < 100:
                        time.sleep(0.5)
                        break
                    time.sleep(1) 
開發者ID:DataIntegrationAlliance,項目名稱:data_integration_celery,代碼行數:28,代碼來源:check.py

示例8: send

# 需要導入模塊: import kombu [as 別名]
# 或者: from kombu import Producer [as 別名]
def send(self, topic, message):
        """Publishes a pulse message to the proper exchange."""

        if not message:
            Log.error("Expecting a message")

        message._prepare()

        if not self.connection:
            self.connect()

        producer = Producer(
            channel=self.connection,
            exchange=Exchange(self.settings.exchange, type='topic'),
            routing_key=topic
        )

        # The message is actually a simple envelope format with a payload and
        # some metadata.
        final_data = Data(
            payload=message.data,
            _meta=set_default({
                'exchange': self.settings.exchange,
                'routing_key': message.routing_key,
                'serializer': self.settings.serializer,
                'sent': time_to_string(datetime.datetime.now(timezone(self.settings.broker_timezone))),
                'count': self.count
            }, message.metadata)
        )

        producer.publish(jsons.scrub(final_data), serializer=self.settings.serializer)
        self.count += 1 
開發者ID:mozilla,項目名稱:jx-sqlite,代碼行數:34,代碼來源:pulse.py

示例9: _producer

# 需要導入模塊: import kombu [as 別名]
# 或者: from kombu import Producer [as 別名]
def _producer(self):
        return self._connection().Producer(exchange=self._exchange(),
                                           **self.producer_options) 
開發者ID:miguelgrinberg,項目名稱:python-socketio,代碼行數:5,代碼來源:kombu_manager.py

示例10: inject

# 需要導入模塊: import kombu [as 別名]
# 或者: from kombu import Producer [as 別名]
def inject(self, exchange, routing_key, payload):
        self.__logs.irl.debug("Injecting a test AMQP message: ex=%s, rk=%s, payload=%s", exchange, routing_key, payload)
        if not isinstance(exchange, Exchange):
            exchange = Exchange(exchange, 'topic')
        prod = Producer(self.__connection, exchange=exchange, routing_key=routing_key)
        prod.publish(payload) 
開發者ID:RackHD,項目名稱:RackHD,代碼行數:8,代碼來源:amqp_source.py

示例11: test_helper_sync_send_msg

# 需要導入模塊: import kombu [as 別名]
# 或者: from kombu import Producer [as 別名]
def test_helper_sync_send_msg(self, exchange, ex_rk, send_rk, payload):
        ex = Exchange(exchange, 'topic')
        queue = Queue(exchange=ex, routing_key=ex_rk + '.*', exclusive=True, channel=self.__connection)
        queue.declare()
        prod = Producer(self.__connection, exchange=ex, routing_key=send_rk)
        prod.publish(payload)
        return queue 
開發者ID:RackHD,項目名稱:RackHD,代碼行數:9,代碼來源:amqp_source.py

示例12: setUp

# 需要導入模塊: import kombu [as 別名]
# 或者: from kombu import Producer [as 別名]
def setUp(self):
        super(BaseRetryHandlerIntegrationTest, self).setUp()

        # NOTE:
        # must be a real rabbitmq instance, we rely on rabbitmq
        # features (dead-letter exchange) for our retry queue logic
        self.connection = kombu.Connection(
            settings.BROKER_URL,
            connect_timeout=1,
        )
        self.connection.ensure_connection()
        self.connection.connect()
        self.channel = self.connection.channel()

        self.handler = AMQPRetryHandler(
            self.channel,
            routing_key=self.routing_key,
            queue=self.routing_key,
            exchange=self.exchange,
            queue_arguments={},
            func=lambda body: None,
            backoff_func=lambda attempt: 0,
        )
        self.handler.declare_queues()

        queues = [
            self.handler.worker_queue,
            self.handler.retry_queue,
            self.handler.archive_queue,
        ]
        for queue in queues:
            queue.purge()

        self.archive_consumer = kombu.Consumer(
            channel=self.channel,
            queues=[self.handler.archive_queue],
            callbacks=[self.handle_archive]
        )

        for consumer in [self.handler.consumer, self.archive_consumer]:
            consumer.consume()

        self.producer = kombu.Producer(
            self.channel,
            exchange=self.handler.exchanges[self.handler.exchange],
            routing_key=self.routing_key,
            serializer='json'
        )
        self.archives = [] 
開發者ID:depop,項目名稱:celery-message-consumer,代碼行數:51,代碼來源:base.py


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