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


Python confluent_kafka.Producer方法代碼示例

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


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

示例1: _initialize_members

# 需要導入模塊: import confluent_kafka [as 別名]
# 或者: from confluent_kafka import Producer [as 別名]
def _initialize_members(self, topic, server, port, zk_server, zk_port, partitions):

        # get logger isinstance
        self._logger = logging.getLogger("SPOT.INGEST.KafkaProducer")

        # kafka requirements
        self._server = server
        self._port = port
        self._zk_server = zk_server
        self._zk_port = zk_port
        self._topic = topic
        self._num_of_partitions = partitions
        self._partitions = []
        self._partitioner = None
        self._kafka_brokers = '{0}:{1}'.format(self._server, self._port)

        # create topic with partitions
        self._create_topic()

        self._kafka_conf = self._producer_config(self._kafka_brokers)

        self._p = Producer(**self._kafka_conf) 
開發者ID:apache,項目名稱:incubator-spot,代碼行數:24,代碼來源:kafka_client.py

示例2: create_producer

# 需要導入模塊: import confluent_kafka [as 別名]
# 或者: from confluent_kafka import Producer [as 別名]
def create_producer(self, retry_limit, buffering_max):
        console_out_many(["Creating producer with:", 
                f"       bootstrap.servers={self.broker_manager.get_bootstrap_servers()}",
                f"       acks={self.acks_mode}",
                f"       retries={retry_limit}",
                f"       buffering={buffering_max}"], self.get_actor())

        self.producer = Producer({'bootstrap.servers': self.broker_manager.get_bootstrap_servers(),
                            'message.send.max.retries': retry_limit,
                            'queue.buffering.max.ms': buffering_max,
                            #'queue.buffering.max.ms': 100,
                            #'batch.num.messages': 1000,
                            #'stats_cb': my_stats_callback,
                            #'statistics.interval.ms': 100,
                            'metadata.max.age.ms': 60000,
                            'default.topic.config': { 'request.required.acks': self.acks_mode }}) 
開發者ID:Vanlightly,項目名稱:ChaosTestingCode,代碼行數:18,代碼來源:KafkaProducer.py

示例3: create_idempotent_producer

# 需要導入模塊: import confluent_kafka [as 別名]
# 或者: from confluent_kafka import Producer [as 別名]
def create_idempotent_producer(self, retry_limit, buffering_max):
        console_out_many(["Creating idempotent producer with:", 
                f"       bootstrap.servers={self.broker_manager.get_bootstrap_servers()}",
                f"       acks={self.acks_mode}",
                f"       retries={retry_limit}",
                "        metadata.max.age.ms: 60000",
                f"       buffering={buffering_max}"], self.get_actor())

        self.producer = Producer({'bootstrap.servers': self.broker_manager.get_bootstrap_servers(),
                            'message.send.max.retries': retry_limit,
                            'enable.idempotence': True,
                            'queue.buffering.max.ms': buffering_max,
                            #'batch.num.messages': 1000,
                            #'stats_cb': my_stats_callback,
                            #'statistics.interval.ms': 100,
                            'metadata.max.age.ms': 60000,
                            'default.topic.config': { 'request.required.acks': self.acks_mode }
                        }) 
開發者ID:Vanlightly,項目名稱:ChaosTestingCode,代碼行數:20,代碼來源:KafkaProducer.py

示例4: prepareProducer

# 需要導入模塊: import confluent_kafka [as 別名]
# 或者: from confluent_kafka import Producer [as 別名]
def prepareProducer(self,groupID = "pythonproducers"):
        options ={
                'bootstrap.servers':  self.kafka_brokers,
                'group.id': groupID
        }
        # We need this test as local kafka does not expect SSL protocol.
        if (self.kafka_env != 'LOCAL'):
            options['security.protocol'] = 'SASL_SSL'
            options['sasl.mechanisms'] = 'PLAIN'
            options['sasl.username'] = 'token'
            options['sasl.password'] = self.kafka_apikey
        if (self.kafka_env == 'OCP'):
            options['ssl.ca.location'] = os.environ['PEM_CERT']
        print("[KafkaProducer] - This is the configuration for the producer:")
        print('[KafkaProducer] - {}'.format(options))
        self.producer = Producer(options) 
