Package com.impetus.kundera.ycsb.runner

Source Code of com.impetus.kundera.ycsb.runner.HBaseRunner

/**
*
*/
package com.impetus.kundera.ycsb.runner;

import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

import org.apache.commons.configuration.Configuration;

import com.impetus.kundera.ycsb.utils.HBaseOperationUtils;
import com.impetus.kundera.ycsb.utils.MailUtils;

/**
* @author vivek.mishra
*
*/
public class HBaseRunner extends YCSBRunner
{
    private String startHBaseServerCommand;

    private String stopHBaseServerCommand;

    public HBaseRunner(String propertyFile, Configuration config)
    {
        super(propertyFile, config);
        String server = config.getString("server.location");
        this.startHBaseServerCommand = server+"start-hbase.sh";
        this.stopHBaseServerCommand = "/root/software/stopServers.sh";
    }

    /*
     * (non-Javadoc)
     *
     * @see com.impetus.kundera.ycsb.runner.YCSBRunner#startServer(boolean,
     * java.lang.Runtime)
     */
    @Override
    public void startServer(boolean performDelete, Runtime runTime)
    {
        if (performDelete)
        {
            try
            {
                HBaseOperationUtils.startHBaseServer(runTime, startHBaseServerCommand);
                HBaseOperationUtils utils = new HBaseOperationUtils();
                utils.createTable(schema, columnFamilyOrTable);
            }
            catch (IOException e)
            {
                e.printStackTrace();
            }
            catch (InterruptedException e)
            {
                e.printStackTrace();
            }
        }
    }

    /*
     * (non-Javadoc)
     *
     * @see
     * com.impetus.kundera.ycsb.runner.YCSBRunner#stopServer(java.lang.Runtime)
     */
    @Override
    public void stopServer(Runtime runTime)
    {
        try
        {
            HBaseOperationUtils.stopHBaseServer(stopHBaseServerCommand, runTime);
        }
        catch (IOException e)
        {
            e.printStackTrace();
        }
        catch (InterruptedException e)
        {
            e.printStackTrace();
        }
    }

    /*
     * (non-Javadoc)
     *
     * @see com.impetus.kundera.ycsb.runner.YCSBRunner#sendMail()
     */
    @Override
    protected void sendMail()
    {
        Map<String, Double> delta = new HashMap<String, Double>();

        double kunderaHBaseToNativeDelta = ((timeTakenByClient.get(clients[1]).doubleValue() - timeTakenByClient.get(
                clients[0]).doubleValue())
                / timeTakenByClient.get(clients[1]).doubleValue() * 100);
        delta.put("kunderaHBaseToNativeDelta", kunderaHBaseToNativeDelta);

        if (kunderaHBaseToNativeDelta > 8.00)
        {
            MailUtils.sendMail(delta, isUpdate ? "update" : runType, "hbase");
        } else
        {
            MailUtils.sendPositiveEmail(delta, isUpdate ? "update" : runType, "hbase");
           
        }
    }

}
TOP

Related Classes of com.impetus.kundera.ycsb.runner.HBaseRunner

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.