Package org.voltdb.sysprocs

Source Code of org.voltdb.sysprocs.EvictTuples

package org.voltdb.sysprocs;

import java.util.List;
import java.util.Map;

import org.apache.log4j.Logger;
import org.voltdb.DependencySet;
import org.voltdb.ParameterSet;
import org.voltdb.ProcInfo;
import org.voltdb.VoltSystemProcedure;
import org.voltdb.VoltTable;
import org.voltdb.VoltTable.ColumnInfo;
import org.voltdb.VoltType;
import org.voltdb.catalog.Table;
import org.voltdb.jni.ExecutionEngine;
import org.voltdb.types.TimestampType;

import edu.brown.hstore.PartitionExecutor;
import edu.brown.logging.LoggerUtil;
import edu.brown.logging.LoggerUtil.LoggerBoolean;
import edu.brown.profilers.AntiCacheManagerProfiler;
import edu.brown.profilers.AntiCacheManagerProfiler.EvictionHistory;

/**
* Special system procedure for evicting tuples using the anti-cache feature
*/
@ProcInfo(
    partitionParam = 0,
    singlePartition = true
)
public class EvictTuples extends VoltSystemProcedure {
    private static final Logger LOG = Logger.getLogger(EvictTuples.class);
    private static final LoggerBoolean debug = new LoggerBoolean();
    static {
        LoggerUtil.attachObserver(LOG, debug);
    }

    public static final ColumnInfo ResultsColumns[] = {
        new ColumnInfo(VoltSystemProcedure.CNAME_HOST_ID, VoltSystemProcedure.CTYPE_ID),
        new ColumnInfo("HOSTNAME", VoltType.STRING),
        new ColumnInfo("PARTITION", VoltType.INTEGER),
        new ColumnInfo("TABLE", VoltType.STRING),
        new ColumnInfo("ANTICACHE_TUPLES_EVICTED", VoltType.INTEGER),
        new ColumnInfo("ANTICACHE_BLOCKS_EVICTED", VoltType.INTEGER),
        new ColumnInfo("ANTICACHE_BYTES_EVICTED", VoltType.BIGINT),
        new ColumnInfo("CREATED", VoltType.TIMESTAMP),
    };
   
    @Override
    public void initImpl() {
        executor.registerPlanFragment(SysProcFragmentId.PF_antiCacheEviction, this);
    }

    @Override
    public DependencySet executePlanFragment(Long txn_id,
                                             Map<Integer, List<VoltTable>> dependencies,
                                             int fragmentId,
                                             ParameterSet params,
                                             PartitionExecutor.SystemProcedureExecutionContext context) {
        assert(fragmentId == SysProcFragmentId.PF_antiCacheEviction);
        throw new IllegalAccessError("Invalid invocation of " + this.getClass() + ".executePlanFragment()");
    }
   