開發者ID:ibm-cloud-architecture,項目名稱:refarch-kc,代碼行數:18,代碼來源:KcProducer.py

示例5: test_ksql_create_stream_w_properties

# 需要導入模塊: import confluent_kafka [as 別名]
# 或者: from confluent_kafka import Producer [as 別名]
def test_ksql_create_stream_w_properties(self):
        """ Test GET requests """
        topic = self.exist_topic
        stream_name = self.test_prefix + "test_ksql_create_stream"
        stream_name = "test_ksql_create_stream"
        ksql_string = "CREATE STREAM {} (ORDER_ID INT, TOTAL_AMOUNT DOUBLE, CUSTOMER_NAME VARCHAR) \
                       WITH (kafka_topic='{}', value_format='JSON');".format(stream_name, topic)
        streamProperties = {"ksql.streams.auto.offset.reset": "earliest"}
        if 'TEST_KSQL_CREATE_STREAM' not in utils.get_all_streams(self.api_client):
            r = self.api_client.ksql(ksql_string, stream_properties=streamProperties)
            self.assertEqual(r[0]['commandStatus']['status'], 'SUCCESS')
        producer = Producer({'bootstrap.servers': self.bootstrap_servers})
        producer.produce(self.exist_topic, '''{"order_id":3,"total_amount":43,"customer_name":"Palo Alto"}''')
        producer.flush()
        print()
        chunks = self.api_client.query("select * from {}".format(stream_name), stream_properties=streamProperties, idle_timeout=10)
        for chunk in chunks:
            pass
            assert json.loads(chunk)['row']['columns'][-1]=='Palo Alto' 
開發者ID:bryanyang0528,項目名稱:ksql-python,代碼行數:21,代碼來源:test_client.py

示例6: test_conf_none

# 需要導入模塊: import confluent_kafka [as 別名]
# 或者: from confluent_kafka import Producer [as 別名]
def test_conf_none():
    """ Issue #133
    Test that None can be passed for NULL by setting bootstrap.servers
    to None. If None would be converted to a string then a broker would
    show up in statistics. Verify that it doesnt. """

    def stats_cb_check_no_brokers(stats_json_str):
        """ Make sure no brokers are reported in stats """
        global seen_stats_cb_check_no_brokers
        stats = json.loads(stats_json_str)
        assert len(stats['brokers']) == 0, "expected no brokers in stats: %s" % stats_json_str
        seen_stats_cb_check_no_brokers = True

    conf = {'bootstrap.servers': None,  # overwrites previous value
            'statistics.interval.ms': 10,
            'stats_cb': stats_cb_check_no_brokers}

    p = confluent_kafka.Producer(conf)
    p.poll(timeout=1)

    global seen_stats_cb_check_no_brokers
    assert seen_stats_cb_check_no_brokers 
開發者ID:confluentinc,項目名稱:confluent-kafka-python,代碼行數:24,代碼來源:test_misc.py

示例7: test_error_cb

# 需要導入模塊: import confluent_kafka [as 別名]
# 或者: from confluent_kafka import Producer [as 別名]
def test_error_cb():
    """ Test the error callback. """

    global seen_all_brokers_down

    # Configure an invalid broker and make sure the ALL_BROKERS_DOWN
    # error is seen in the error callback.
    p = Producer({'bootstrap.servers': '127.0.0.1:1', 'socket.timeout.ms': 10,
                  'error_cb': error_cb})

    t_end = time.time() + 5

    while not seen_all_brokers_down and time.time() < t_end:
        p.poll(1)

    assert seen_all_brokers_down 
開發者ID:confluentinc,項目名稱:confluent-kafka-python,代碼行數:18,代碼來源:test_KafkaError.py

示例8: test_fatal

# 需要導入模塊: import confluent_kafka [as 別名]
# 或者: from confluent_kafka import Producer [as 別名]
def test_fatal():
    """ Test fatal exceptions """

    # Configure an invalid broker and make sure the ALL_BROKERS_DOWN
    # error is seen in the error callback.
    p = Producer({'error_cb': error_cb})

    with pytest.raises(KafkaException) as exc:
        raise KafkaException(KafkaError(KafkaError.MEMBER_ID_REQUIRED,
                                        fatal=True))
    err = exc.value.args[0]
    assert isinstance(err, KafkaError)
    assert err.fatal()
    assert not err.retriable()
    assert not err.txn_requires_abort()

    p.poll(0)  # Need some p use to avoid flake8 unused warning 
開發者ID:confluentinc,項目名稱:confluent-kafka-python,代碼行數:19,代碼來源:test_KafkaError.py

示例9: _get_kafka_producer

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

        try:

            if self.kafka_endpoint.startswith('@'):
                try:
                    _k_endpoint = get_endpoint_from_consul(self.consul_endpoint,
                                                           self.kafka_endpoint[1:])
                    log.debug('found-kafka-service', endpoint=_k_endpoint)

                except Exception as e:
                    log.exception('no-kafka-service-in-consul', e=e)

                    self.kproducer = None
                    self.kclient = None
                    return
            else:
                _k_endpoint = self.kafka_endpoint
            self.kproducer = _kafkaProducer(
                {'bootstrap.servers' :_k_endpoint}
                )
            pass
        except Exception, e:
            log.exception('failed-get-kafka-producer', e=e)
            return 
開發者ID:opencord,項目名稱:voltha,代碼行數:27,代碼來源:kafka_proxy.py

示例10: Kafka

# 需要導入模塊: import confluent_kafka [as 別名]
# 或者: from confluent_kafka import Producer [as 別名]
def Kafka(node, servers='', topic='', json=False, wrap=False):
    '''Connect to kafka server and send data

    Args:
        foo (callable): input stream
        foo_kwargs (dict): kwargs for the input stream
        servers (list): kafka bootstrap servers
        group (str): kafka group id
        topics (list): list of kafka topics to connect to
        json (bool): load input data as json
        wrap (bool): wrap result in a list
        interval (int): kafka poll interval
    '''

    p = Producer({'bootstrap.servers': servers})

    def _send(data, producer=p, topic=topic, json=json, wrap=wrap):
        # Trigger any available delivery report callbacks from previous produce() calls
        producer.poll(0)

        if wrap:
            data = [data]

        if json:
            data = JSON.dumps(data)

        producer.produce(topic, data.encode('utf-8'))
        return data

    ret = Node(foo=_send, name='Kafka', inputs=1, graphvizshape=_OUTPUT_GRAPHVIZSHAPE)
    node >> ret
    return ret 
開發者ID:timkpaine,項目名稱:tributary,代碼行數:34,代碼來源:kafka.py

示例11: create_kafka_consumer

# 需要導入模塊: import confluent_kafka [as 別名]
# 或者: from confluent_kafka import Producer [as 別名]
def create_kafka_consumer(brokers_ips: str, extra_params: Dict):
    config = extra_params or dict()
    config.update({'bootstrap.servers': ",".join(brokers_ips)})
    return confluent_kafka.Producer(config) 
開發者ID:intel,項目名稱:workload-collocation-agent,代碼行數:6,代碼來源:storage.py

示例12: __init__

