org.graylog2.plugin.KafkaJournalConfiguration Maven / Gradle / Ivy
/*
* Copyright (C) 2020 Graylog, Inc.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the Server Side Public License, version 1,
* as published by MongoDB, Inc.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* Server Side Public License for more details.
*
* You should have received a copy of the Server Side Public License
* along with this program. If not, see
* .
*/
package org.graylog2.plugin;
import com.github.joschi.jadconfig.Parameter;
import com.github.joschi.jadconfig.util.Size;
import org.graylog2.configuration.PathConfiguration;
import org.joda.time.Duration;
import java.nio.file.Path;
public class KafkaJournalConfiguration extends PathConfiguration {
public KafkaJournalConfiguration() { }
@Parameter(value = "message_journal_dir", required = true)
private Path messageJournalDir = DEFAULT_DATA_DIR.resolve("journal");
@Parameter("message_journal_segment_size")
private Size messageJournalSegmentSize = Size.megabytes(100L);
@Parameter("message_journal_segment_age")
private Duration messageJournalSegmentAge = Duration.standardHours(1L);
@Parameter("message_journal_max_size")
private Size messageJournalMaxSize = Size.gigabytes(5L);
@Parameter("message_journal_max_age")
private Duration messageJournalMaxAge = Duration.standardHours(12L);
@Parameter("message_journal_flush_interval")
private long messageJournalFlushInterval = 1_000_000L;
@Parameter("message_journal_flush_age")
private Duration messageJournalFlushAge = Duration.standardMinutes(1L);
public Path getMessageJournalDir() {
return messageJournalDir;
}
public Size getMessageJournalSegmentSize() {
return messageJournalSegmentSize;
}
public Duration getMessageJournalSegmentAge() {
return messageJournalSegmentAge;
}
public Duration getMessageJournalMaxAge() {
return messageJournalMaxAge;
}
public Size getMessageJournalMaxSize() {
return messageJournalMaxSize;
}
public long getMessageJournalFlushInterval() {
return messageJournalFlushInterval;
}
public Duration getMessageJournalFlushAge() {
return messageJournalFlushAge;
}
}