CommandExcutor.java 2.52 KB
package com.sitech.ismp.check;

import javax.management.MBeanServer;
import javax.management.ObjectName;

import com.sitech.base.Config;
import com.sitech.util.mq.JMSSender;
import org.apache.log4j.Logger;

import com.sitech.ismp.messageObject.cc.CommandParameters;
import com.sitech.ismp.messageObject.cc.CommandResults;
import com.sitech.jmx.manage.MBeanManager;
import com.sitech.util.mq.MQConstants;
import com.sitech.util.mq.TunnelFactory;

public class CommandExcutor implements Runnable{
	private static Logger logger = Logger.getLogger(CommandExcutor.class);
	private CommandParameters param = null;
	private MBeanServer mbs = null;
	
	public CommandExcutor(CommandParameters param) {
		System.out.println("CommandExcutor:"+param.getTASK_ID());
		this.param = param;
		this.mbs = MBeanManager.getInstance().getMBeanServer();
	}
	
	public void run() {
		int type = param.getTYPE();
		String objectName = null;
		String operation = null;
		String className = null;

		switch (type) {
		case 1:
			objectName = "ExecuteShell:type=MBean";
			operation = "executeCommands";
			className = "com.sitech.ismp.check.mbean.ShellExecutor";
			break;
		case 2:
			objectName = "ExecuteSql:type=MBean";
			operation = "executeSqls";
			className = "com.sitech.ismp.check.mbean.SqlExecutor";
			break;
		case 3:
			objectName = "ExecuteProcedures:type=MBean";
			operation = "executeProcedures";
			className = "com.sitech.ismp.check.mbean.ProcedureExecutor";
			break;
		case 4:
			objectName = "ExecuteCommand:type=MBean";
			operation = "executeCommands";
			className = "com.sitech.ismp.check.mbean.CommandExecutor";
			break;
		default:
			return;
		}
		
		MBeanManager.getInstance().registCollMBean(objectName, className);
		
		CommandResults result = null;
		try {
			Object[] params = new Object[] { param };
			String[] signature = new String[] { "com.sitech.ismp.messageObject.cc.CommandParameters" };
			ObjectName jmxobjectname = new ObjectName(objectName);

			result = (CommandResults) mbs.invoke(jmxobjectname, operation, params, signature);
		} catch (Exception e) {
			logger.error("Exception while executing job, objectName["
					+ objectName + "], methodName[" + operation + "].", e);
		}

		if (result != null) {
			TunnelFactory.getTunnel(MQConstants.Q_CCAGENT_RESULT).writeData(result);
		}
	}

    /**
     * cc used only
     */
    private static JMSSender ccSender = new JMSSender(
            Config.WORKSTAITON_CONN_URL, MQConstants.Q_CCAGENT_RESULT);

    static{
        ccSender.start();
        logger.info("Start CCCPServer Message Producer...");
    }
}