# 需要導入模塊: import confluent_kafka [as 別名]
# 或者: from confluent_kafka import Producer [as 別名]
def __init__(self, config):  # pragma: no cover
        """
        Streaming client implementation based on Kafka.

        Configuration keys:
          KAFKA_ADDRESS
          KAFKA_CONSUMER_GROUP
          KAFKA_TOPIC
          TIMEOUT
          EVENT_HUB_KAFKA_CONNECTION_STRING
        """
        self.logger = Logger()

        self.topic = config.get("KAFKA_TOPIC")
        if not self.topic:
            raise ValueError("KAFKA_TOPIC is not set in the config object.")

        if not config.get("KAFKA_ADDRESS"):
            raise ValueError("KAFKA_ADDRESS is not set in the config object.")

        if config.get("TIMEOUT"):
            try:
                self.timeout = int(config.get("TIMEOUT"))
            except ValueError:
                self.timeout = None
        else:
            self.timeout = None

        kafka_config = self.create_kafka_config(config)
        self.admin = admin.AdminClient(kafka_config)

        if config.get("KAFKA_CONSUMER_GROUP") is None:
            self.logger.info('Creating Producer')
            self.producer = Producer(kafka_config)
            self.run = False
        else:
            self.logger.info('Creating Consumer')
            self.consumer = Consumer(kafka_config)
            self.run = True
            signal.signal(signal.SIGTERM, self.exit_gracefully) 
開發者ID:microsoft,項目名稱:agogosml,代碼行數:42,代碼來源:kafka_streaming_client.py

示例13: main

# 需要導入模塊: import confluent_kafka [as 別名]
# 或者: from confluent_kafka import Producer [as 別名]
def main():
    """Main entry for script"""
    parser = _get_parser()
    args = parser.parse_args()
    sources = _get_sources(_get_items(args.items), args.limit)
    timestamp = pd.Timestamp(args.start)
    freq = pd.Timedelta(args.freq)
    logging.basicConfig(level=_VERBOSITY.get(args.verbosity, logging.DEBUG))
    if args.broker_list is None:
        def _produce(timestamp, name, price):
            print('{},{},{}'.format(timestamp, name, price))

        LOGGER.debug('Running in console mode')
        _run(sources, timestamp, freq, args.real_time, args.real_time_multiplier, _produce)
    else:
        if args.topic is None:
            raise ValueError('Must specify --topic when using Kafka')
        from confluent_kafka import Producer
        producer = Producer({'bootstrap.servers': args.broker_list})

        def _produce(timestamp, name, price):
            data = '{},{},{}'.format(timestamp, name, price)
            produced = False
            while not produced:
                try:
                    producer.produce(args.topic, value=data.encode('utf-8'), key=name)
                    producer.poll(0)
                    produced = True
                except BufferError:
                    producer.poll(10)

        LOGGER.debug('Producing to %s on %s', args.topic, args.broker_list)
        _run(sources, timestamp, freq, args.real_time, args.real_time_multiplier, _produce)
        producer.flush() 
開發者ID:wintoncode,項目名稱:winton-kafka-streams,代碼行數:36,代碼來源:generator.py

示例14: producer

# 需要導入模塊: import confluent_kafka [as 別名]
# 或者: from confluent_kafka import Producer [as 別名]
def producer(self):
        # TODO: Must set all config values applicable to a producer
        return kafka.Producer({'bootstrap.servers': self.config.BOOTSTRAP_SERVERS}) 
開發者ID:wintoncode,項目名稱:winton-kafka-streams,代碼行數:5,代碼來源:kafka_client_supplier.py

示例15: init

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

        global log
        global kafka_producer

        if not log:
            log = create_logger(Config().get("logging"))

        if kafka_producer:
            raise Exception("XOSKafkaProducer already initialized")

        else:
            log.info(
                "Connecting to Kafka with bootstrap servers: %s"
                % Config.get("kafka_bootstrap_servers")
            )

            try:
                producer_config = {
                    "bootstrap.servers": ",".join(Config.get("kafka_bootstrap_servers"))
                }

                kafka_producer = confluent_kafka.Producer(**producer_config)

                log.info("Connected to Kafka: %s" % kafka_producer)

            except confluent_kafka.KafkaError as e:
                log.exception("Kafka Error: %s" % e) 
開發者ID:open-cloud,項目名稱:xos,代碼行數:30,代碼來源:xoskafkaproducer.py


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