我用的是Spring Boot,Apache·Kafka。
下面是我的控制器代码
package com.infy.controller;
@RestController
@RequestMapping(value = "/serving/")
public class ServingRequestWebControllerImpl implements ServingRequestWebController {
private static final Logger logger = LoggerFactory.getLogger(ServingRequestWebControllerImpl.class);
@Autowired
KafkaTemplate<String, TaskDetailsEntity> kafkaJsontemplate;
String TOPIC_NAME = "sample-topic";
@Override
@PostMapping(value = "/produce", consumes = { "application/json" }, produces = { "application/json" })
public String taskQueue(TaskDetailsEntity taskgDetailsEntity) {
kafkaJsontemplate.send(TOPIC_NAME, taskgDetailsEntity);
return "Serving Request Published Successfully To:- " + TOPIC_NAME;
}
}
下面是Kafka的配置代码
package com.infy.config;
@Configuration
public class KafkaConfig {
@Bean
public ProducerFactory<String, String> producerFactory() {
Map<String, Object> config = new HashMap<>();
config.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, "127.0.0.1:9092");
config.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
config.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, JsonSerializer.class);
return new DefaultKafkaProducerFactory(config);
}
@Bean
public KafkaTemplate<String, String> kafkaTemplate() {
return new KafkaTemplate<String, String>(producerFactory());
}
public ProducerFactory<String, ServingDetailsEntity> producerFactoryServingDetail() {
Map<String, Object> config = new HashMap<>();
config.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, "127.0.0.1:9092");
config.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
config.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, JsonSerializer.class);
return new DefaultKafkaProducerFactory(config);
}
@Bean
public KafkaTemplate<String, ServingDetailsEntity> kafkaTemplateServingDetailsListener() {
return new KafkaTemplate<String, ServingDetailsEntity>(producerFactoryServingDetail());
}
@Bean
public ConsumerFactory<String, ServingDetailsEntity> consumerFactory() {
Map<String, Object> config = new HashMap<>();
config.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, "127.0.0.1:9092");
config.put(ConsumerConfig.GROUP_ID_CONFIG, "event-group");
config.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, StringSerializer.class);
config.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, JsonSerializer.class);
return new DefaultKafkaConsumerFactory<>(config, new StringDeserializer(),
new JsonDeserializer<>(ServingDetailsEntity.class));
}
@Bean
public ConcurrentKafkaListenerContainerFactory<String, ServingDetailsEntity> kafkaTemplateTaskDetailsListener() {
ConcurrentKafkaListenerContainerFactory<String, ServingDetailsEntity> factory = new ConcurrentKafkaListenerContainerFactory<String, ServingDetailsEntity>();
factory.setConsumerFactory(consumerFactory());
return factory;
}
}
下面是我的消费代码
package com.infy.consumer;
@Service
public class KafkaConsumerService {
private static final Logger logger = LoggerFactory.getLogger(KafkaConsumerService.class);
@Autowired
private ServingService service;
@KafkaListener(topics = "sample-topic", groupId = "event-group",containerFactory = "kafkaTemplateTaskDetailsListener")
public void consumeTask(TaskDetailsEntity taskDtls){
System.out.println("Consumed Message:- \n "+taskDtls);
TaskDetailsEntity upsert = service.taskUpsert(taskDtls);
System.out.println(upsert.getId());
logger.info("\n Exit KafkaConsumerService consumeTask");
}
}
当我运行我的springboot应用程序时,我得到了下面的错误
描述:com.infy.controller.servingrequestwebcontrollerimpl中的字段kafkajsontemplate需要类型为“org.springframework.kafka.core.kafkatemplate”的bean,但找不到该bean。注入点具有以下注解:-@org.springframework.beans.factory.annotation.autowired(required=true)找到了以下候选对象,但无法注入:-未加载“kafkaautoconfiguration”中的bean方法“kafkatemplate”,因为排除了自动配置“kafkaautoconfiguration”。操作:考虑重新访问上面的条目或在配置中定义类型为“org.springframework.kafka.core.kafkatemplate”的bean。
我尝试将以下配置添加到application.properties,但没有成功
spring.autoconfigure.exclude=org.springframework.boot.autoconfigure.kafka.KafkaAutoConfiguration
下面是我的 Spring 启动主代码
package com.infy;
@SpringBootApplication
public class SpringBootInitializer {
public static void main(String[] args) {
SpringApplication.run(SpringBootInitializer.class, args);
}
}
请有人帮帮我,我犯了什么错误。
1条答案
按热度按时间stszievb1#
你想自动连接一个类型的bean
KafkaTemplate<String, TaskDetailsEntity>
,但您只声明了类型为的beanKafkaTemplate<String, String>
以及KafkaTemplate<String, ServingDetailsEntity>
在你的Kafka图里。可能也是一个错误
producerFactory()
有@Bean
注解和producerFactoryServingDetail()
没有。