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


Java TopicInfo類代碼示例

本文整理匯總了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


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