本文整理匯總了Java中com.google.cloud.pubsub.TopicInfo類的典型用法代碼示例。如果您正苦於以下問題:Java TopicInfo類的具體用法?Java TopicInfo怎麽用?Java TopicInfo使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
TopicInfo類屬於com.google.cloud.pubsub包,在下文中一共展示了TopicInfo類的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: declareTopic
import com.google.cloud.pubsub.TopicInfo; //導入依賴的package包/類
public TopicInfo declareTopic(String name, String prefix, Integer partitionIndex) {
TopicInfo topic = null;
String topicName = createTopicName(name, prefix, partitionIndex);
try {
logger.debug("Creating topic: {} ",topic);
topic = client.create(TopicInfo.of(topicName));
}
catch (PubSubException e) {
if (e.reason().equals(PubSubBinder.ALREADY_EXISTS)) {
logger.warn("Topic: {} already exists, reusing definition from remote server",topicName);
topic = Topic.of(topicName);
}
}
return topic;
}
開發者ID:viniciusccarvalho,項目名稱:spring-cloud-stream-binder-pubsub,代碼行數:18,代碼來源:PubSubResourceManager.java
示例2: createProducerDestinationIfNecessary
import com.google.cloud.pubsub.TopicInfo; //導入依賴的package包/類
@Override
protected List<TopicInfo> createProducerDestinationIfNecessary(String name,
ExtendedProducerProperties<PubSubProducerProperties> properties) {
Integer partitionIndex = null;
List<TopicInfo> topics = new LinkedList<>();
if (properties.isPartitioned()) {
for (int i = 0; i < properties.getPartitionCount(); i++) {
if (properties.isPartitioned())
partitionIndex = i;
TopicInfo topic = resourceManager.declareTopic(name,
properties.getExtension().getPrefix(), partitionIndex);
topics.add(topic);
}
}
else {
topics.add(resourceManager.declareTopic(name,
properties.getExtension().getPrefix(), null));
}
return topics;
}
開發者ID:viniciusccarvalho,項目名稱:spring-cloud-stream-binder-pubsub,代碼行數:23,代碼來源:PubSubMessageChannelBinder.java
示例3: createProducerMessageHandler
import com.google.cloud.pubsub.TopicInfo; //導入依賴的package包/類
@Override
protected MessageHandler createProducerMessageHandler(List<TopicInfo> destinations,
ExtendedProducerProperties<PubSubProducerProperties> producerProperties)
throws Exception {
PubSubMessageHandler handler = null;
if (producerProperties.getExtension().isBatchEnabled()) {
handler = new BatchingPubSubMessageHandler(resourceManager,
producerProperties, destinations);
((BatchingPubSubMessageHandler) handler)
.setConcurrency(producerProperties.getExtension().getConcurrency());
}
else {
handler = new SimplePubSubMessageHandler(resourceManager, producerProperties,
destinations);
}
resourceManager.createRequiredMessageGroups(destinations, producerProperties);
return handler;
}
開發者ID:viniciusccarvalho,項目名稱:spring-cloud-stream-binder-pubsub,代碼行數:22,代碼來源:PubSubMessageChannelBinder.java
示例4: createNonPartitionedSubscription
import com.google.cloud.pubsub.TopicInfo; //導入依賴的package包/類
@Test
public void createNonPartitionedSubscription() throws Exception {
PubSubProducerProperties properties = new PubSubProducerProperties();
ExtendedProducerProperties<PubSubProducerProperties> producerProperties = new ExtendedProducerProperties<>(properties);
producerProperties.setRequiredGroups("hdfs", "average");
producerProperties.getExtension().setPrefix("createNonPartitionedSubscription");
List<TopicInfo> topics = new ArrayList<>();
topics.add(resourceManager.declareTopic("test",properties.getPrefix(),null));
resourceManager.createRequiredMessageGroups(topics,producerProperties);
Topic topic = pubSub.getTopic(topics.get(0).name());
Assert.assertNotNull(topic);
topic.listSubscriptions().iterateAll().forEachRemaining(subscriptionId -> {
Assert.assertTrue(subscriptionId.subscription().startsWith("createNonPartitionedSubscription.test."));
});
resourceManager.deleteTopics(topics);
}
開發者ID:viniciusccarvalho,項目名稱:spring-cloud-stream-binder-pubsub,代碼行數:21,代碼來源:ResourceManagerTests.java
示例5: createPartitionedSubscription
import com.google.cloud.pubsub.TopicInfo; //導入依賴的package包/類
@Test
public void createPartitionedSubscription() throws Exception {
PubSubProducerProperties properties = new PubSubProducerProperties();
ExtendedProducerProperties<PubSubProducerProperties> producerProperties = new ExtendedProducerProperties<>(properties);
producerProperties.setRequiredGroups("hdfs", "average");
producerProperties.getExtension().setPrefix("createPartitionedSubscription");
List<TopicInfo> topics = new ArrayList<>();
for(int i=0;i<2;i++){
topics.add(resourceManager.declareTopic("test",properties.getPrefix(),i));
}
resourceManager.createRequiredMessageGroups(topics,producerProperties);
for(int i=0;i<2;i++){
Topic topic = pubSub.getTopic(topics.get(i).name());
Assert.assertNotNull(topic);
topic.listSubscriptions().values().forEach(subscriptionId -> {
Assert.assertTrue(subscriptionId.subscription().startsWith("createPartitionedSubscription.test-"));
});
}
resourceManager.deleteTopics(topics);
}
開發者ID:viniciusccarvalho,項目名稱:spring-cloud-stream-binder-pubsub,代碼行數:26,代碼來源:ResourceManagerTests.java
示例6: consumeMessages
import com.google.cloud.pubsub.TopicInfo; //導入依賴的package包/類
@Test
public void consumeMessages() throws Exception {
int messageCount = 2000;
final AtomicInteger counter = new AtomicInteger(0);
CountDownLatch latch = new CountDownLatch(messageCount);
String baseTopicName = "pubsub-test";
ExtendedProducerProperties<PubSubProducerProperties> extendedProducerProperties = new ExtendedProducerProperties<>(new PubSubProducerProperties());
List<TopicInfo> topics = new ArrayList<>();
topics.add(resourceManager.declareTopic(baseTopicName,"",null));
SubscriptionInfo subscriptionInfo = resourceManager.declareSubscription(topics.get(0).name(),"test-subscription","");
PubSubMessageHandler messageHandler = new BatchingPubSubMessageHandler(resourceManager,extendedProducerProperties,topics);
messageHandler.start();
resourceManager.createConsumer(subscriptionInfo, message -> {
counter.incrementAndGet();
latch.countDown();
});
for(int j=0;j<messageCount;j++){
String payload = "foo-"+j;
messageHandler.handleMessage(MessageBuilder.withPayload(payload.getBytes()).build());
}
latch.await();
Assert.assertEquals(messageCount,counter.get());
}
開發者ID:viniciusccarvalho,項目名稱:spring-cloud-stream-binder-pubsub,代碼行數:25,代碼來源:PubSubMessageHandlerTests.java
示例7: PubSubMessageHandler
import com.google.cloud.pubsub.TopicInfo; //導入依賴的package包/類
public PubSubMessageHandler(PubSubResourceManager resourceManager,
ExtendedProducerProperties<PubSubProducerProperties> producerProperties,
List<TopicInfo> topics) {
this.resourceManager = resourceManager;
this.producerProperties = producerProperties;
this.mapper = new ObjectMapper();
this.topics = topics;
}
開發者ID:viniciusccarvalho,項目名稱:spring-cloud-stream-binder-pubsub,代碼行數:9,代碼來源:PubSubMessageHandler.java
示例8: createRequiredMessageGroups
import com.google.cloud.pubsub.TopicInfo; //導入依賴的package包/類
public void createRequiredMessageGroups(List<TopicInfo> destinations,
ExtendedProducerProperties<PubSubProducerProperties> producerProperties) {
for (String requiredGroupName : producerProperties.getRequiredGroups()) {
for (int i = 0; i < producerProperties.getPartitionCount(); i++) {
String name = destinations.get(i).name();
declareSubscription(destinations.get(i).name(), name, requiredGroupName);
}
}
}
開發者ID:viniciusccarvalho,項目名稱:spring-cloud-stream-binder-pubsub,代碼行數:11,代碼來源:PubSubResourceManager.java
示例9: createConsumerDestinationIfNecessary
import com.google.cloud.pubsub.TopicInfo; //導入依賴的package包/類
@Override
protected Subscription createConsumerDestinationIfNecessary(String name, String group,
ExtendedConsumerProperties<PubSubConsumerProperties> properties) {
boolean partitioned = properties.isPartitioned();
Integer partitionIndex = null;
if (partitioned) {
partitionIndex = properties.getInstanceIndex();
}
TopicInfo topicInfo = resourceManager.declareTopic(name,
properties.getExtension().getPrefix(), partitionIndex);
SubscriptionInfo subscription = resourceManager
.declareSubscription(topicInfo.name(), topicInfo.name(), group);
return resourceManager.createSubscription(subscription);
}
開發者ID:viniciusccarvalho,項目名稱:spring-cloud-stream-binder-pubsub,代碼行數:15,代碼來源:PubSubMessageChannelBinder.java
示例10: deleteTopics
import com.google.cloud.pubsub.TopicInfo; //導入依賴的package包/類
public void deleteTopics(List<TopicInfo> topics) {
for (TopicInfo t : topics) {
client.deleteTopic(t.name());
}
}
開發者ID:viniciusccarvalho,項目名稱:spring-cloud-stream-binder-pubsub,代碼行數:6,代碼來源:PubSubResourceManager.java
示例11: BatchingPubSubMessageHandler
import com.google.cloud.pubsub.TopicInfo; //導入依賴的package包/類
public BatchingPubSubMessageHandler(PubSubResourceManager resourceManager, ExtendedProducerProperties<PubSubProducerProperties> producerProperties, List<TopicInfo> topics) {
super(resourceManager, producerProperties, topics);
this.processor = WorkQueueProcessor.share(true);
}
開發者ID:viniciusccarvalho,項目名稱:spring-cloud-stream-binder-pubsub,代碼行數:5,代碼來源:BatchingPubSubMessageHandler.java
示例12: SimplePubSubMessageHandler
import com.google.cloud.pubsub.TopicInfo; //導入依賴的package包/類
public SimplePubSubMessageHandler(PubSubResourceManager resourceManager, ExtendedProducerProperties<PubSubProducerProperties> producerProperties, List<TopicInfo> topics) {
super(resourceManager, producerProperties, topics);
}
開發者ID:viniciusccarvalho,項目名稱:spring-cloud-stream-binder-pubsub,代碼行數:4,代碼來源:SimplePubSubMessageHandler.java