【问题标题】:Can I call the Bluemix message hub service from Python?我可以从 Python 调用 Bluemix 消息中心服务吗?
【发布时间】:2016-05-19 14:37:28
【问题描述】:
kafka-python 客户端支持 Kafka 0.9,但显然不包含新的身份验证和加密功能,所以我猜它只适用于开放服务器(与以前的版本一样)。在任何情况下,即使是 Java 客户端也需要一个特殊的消息中心登录模块来连接(或者从示例中看起来是这样),这表明除非有可用于 Python 的类似模块,否则什么都不会起作用。
我的具体场景是,我想使用同样托管在 Bluemix 中的 Jupyter 笔记本中的消息中心服务(Apache Spark 服务)。
【问题讨论】:
标签:
python
apache-kafka
ibm-cloud
message-hub
【解决方案1】:
我能够使用 kafka-python 库进行连接:
$ pip install --user kafka-python
然后……
from kafka import KafkaProducer
from kafka.errors import KafkaError
import ssl
############################################
# Service credentials from Bluemix UI:
############################################
bootstrap_servers = # kafka_brokers_sasl
sasl_plain_username = # user
sasl_plain_password = # password
############################################
sasl_mechanism = 'PLAIN'
security_protocol = 'SASL_SSL'
# Create a new context using system defaults, disable all but TLS1.2
context = ssl.create_default_context()
context.options &= ssl.OP_NO_TLSv1
context.options &= ssl.OP_NO_TLSv1_1
producer = KafkaProducer(bootstrap_servers = bootstrap_servers,
sasl_plain_username = sasl_plain_username,
sasl_plain_password = sasl_plain_password,
security_protocol = security_protocol,
ssl_context = context,
sasl_mechanism = sasl_mechanism,
api_version=(0,10))
# Asynchronous by default
future = producer.send('my-topic', b'raw_bytes')
# Block for 'synchronous' sends
try:
record_metadata = future.get(timeout=10)
except KafkaError:
# Decide what to do if produce request failed...
log.exception()
pass
# Successful result returns assigned partition and offset
print (record_metadata.topic)
print (record_metadata.partition)
print (record_metadata.offset)
这适用于我从 Bluemix spark 作为 jupyter notebook 的服务,但是,请注意,这种方法不使用 spark。代码只是在驱动主机上运行。