org.graylog2.plugin.BaseConfiguration 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.ValidationException;
import com.github.joschi.jadconfig.ValidatorMethod;
import com.github.joschi.jadconfig.util.Duration;
import com.github.joschi.jadconfig.validators.PositiveDurationValidator;
import com.github.joschi.jadconfig.validators.PositiveIntegerValidator;
import com.github.joschi.jadconfig.validators.StringNotBlankValidator;
import com.lmax.disruptor.BlockingWaitStrategy;
import com.lmax.disruptor.BusySpinWaitStrategy;
import com.lmax.disruptor.SleepingWaitStrategy;
import com.lmax.disruptor.WaitStrategy;
import com.lmax.disruptor.YieldingWaitStrategy;
import org.apache.commons.lang3.StringUtils;
import org.graylog2.configuration.PathConfiguration;
import org.graylog2.shared.messageq.MessageQueueModule;
import org.graylog2.utilities.ProxyHostsPattern;
import org.graylog2.utilities.ProxyHostsPatternConverter;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.net.URI;
import static org.graylog2.shared.messageq.MessageQueueModule.DISK_JOURNAL_MODE;
import static org.graylog2.shared.messageq.MessageQueueModule.NOOP_JOURNAL_MODE;
@SuppressWarnings("FieldMayBeFinal")
public abstract class BaseConfiguration extends PathConfiguration {
private static final Logger LOG = LoggerFactory.getLogger(BaseConfiguration.class);
@Parameter(value = "shutdown_timeout", validator = PositiveIntegerValidator.class)
protected int shutdownTimeout = 30000;
@Parameter(value = "processbuffer_processors", required = true, validator = PositiveIntegerValidator.class)
private int processBufferProcessors = 5;
@Parameter(value = "processor_wait_strategy", required = true)
private String processorWaitStrategy = "blocking";
@Parameter(value = "ring_size", required = true, validator = PositiveIntegerValidator.class)
private int ringSize = 65536;
@Parameter(value = "inputbuffer_ring_size", required = true, validator = PositiveIntegerValidator.class)
private int inputBufferRingSize = 65536;
@Parameter(value = "inputbuffer_wait_strategy", required = true)
private String inputBufferWaitStrategy = "blocking";
@Parameter(value = "async_eventbus_processors")
private int asyncEventbusProcessors = 2;
@Parameter(value = "udp_recvbuffer_sizes", required = true, validator = PositiveIntegerValidator.class)
private int udpRecvBufferSizes = 1048576;
@Parameter("message_journal_enabled")
private boolean messageJournalEnabled = true;
@Parameter(value = "message_journal_mode")
private String messageJournalMode = MessageQueueModule.DISK_JOURNAL_MODE;
@Parameter("inputbuffer_processors")
private int inputbufferProcessors = 2;
@Parameter("message_recordings_enable")
private boolean messageRecordingsEnable = false;
@Parameter("disable_native_system_stats_collector")
private boolean disableNativeSystemStatsCollector = false;
@Parameter(value = "http_proxy_uri")
private URI httpProxyUri;
@Parameter(value = "http_non_proxy_hosts", converter = ProxyHostsPatternConverter.class)
private ProxyHostsPattern httpNonProxyHostsPattern;
@Parameter(value = "http_connect_timeout", validator = PositiveDurationValidator.class)
private Duration httpConnectTimeout = Duration.seconds(5L);
@Parameter(value = "http_write_timeout", validator = PositiveDurationValidator.class)
private Duration httpWriteTimeout = Duration.seconds(10L);
@Parameter(value = "http_read_timeout", validator = PositiveDurationValidator.class)
private Duration httpReadTimeout = Duration.seconds(10L);
@Parameter(value = "installation_source", validator = StringNotBlankValidator.class)
private String installationSource = "unknown";
@Parameter(value = "proxied_requests_thread_pool_size", required = true, validator = PositiveIntegerValidator.class)
private int proxiedRequestsThreadPoolSize = 64;
@Parameter(value = "proxied_requests_default_call_timeout", required = true, validator = PositiveDurationValidator.class)
private Duration proxiedRequestsDefaultCallTimeout = Duration.seconds(5);
public int getProcessBufferProcessors() {
return processBufferProcessors;
}
private WaitStrategy getWaitStrategy(String waitStrategyName, String configOptionName) {
switch (waitStrategyName) {
case "sleeping":
return new SleepingWaitStrategy();
case "yielding":
return new YieldingWaitStrategy();
case "blocking":
return new BlockingWaitStrategy();
case "busy_spinning":
return new BusySpinWaitStrategy();
default:
LOG.warn("Invalid setting for [{}]:"
+ " Falling back to default: BlockingWaitStrategy.", configOptionName);
return new BlockingWaitStrategy();
}
}
public WaitStrategy getProcessorWaitStrategy() {
return getWaitStrategy(processorWaitStrategy, "processbuffer_wait_strategy");
}
public int getRingSize() {
return ringSize;
}
public int getInputBufferRingSize() {
return inputBufferRingSize;
}
public WaitStrategy getInputBufferWaitStrategy() {
return getWaitStrategy(inputBufferWaitStrategy, "inputbuffer_wait_strategy");
}
public int getAsyncEventbusProcessors() {
return asyncEventbusProcessors;
}
public boolean isMessageJournalEnabled() {
return messageJournalEnabled;
}
public void setMessageJournalEnabled(boolean messageJournalEnabled) {
this.messageJournalEnabled = messageJournalEnabled;
}
public int getInputbufferProcessors() {
return inputbufferProcessors;
}
public int getShutdownTimeout() {
return shutdownTimeout;
}
public int getUdpRecvBufferSizes() {
return udpRecvBufferSizes;
}
public boolean isMessageRecordingsEnabled() {
return messageRecordingsEnable;
}
public boolean isDisableNativeSystemStatsCollector() {
return disableNativeSystemStatsCollector;
}
public URI getHttpProxyUri() {
return httpProxyUri;
}
public ProxyHostsPattern getHttpNonProxyHostsPattern() {
return httpNonProxyHostsPattern;
}
public Duration getHttpConnectTimeout() {
return httpConnectTimeout;
}
public Duration getHttpWriteTimeout() {
return httpWriteTimeout;
}
public Duration getHttpReadTimeout() {
return httpReadTimeout;
}
public String getInstallationSource() {
return installationSource;
}
/**
* Journal mode will be "noop" if the journal is disabled or the configured journal mode otherwise.
*/
public String getMessageJournalMode() {
return messageJournalEnabled ? messageJournalMode : NOOP_JOURNAL_MODE;
}
@ValidatorMethod
public void validateJournalMode() throws ValidationException {
if (!messageJournalEnabled) {
return;
}
// the noop implementation is not fully functional and relies on the journal mode being disabled because
// otherwise message would be lost.
if (messageJournalMode.equals(NOOP_JOURNAL_MODE)) {
throw new ValidationException("Setting message journal mode to <" + NOOP_JOURNAL_MODE +
"> without disabling the message journal is not supported.");
}
if (StringUtils.isBlank(messageJournalMode)) {
throw new ValidationException("Journal mode (e.g. <" + DISK_JOURNAL_MODE + ">) needs to be " +
"provided when the journal is enabled.");
}
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy