超时连接到Bluemix上的消息中心

时间:2015-12-03 19:50:21

标签: ibm-cloud message-hub

我尝试连接到消息中心服务。如果我使用REST API,我可以连接但是当我尝试从我的Java程序连接时,总是超时

我正在使用下一个配置:

Properties producerProps = new Properties();
producerProps.put(SslConfigs.SSL_PROTOCOL_CONFIG, "TLSv1.2");
producerProps.put(SslConfigs.SSL_ENABLED_PROTOCOLS_CONFIG, "TLSv1.2");
producerProps.put(SslConfigs.SSL_TRUSTSTORE_LOCATION_CONFIG, "/Library/Java/JavaVirtualMachines/jdk1.8.0_66.jdk/Contents/Home/jre/lib/security/cacerts");
producerProps.put(SslConfigs.SSL_TRUSTSTORE_PASSWORD_CONFIG, "changeit");
producerProps.put(SslConfigs.SSL_TRUSTSTORE_TYPE_CONFIG, "JKS");
producerProps.put(SslConfigs.SSL_ENDPOINT_IDENTIFICATION_ALGORITHM_CONFIG, "HTTPS");
producerProps.put(CommonClientConfigs.SECURITY_PROTOCOL_CONFIG, "SSL");

producerProps.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, org.apache.kafka.common.serialization.ByteArraySerializer.class);
producerProps.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, org.apache.kafka.common.serialization.ByteArraySerializer.class);
producerProps.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, "kafka01-prod01.messagehub.services.us-south.bluemix.net:9093,kafka02-prod01.messagehub.services.us-south.bluemix.net:9093,kafka03-prod01.messagehub.services.us-south.bluemix.net:9093,kafka04-prod01.messagehub.services.us-south.bluemix.net:9093,kafka05-prod01.messagehub.services.us-south.bluemix.net:9093");
producerProps.put(ProducerConfig.CLIENT_ID_CONFIG, "myApiKey");

KafkaProducer<byte[], byte[]> kafkaProducer = new KafkaProducer<>(producerProps);
ProducerRecord<byte[], byte[]> producerRecord = new ProducerRecord<>("myTopic", "records".getBytes(), "[{ \"value\" : \"test\" }]".getBytes());

RecordMetadata metadata = kafkaProducer.send(producerRecord).get();
System.out.println("Offset: " + metadata.offset());
kafkaProducer.close();

过了一会儿,错误就是

Exception in thread "main" java.util.concurrent.ExecutionException: org.apache.kafka.common.errors.TimeoutException: Failed to update metadata after 231 ms.
at org.apache.kafka.clients.producer.KafkaProducer$FutureFailure.<init>(KafkaProducer.java:706)
at org.apache.kafka.clients.producer.KafkaProducer.send(KafkaProducer.java:453)
at org.apache.kafka.clients.producer.KafkaProducer.send(KafkaProducer.java:339)

我使用kafka-clients版本0.9.0.0

有什么想法吗?

3 个答案:

答案 0 :(得分:4)

您看到的异常通常是在使用前未创建主题的症状。 Message Hub不允许自动创建主题 - 必须通过Bluemix Dashboard创建主题,或者通过管理REST界面以编程方式创建主题。当您收到此错误时,您是否先创建了主题?

如果您还没有找到它们 - 这里是我们示例的链接,包括创建主题的Java示例,然后使用Kafka Java客户端生成/使用消息。 https://github.com/ibm-messaging/message-hub-samples

答案 1 :(得分:1)

好消息。现在一切都有效。自上次使用

以来,主题消失了

我向REST API发出POST请求,以确保创建主题,而不是接收422我收到了202,因此未创建主题。现在一切都像魅力一样

感谢大家

答案 2 :(得分:0)

关于UI被困在“等待数据......” 我们意识到了这个问题,并努力解决它。 欢呼声