    public VoltTable[] run(int partition, String tableNames[], String childrenTableNames[], long blockSizes[], int numBlocks[]) {
        ExecutionEngine ee = executor.getExecutionEngine();
        assert(tableNames.length == blockSizes.length);
        // LOG.info("reached evict tuples");
       
        // PROFILER
        AntiCacheManagerProfiler profiler = null;
        long start = -1;
        if (hstore_conf.site.anticache_profiling) {
            start = System.currentTimeMillis();
            profiler = hstore_site.getAntiCacheManager().getDebugContext().getProfiler(this.partitionId);
            profiler.eviction_time.start();
        }

        // Check Input
        if (tableNames.length == 0) {
            throw new VoltAbortException("No tables to evict were given");
        }
        Table tables[] = new Table[tableNames.length];
        Table childTables[] = new Table[tableNames.length];
        for (int i = 0; i < tableNames.length; i++) {
    //    LOG.info("reached tables for loop");
            tables[i] = catalogContext.database.getTables().getIgnoreCase(tableNames[i]);
            if (tables[i] == null) {
                String msg = String.format("Unknown table '%s'", tableNames[i]);
          //      LOG.info("abort due to null table");
                throw new VoltAbortException(msg);
            }
            else if (tables[i].getEvictable() == false) {
                String msg = String.format("Trying to evict tuples from table '%s' but it is not marked as evictable", tables[i].getName());
            //    LOG.info("abort due to non evictanle table");
                throw new VoltAbortException(msg);
            }
            else if (blockSizes[i] <= 0) {
                String msg = String.format("Invalid block eviction size '%d' for table '%s'", blockSizes[i], tables[i].getName());
            //    LOG.info("abort due to blocksize < 0");
                throw new VoltAbortException(msg);
            }
            else if (numBlocks[i] <= 0) {
                String msg = String.format("Invalid number of blocks to evict '%d' for table '%s'", numBlocks[i], tables[i].getName());
            //    LOG.info("abort due to num blocks < 0");
                throw new VoltAbortException(msg);
            }
        } // FOR
       
        // TODO: Instead of sending down requests one at a time per table, it will
        //       be much faster if we just send down the entire batch
        final VoltTable allResults = new VoltTable(ResultsColumns);
        long totalTuplesEvicted = 0;
        long totalBlocksEvicted = 0;
        long totalBytesEvicted = 0;
        for (int i = 0; i < tableNames.length; i++) {
        //LOG.info("reached batching loop");
            if (debug.val)
                LOG.debug(String.format("Evicting %d blocks of blockSize %d",
                          numBlocks[i], blockSizes[i]));
            VoltTable vt = null;
            if (debug.val)
                LOG.debug("****************"+hstore_conf.site.anticache_batching);
            if (hstore_conf.site.anticache_batching == true){
                if (debug.val) LOG.info("reached here!!!!!");
                if (childrenTableNames.length!=0 && !childrenTableNames[i].isEmpty()){
                    childTables[i] = catalogContext.database.getTables().getIgnoreCase(childrenTableNames[i]);
                    vt = ee.antiCacheEvictBlockInBatch(tables[i], childTables[i], blockSizes[i], numBlocks[i]);                   
                } else {
                    vt = ee.antiCacheEvictBlock(tables[i], blockSizes[i], numBlocks[i]);
                }
            }else{
                vt = ee.antiCacheEvictBlock(tables[i], blockSizes[i], numBlocks[i]);   
            }
           
            boolean adv = vt.advanceRow();
           
            if (!adv) {
                String msg = String.format("antiCacheEvictBlock failed to return any rows.");
                throw new VoltAbortException(msg);
            }
//            assert(adv);
            long tuplesEvicted = vt.getLong("ANTICACHE_TUPLES_EVICTED");
            long blocksEvicted = vt.getLong("ANTICACHE_BLOCKS_EVICTED");
            long bytesEvicted = vt.getLong("ANTICACHE_BYTES_EVICTED");
            Object row[] = {
                    this.hstore_site.getSiteId(),
                    this.hstore_site.getSiteName(),
                    this.executor.getPartitionId(),
                    vt.getString("TABLE_NAME"),
                    tuplesEvicted,
                    blocksEvicted,
                    bytesEvicted,
                    new TimestampType()
            };
            allResults.addRow(row);
            totalTuplesEvicted += tuplesEvicted;
            totalBlocksEvicted += blocksEvicted;
            totalBytesEvicted += bytesEvicted;
        } // FOR
       
        // PROFILER
        if (profiler != null) {
            EvictionHistory eh = new EvictionHistory(start,
                                                     System.currentTimeMillis(),
                                                     totalTuplesEvicted,
                                                     totalBlocksEvicted,
                                                     totalBytesEvicted);
            profiler.eviction_history.add(eh);
            profiler.eviction_time.stopIfStarted();
        }
       
        return new VoltTable[]{ allResults };
    }
}
TOP

Related Classes of org.voltdb.sysprocs.EvictTuples

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.