All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.uber.hoodie.config.HoodieMetricsConfig Maven / Gradle / Ivy

There is a newer version: 0.4.7
Show newest version
/*
 * Copyright (c) 2016 Uber Technologies, Inc. ([email protected])
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *          http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.uber.hoodie.config;

import com.uber.hoodie.metrics.MetricsReporterType;

import javax.annotation.concurrent.Immutable;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.util.Properties;

/**
 * Fetch the configurations used by the Metrics system.
 */
@Immutable
public class HoodieMetricsConfig extends DefaultHoodieConfig {

    public final static String METRIC_PREFIX = "hoodie.metrics";
    public final static String METRICS_ON = METRIC_PREFIX + ".on";
    public final static boolean DEFAULT_METRICS_ON = false;
    public final static String METRICS_REPORTER_TYPE = METRIC_PREFIX + ".reporter.type";
    public final static MetricsReporterType DEFAULT_METRICS_REPORTER_TYPE =
        MetricsReporterType.GRAPHITE;

    // Graphite
    public final static String GRAPHITE_PREFIX = METRIC_PREFIX + ".graphite";
    public final static String GRAPHITE_SERVER_HOST = GRAPHITE_PREFIX + ".host";
    public final static String DEFAULT_GRAPHITE_SERVER_HOST = "localhost";

    public final static String GRAPHITE_SERVER_PORT = GRAPHITE_PREFIX + ".port";
    public final static int DEFAULT_GRAPHITE_SERVER_PORT = 4756;

    public final static String GRAPHITE_METRIC_PREFIX = GRAPHITE_PREFIX + ".metric.prefix";

    private HoodieMetricsConfig(Properties props) {
        super(props);
    }

    public static HoodieMetricsConfig.Builder newBuilder() {
        return new Builder();
    }

    public static class Builder {
        private final Properties props = new Properties();

        public Builder fromFile(File propertiesFile) throws IOException {
            FileReader reader = new FileReader(propertiesFile);
            try {
                this.props.load(reader);
                return this;
            } finally {
                reader.close();
            }
        }

        public Builder fromProperties(Properties props) {
            this.props.putAll(props);
            return this;
        }


        public Builder on(boolean metricsOn) {
            props.setProperty(METRICS_ON, String.valueOf(metricsOn));
            return this;
        }

        public Builder withReporterType(String reporterType) {
            props.setProperty(METRICS_REPORTER_TYPE, reporterType);
            return this;
        }

        public Builder toGraphiteHost(String host) {
            props.setProperty(GRAPHITE_SERVER_HOST, host);
            return this;
        }

        public Builder onGraphitePort(int port) {
            props.setProperty(GRAPHITE_SERVER_PORT, String.valueOf(port));
            return this;
        }

        public Builder usePrefix(String prefix) {
            props.setProperty(GRAPHITE_METRIC_PREFIX, prefix);
            return this;
        }

        public HoodieMetricsConfig build() {
            HoodieMetricsConfig config = new HoodieMetricsConfig(props);
            setDefaultOnCondition(props, !props.containsKey(METRICS_ON), METRICS_ON,
                String.valueOf(DEFAULT_METRICS_ON));
            setDefaultOnCondition(props, !props.containsKey(METRICS_REPORTER_TYPE),
                METRICS_REPORTER_TYPE, DEFAULT_METRICS_REPORTER_TYPE.name());
            setDefaultOnCondition(props, !props.containsKey(GRAPHITE_SERVER_HOST),
                GRAPHITE_SERVER_HOST, DEFAULT_GRAPHITE_SERVER_HOST);
            setDefaultOnCondition(props, !props.containsKey(GRAPHITE_SERVER_PORT),
                GRAPHITE_SERVER_PORT, String.valueOf(DEFAULT_GRAPHITE_SERVER_PORT));
            setDefaultOnCondition(props, !props.containsKey(GRAPHITE_SERVER_PORT),
                GRAPHITE_SERVER_PORT, String.valueOf(DEFAULT_GRAPHITE_SERVER_PORT));
            return config;
        }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy