设置Python KafkaProducer sasl机制属性

Ano*_*ias 2 python ssl apache-kafka kafka-producer-api apache-kafka-security

我们使用的 sasl 机制是SCRAM-SHA-256但是 kafka 生产者只会接受sasl_mechanismas PLAIN, GSSAPI,OAUTHBEARER

下面的配置会报错

sasl_mechanism must be in PLAIN, GSSAPI, OAUTHBEARER
Run Code Online (Sandbox Code Playgroud)

配置

    ssl_produce = KafkaProducer(bootstrap_servers='brokerCName:9093',
                     security_protocol='SASL_SSL',
                     ssl_cafile='pemfilename.pem',
                     sasl_mechanism='SCRAM-SHA-256',
                     sasl_plain_username='password',
                     sasl_plain_password='secret')
Run Code Online (Sandbox Code Playgroud)

我需要知道如何指定正确的 sasl 机制。

谢谢

Gio*_*ous 6

kafka-python v2.0.0+ 的更新答案

2.0.0开始,kafka-python 同时支持SCRAM-SHA-256SCRAM-SHA-512


旧版本的先前答案kafka-python

据我了解,您正在使用kafka-python客户端。从源代码中,我可以看到这sasl_mechanism='SCRAM-SHA-256'不是一个有效的选项:

    """
    ...
    sasl_mechanism (str): Authentication mechanism when security_protocol
        is configured for SASL_PLAINTEXT or SASL_SSL. Valid values are:
        PLAIN, GSSAPI, OAUTHBEARER.
    ...
    """

    if self.config['security_protocol'] in ('SASL_PLAINTEXT', 'SASL_SSL'):
        assert self.config['sasl_mechanism'] in self.SASL_MECHANISMS, (
            'sasl_mechanism must be in ' + ', '.join(self.SASL_MECHANISMS)) 
Run Code Online (Sandbox Code Playgroud)

一种快速解决方法是使用confluent-kafka支持以下功能的客户端 sasl_mechanism='SCRAM-SHA-256'

from confluent_kafka import Producer 

# See https://github.com/edenhill/librdkafka/blob/master/CONFIGURATION.md
conf = {
    'bootstrap.servers': 'localhost:9092',
    'security.protocol': 'SASL_SSL',
    'sasl.mechanisms': 'SCRAM-SHA-256',
    'sasl.username': 'yourUsername',
    'sasl.password': 'yourPassword', 
    # any other config you like ..
}

p = Producer(**conf)
 
# Rest of your code goes here.. 
Run Code Online (Sandbox Code Playgroud)


Suk*_*iCZ 5

kafka-python在2.0.0版本中支持SCRAM-SHA-256和。SCRAM-SHA-512