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

com.alibaba.druid.support.profile.ProfileStat Maven / Gradle / Ivy

There is a newer version: 1.2.24
Show newest version
/*
 * Copyright 1999-2011 Alibaba Group Holding Ltd.
 *
 * 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.alibaba.druid.support.profile;

import java.util.ArrayList;
import java.util.Collections;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;

public class ProfileStat {

    private Map entries = new LinkedHashMap(4);

    private ReadWriteLock                          lock    = new ReentrantReadWriteLock();

    public Map getEntries() {
        return entries;
    }

    public void record(Map requestStatsMap) {
        if (requestStatsMap == null) {
            return;
        }

        for (Map.Entry entry : requestStatsMap.entrySet()) {
            ProfileEntryKey entryKey = entry.getKey();
            ProfileEntryReqStat reqEntryStat = entry.getValue();

            ProfileEntryStat entryStat = getProfileEntry(entryKey);

            entryStat.addExecuteCount(reqEntryStat.getExecuteCount());
            entryStat.addExecuteTimeNanos(reqEntryStat.getExecuteTimeNanos());
        }
    }

    private ProfileEntryStat getProfileEntry(ProfileEntryKey entryKey) {

        lock.readLock().lock();
        try {
            ProfileEntryStat entryStat = entries.get(entryKey);
            if (entryStat != null) {
                return entryStat;
            }
        } finally {
            lock.readLock().unlock();
        }

        lock.writeLock().lock();
        try {
            ProfileEntryStat entryStat = entries.get(entryKey);
            if (entryStat == null) {
                entries.put(entryKey, new ProfileEntryStat());
                entryStat = entries.get(entryKey);
            }
            return entryStat;
        } finally {
            lock.writeLock().unlock();
        }
    }

    public List> getStatData() {

        List statValueList = getStatValue(false);
        
        int size = statValueList.size();
        List> list = new ArrayList>(size);
        for (int i = 0; i < size; ++i) {
            list.add(statValueList.get(i).getData());
        }

        return list;
    }

    public List getStatValue(boolean reset) {
        List list = new ArrayList();

        lock.readLock().lock();
        try {
            for (Map.Entry entry : entries.entrySet()) {
                ProfileEntryStatValue entryStatValue = entry.getValue().getValue(reset);
                entry.getKey().fillValue(entryStatValue);

                list.add(entryStatValue);
            }
        } finally {
            lock.readLock().unlock();
        }

        Collections.reverse(list);

        return list;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy