方法采样执行

控制数据采样频率工具类

@Component
public class SamplingHelper implements InitializingBean {

    public static final long MAX_COUNT = 100000L;

    private Map<SamplingItem, AtomicInteger> counterMap = new EnumMap<>(SamplingItem.class);

    @Override
    public void afterPropertiesSet() {
        counterMap = Arrays.stream(SamplingItem.values())
                .collect(Collectors.toMap(
                        o -> o,
                        o -> new AtomicInteger(0)
                ));
    }

    public void doSample(SamplingItem samplingItem, Runnable runnable) {
        this.doSample(samplingItem, () -> {
            runnable.run();
            return null;
        });
    }

    public <T> T doSample(SamplingItem samplingItem, Supplier<T> supplier) {
        boolean allowSampling = VivoConfigManager.getBoolean("ALLOW_SAMPLE_COLLECTION", false);
        if (!allowSampling) {
            return null;
        }

        AtomicInteger counter = counterMap.get(samplingItem);
        if (counter == null) {
            return null;
        }

        int count = counter.incrementAndGet();
        try {
            boolean accept = count % samplingItem.samplingRate == 0;
            if (accept) {
                return supplier.get();
            } else {
                return null;
            }
        } finally {
            // 当累加到一定数量的时候重置,避免溢出
            if (count > MAX_COUNT) {
                counter.set(0);
            }
        }
    }

    public enum SamplingItem {
        /**
         * 采样类型
         */
        CONNECTION(15),
        TIME_COLLECT(20);

        private final int samplingRate;

        SamplingItem(int samplingRate) {
            this.samplingRate = samplingRate;
        }
    }
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容