![](/img/trans.png)
[英]Why is Spring Boot not reading from default application.properties file
[英]Spring Boot doesn't read the default value from the application.properties file
我有這個propelr.properties:
elasticsearch.port=443
elasticsearch.protocol=https
elasticsearch.index=contentlink
elasticsearch.type=cl
kafka.max-poll-records=1000
kafka.topic=es-indexer-topic
kafka.group.id=espn-content-link-kafka-es-connector-group
kafka.concurrency-level=4
這是我獲取端口的文件:
@Component
final class ElasticSearchClientFactory extends
AbstractFactoryBean<RestHighLevelClient> {
private final RestHighLevelClient client;
ElasticSearchClientFactory(
final @Value("${elasticsearch.hostname}") String hostname,
final @Value("${elasticsearch.port}") int port,
final @Value("${elasticsearch.protocol}") String protocol
) {
client = new RestHighLevelClient(RestClient.builder(new
HttpHost(hostname, port, protocol)));
}
@Override
public Class<?> getObjectType() {
return RestHighLevelClient.class;
}
@Override
protected RestHighLevelClient createInstance() throws Exception {
return client;
}
@Override
public void destroy() throws Exception {
if (Objects.nonNull(client)) {
client.close();
}
}
}
這部分代碼是@Configuration所在的位置:
@EnableKafka
@Configuration
public class KafkaReceiverConfig {
@Value("${contentlink.kafka.bootstrap.servers}")
private String bootstrapServers;
@Value("${kafka.group.id}")
private String kafkaGroupId;
@Value("${kafka.max-poll-records}")
private String kafkaMaxPollRecords;
@Value("${kafka.concurrency-level}")
private int kafkaConcurrencyLevel;
private EspnMetricRegistry metricRegistry;
@Bean
public KafkaReceiver receiver(
@Value("${elasticsearch.index}") final String index,
@Value("${elasticsearch.type}") final String type,
final RestHighLevelClient client, final EspnMetricRegistry metricRegistry) {
return new KafkaReceiver(index, type, metricRegistry, client);
}
@Bean
public ConcurrentKafkaListenerContainerFactory<String, ESPNEntity> kafkaListenerContainerFactory() {
ConcurrentKafkaListenerContainerFactory<String, ESPNEntity> factory =
new ConcurrentKafkaListenerContainerFactory<>();
factory.setConsumerFactory(kafkaConsumerFactory());
factory.setBatchListener(true);
factory.setConcurrency(kafkaConcurrencyLevel);
return factory;
}
@Bean
public ConsumerFactory<String, ESPNEntity> kafkaConsumerFactory() {
final Deserializer<String> key = new StringDeserializer();
final Deserializer<ESPNEntity> value = new ESPNEntitySerde(new ESPNEntityConverter());
return new DefaultKafkaConsumerFactory<>(consumerConfigs(), key, value);
}
@Bean
public Map<String, Object> consumerConfigs() {
Map<String, Object> props = new HashMap<>();
props.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, bootstrapServers);
props.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
props.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, ESPNEntitySerde.class);
props.put(ConsumerConfig.GROUP_ID_CONFIG, kafkaGroupId);
props.put(ConsumerConfig.MAX_POLL_RECORDS_CONFIG, kafkaMaxPollRecords);
props.put(ConsumerConfig.AUTO_OFFSET_RESET_CONFIG, "earliest");
return props;
}
}
因此,我不知道是什么導致了該錯誤或丟失了什么,但是當我部署到aws時,堆棧卡住了,因為當它到達springboot的一部分時,它會失敗並拋出以下錯誤:
2018-12-19 16:28:45.381 ERROR 43 --- [ main] osboot.SpringApplication : Application startup failed
java.lang.IllegalArgumentException: Could not resolve placeholder 'elasticsearch.port' in value "${elasticsearch.port}"
您需要注冊您的屬性文件。 在@Component注釋下添加以下行:
@PropertySource("classpath:propelr.properties")
所以它應該看起來像這樣:
@Component
@PropertySource("classpath:propelr.properties")
final class ElasticSearchClientFactory extends
AbstractFactoryBean<RestHighLevelClient> {
private final RestHighLevelClient client;
ElasticSearchClientFactory(
final @Value("${elasticsearch.hostname}") String hostname,
final @Value("${elasticsearch.port}") int port,
final @Value("${elasticsearch.protocol}") String protocol
) {
client = new RestHighLevelClient(RestClient.builder(new
HttpHost(hostname, port, protocol)));
}
@Override
public Class<?> getObjectType() {
return RestHighLevelClient.class;
}
@Override
protected RestHighLevelClient createInstance() throws Exception {
return client;
}
@Override
public void destroy() throws Exception {
if (Objects.nonNull(client)) {
client.close();
}
}
}
編輯靜態屬性源占位符
@Bean
public static PropertySourcesPlaceholderConfigurer propertyConfigInDev() {
return new PropertySourcesPlaceholderConfigurer();
}
正如@Rafal所指,您應該指定@propertySource(“ classpath:application.properties”),以提供正確的路徑以及要讀取其屬性的文件名。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.