Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
20 commits
Select commit Hold shift + click to select a range
104dc71
fix: Hopefully fixed the build of the cpp-example on windows systems
chrisdutz Aug 17, 2023
0db1a8f
Merge remote-tracking branch 'upstream/master'
chrisdutz Aug 17, 2023
1bdc2cf
Merge remote-tracking branch 'upstream/master'
chrisdutz Aug 18, 2023
0ea9e78
Merge remote-tracking branch 'upstream/master'
chrisdutz Aug 21, 2023
4b79d7a
Merge remote-tracking branch 'upstream/master'
chrisdutz Aug 31, 2023
5e54115
Merge remote-tracking branch 'upstream/master'
chrisdutz Aug 31, 2023
b16c9a0
Merge remote-tracking branch 'upstream/master'
chrisdutz Sep 5, 2023
d162a48
Merge branch 'apache:master' into master
chrisdutz Sep 6, 2023
13ef12e
Merge remote-tracking branch 'upstream/master'
chrisdutz Sep 7, 2023
4f22e11
Merge branch 'apache:master' into master
chrisdutz Sep 8, 2023
bbbf3e3
Merge remote-tracking branch 'upstream/master'
chrisdutz Sep 14, 2023
8a56b00
Merge remote-tracking branch 'upstream/master'
chrisdutz Sep 19, 2023
2ad77a6
Merge remote-tracking branch 'upstream/master'
chrisdutz Oct 17, 2023
383d101
Merge remote-tracking branch 'upstream/master'
chrisdutz Nov 1, 2023
f6f4ac6
Merge remote-tracking branch 'upstream/master'
chrisdutz Nov 7, 2023
e1c6f72
fix: Increase the timeout even more to finally make the build succeed.
chrisdutz Nov 7, 2023
8a18cf3
Merge remote-tracking branch 'upstream/master'
chrisdutz Nov 9, 2023
56fb6de
feat: Make it possible to disable OS-level metrics, that can be causi…
chrisdutz Nov 12, 2023
fffcf0d
feat: Moved the metrics option from the config-node to the common con…
chrisdutz Nov 12, 2023
f0de474
feat: Made sure the System directories are not initialized in case of…
chrisdutz Nov 12, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,8 @@
import org.apache.iotdb.commons.concurrent.ThreadModule;
import org.apache.iotdb.commons.concurrent.ThreadName;
import org.apache.iotdb.commons.concurrent.ThreadPoolMetrics;
import org.apache.iotdb.commons.conf.CommonConfig;
import org.apache.iotdb.commons.conf.CommonDescriptor;
import org.apache.iotdb.commons.conf.IoTDBConstant;
import org.apache.iotdb.commons.exception.StartupException;
import org.apache.iotdb.commons.service.JMXService;
Expand Down Expand Up @@ -260,8 +262,12 @@ private void setUpMetricService() throws StartupException {
MetricService.getInstance().addMetricSet(new JvmMetrics());
MetricService.getInstance().addMetricSet(new LogbackMetrics());
MetricService.getInstance().addMetricSet(new ProcessMetrics());
MetricService.getInstance().addMetricSet(new DiskMetrics(IoTDBConstant.CN_ROLE));
MetricService.getInstance().addMetricSet(new NetMetrics(IoTDBConstant.CN_ROLE));
// Only enable OS-level metrics, if this is wanted.
CommonConfig commonConfig = CommonDescriptor.getInstance().getConfig();
if (commonConfig.isOsMetricsEnabled()) {
MetricService.getInstance().addMetricSet(new DiskMetrics(IoTDBConstant.CN_ROLE));
MetricService.getInstance().addMetricSet(new NetMetrics(IoTDBConstant.CN_ROLE));
}
MetricService.getInstance().addMetricSet(JvmGcMonitorMetrics.getInstance());
MetricService.getInstance().addMetricSet(ClientManagerMetrics.getInstance());
MetricService.getInstance().addMetricSet(ThreadPoolMetrics.getInstance());
Expand All @@ -270,11 +276,16 @@ private void setUpMetricService() throws StartupException {
}

private void initSystemMetrics() {
ArrayList<String> diskDirs = new ArrayList<>();
diskDirs.add(CONF.getSystemDir());
diskDirs.add(CONF.getConsensusDir());
SystemMetrics.getInstance().setDiskDirs(diskDirs);
MetricService.getInstance().addMetricSet(SystemMetrics.getInstance());
// Only enable OS-level metrics, if this is wanted.
CommonConfig commonConfig = CommonDescriptor.getInstance().getConfig();
if (commonConfig.isOsMetricsEnabled()) {
ArrayList<String> diskDirs = new ArrayList<>();
diskDirs.add(CONF.getSystemDir());
diskDirs.add(CONF.getConsensusDir());
SystemMetrics systemMetrics = SystemMetrics.getInstance();
systemMetrics.setDiskDirs(diskDirs);
MetricService.getInstance().addMetricSet(systemMetrics);
}
}

private void initCpuMetrics() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@

import org.apache.iotdb.common.rpc.thrift.TEndPoint;
import org.apache.iotdb.commons.client.property.ClientPoolProperty.DefaultProperty;
import org.apache.iotdb.commons.conf.CommonConfig;
import org.apache.iotdb.commons.conf.CommonDescriptor;
import org.apache.iotdb.commons.conf.IoTDBConstant;
import org.apache.iotdb.commons.utils.FileUtils;
Expand Down Expand Up @@ -1287,14 +1288,18 @@ void reloadDataDirs(String[][] tierDataDirs) throws LoadConfigurationException {
}

void reloadSystemMetrics() {
ArrayList<String> diskDirs = new ArrayList<>();
diskDirs.add(IoTDBDescriptor.getInstance().getConfig().getSystemDir());
diskDirs.add(IoTDBDescriptor.getInstance().getConfig().getConsensusDir());
diskDirs.addAll(Arrays.asList(IoTDBDescriptor.getInstance().getConfig().getDataDirs()));
diskDirs.addAll(Arrays.asList(CommonDescriptor.getInstance().getConfig().getWalDirs()));
diskDirs.add(CommonDescriptor.getInstance().getConfig().getSyncDir());
diskDirs.add(IoTDBDescriptor.getInstance().getConfig().getSortTmpDir());
SystemMetrics.getInstance().setDiskDirs(diskDirs);
// Only enable OS-level metrics, if this is wanted.
CommonConfig commonConfig = CommonDescriptor.getInstance().getConfig();
if (commonConfig.isOsMetricsEnabled()) {
ArrayList<String> diskDirs = new ArrayList<>();
diskDirs.add(IoTDBDescriptor.getInstance().getConfig().getSystemDir());
diskDirs.add(IoTDBDescriptor.getInstance().getConfig().getConsensusDir());
diskDirs.addAll(Arrays.asList(IoTDBDescriptor.getInstance().getConfig().getDataDirs()));
diskDirs.addAll(Arrays.asList(CommonDescriptor.getInstance().getConfig().getWalDirs()));
diskDirs.add(CommonDescriptor.getInstance().getConfig().getSyncDir());
diskDirs.add(IoTDBDescriptor.getInstance().getConfig().getSortTmpDir());
SystemMetrics.getInstance().setDiskDirs(diskDirs);
}
}

// if IOTDB_DATA_HOME is not set, then we keep dataHomeDir prefix being the same with IOTDB_HOME
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
import org.apache.iotdb.common.rpc.thrift.TNodeResource;
import org.apache.iotdb.commons.client.exception.ClientManagerException;
import org.apache.iotdb.commons.concurrent.IoTDBDefaultThreadExceptionHandler;
import org.apache.iotdb.commons.conf.CommonConfig;
import org.apache.iotdb.commons.conf.CommonDescriptor;
import org.apache.iotdb.commons.conf.IoTDBConstant;
import org.apache.iotdb.commons.exception.StartupException;
Expand Down Expand Up @@ -618,7 +619,8 @@ private void setUpMetricService() throws StartupException {
}
MetricService.getInstance().startInternalReporter();
// bind predefined metrics
DataNodeMetricsHelper.bind();
CommonConfig commonConfig = CommonDescriptor.getInstance().getConfig();
DataNodeMetricsHelper.bind(commonConfig.isOsMetricsEnabled());
}

public static TDataNodeLocation generateDataNodeLocation() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -52,19 +52,22 @@

public class DataNodeMetricsHelper {
/** Bind predefined metric sets into DataNode. */
public static void bind() {
public static void bind(boolean enableOsMetrics) {
MetricService.getInstance().addMetricSet(new UpTimeMetrics());
MetricService.getInstance().addMetricSet(new JvmMetrics());
MetricService.getInstance().addMetricSet(ThreadPoolMetrics.getInstance());
MetricService.getInstance().addMetricSet(new LogbackMetrics());
MetricService.getInstance().addMetricSet(FileMetrics.getInstance());
MetricService.getInstance().addMetricSet(CompactionMetrics.getInstance());
MetricService.getInstance().addMetricSet(new ProcessMetrics());
MetricService.getInstance().addMetricSet(new DiskMetrics(IoTDBConstant.DN_ROLE));
MetricService.getInstance().addMetricSet(new NetMetrics(IoTDBConstant.DN_ROLE));
// Only enable OS-level metrics, if this is wanted.
if (enableOsMetrics) {
MetricService.getInstance().addMetricSet(new DiskMetrics(IoTDBConstant.DN_ROLE));
MetricService.getInstance().addMetricSet(new NetMetrics(IoTDBConstant.DN_ROLE));
}
MetricService.getInstance().addMetricSet(ClientManagerMetrics.getInstance());
initCpuMetrics();
initSystemMetrics();
initSystemMetrics(enableOsMetrics);
MetricService.getInstance().addMetricSet(WritingMetrics.getInstance());

// bind query related metrics
Expand All @@ -87,16 +90,20 @@ public static void bind() {
MetricService.getInstance().addMetricSet(PipeMetrics.getInstance());
}

private static void initSystemMetrics() {
ArrayList<String> diskDirs = new ArrayList<>();
diskDirs.add(IoTDBDescriptor.getInstance().getConfig().getSystemDir());
diskDirs.add(IoTDBDescriptor.getInstance().getConfig().getConsensusDir());
diskDirs.addAll(Arrays.asList(IoTDBDescriptor.getInstance().getConfig().getDataDirs()));
diskDirs.addAll(Arrays.asList(CommonDescriptor.getInstance().getConfig().getWalDirs()));
diskDirs.add(CommonDescriptor.getInstance().getConfig().getSyncDir());
diskDirs.add(IoTDBDescriptor.getInstance().getConfig().getSortTmpDir());
SystemMetrics.getInstance().setDiskDirs(diskDirs);
MetricService.getInstance().addMetricSet(SystemMetrics.getInstance());
private static void initSystemMetrics(boolean enableOsMetrics) {
// Only enable OS-level metrics, if this is wanted.
if (enableOsMetrics) {
ArrayList<String> diskDirs = new ArrayList<>();
diskDirs.add(IoTDBDescriptor.getInstance().getConfig().getSystemDir());
diskDirs.add(IoTDBDescriptor.getInstance().getConfig().getConsensusDir());
diskDirs.addAll(Arrays.asList(IoTDBDescriptor.getInstance().getConfig().getDataDirs()));
diskDirs.addAll(Arrays.asList(CommonDescriptor.getInstance().getConfig().getWalDirs()));
diskDirs.add(CommonDescriptor.getInstance().getConfig().getSyncDir());
diskDirs.add(IoTDBDescriptor.getInstance().getConfig().getSortTmpDir());
SystemMetrics systemMetrics = SystemMetrics.getInstance();
systemMetrics.setDiskDirs(diskDirs);
MetricService.getInstance().addMetricSet(systemMetrics);
}
}

private static void initCpuMetrics() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -214,6 +214,12 @@ public class CommonConfig {
// time in nanosecond precision when starting up
private final long startUpNanosecond = System.nanoTime();

/**
* Configures, if OS-level metrics should be enabled. OS-level metrics can cause problems in some
* environments
*/
private boolean osMetricsEnabled = true;

CommonConfig() {
// Empty constructor
}
Expand Down Expand Up @@ -862,4 +868,12 @@ public void setDeviceLimitThreshold(long deviceLimitThreshold) {
public long getStartUpNanosecond() {
return startUpNanosecond;
}

public boolean isOsMetricsEnabled() {
return osMetricsEnabled;
}

public void setOsMetricsEnabled(boolean osMetricsEnabled) {
this.osMetricsEnabled = osMetricsEnabled;
}
}