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

com.github.dennisit.vplus.data.metric.pipeline.LoggerPipeline Maven / Gradle / Ivy

/*--------------------------------------------------------------------------
 *  Copyright (c) 2010-2020, Elon.su All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are
 * met:
 *
 * Redistributions of source code must retain the above copyright notice,
 * this list of conditions and the following disclaimer.
 * Redistributions in binary form must reproduce the above copyright
 * notice, this list of conditions and the following disclaimer in the
 * documentation and/or other materials provided with the distribution.
 * Neither the name of the elon developer nor the names of its
 * contributors may be used to endorse or promote products derived from
 * this software without specific prior written permission.
 * Author: Elon.su, you can also mail [email protected]
 *--------------------------------------------------------------------------
 */
package com.github.dennisit.vplus.data.metric.pipeline;

import com.github.dennisit.vplus.data.metric.JMetricCollector;
import com.github.dennisit.vplus.data.metric.JMetricPipeline;
import com.google.common.collect.Maps;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.Map;
import java.util.Optional;

/**
 * @author Elon.su
 */
public class LoggerPipeline implements JMetricPipeline {

    /**
     * 日志标记监控名称:metric
     */
    public static final Logger LOG = LoggerFactory.getLogger("metric");

    @Override
    public void initialized() {

    }

    @Override
    public void pipeline(JMetricCollector collector, String key, Object value, long milliseconds) {
        if(null == collector){
            return;
        }
        if(StringUtils.isBlank(key) || null == value){
            LOG.info("{}:{},time={}", key, String.valueOf(value), milliseconds);
        }
    }

    @Override
    public void pipeline(JMetricCollector collector, Map metrics, long milliseconds) {
        if(null == collector){
            return;
        }
        Optional.ofNullable(metrics).orElse(Maps.newHashMap()).forEach((k, v) -> {
            LOG.info("{}:{},time={}", k, String.valueOf(v), milliseconds);
        });
    }


    @Override
    public void destroyed() {

    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy