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

com.scudata.parallel.ClusterPseudo Maven / Gradle / Ivy

Go to download

SPL(Structured Process Language) A programming language specially for structured data computing.

There is a newer version: 20240823
Show newest version
package com.scudata.parallel;

import java.util.HashMap;

import com.scudata.common.RQException;
import com.scudata.dm.Context;
import com.scudata.dm.JobSpace;
import com.scudata.dm.JobSpaceManager;
import com.scudata.dm.Machines;
import com.scudata.dm.Record;
import com.scudata.dm.ResourceManager;
import com.scudata.dm.Sequence;
import com.scudata.dm.cursor.ICursor;
import com.scudata.dm.op.Operable;
import com.scudata.dm.op.Operation;
import com.scudata.dw.pseudo.IPseudo;
import com.scudata.dw.pseudo.PseudoDefination;
import com.scudata.dw.pseudo.PseudoDerive;
import com.scudata.dw.pseudo.PseudoNew;
import com.scudata.dw.pseudo.PseudoNews;
import com.scudata.dw.pseudo.PseudoTable;
import com.scudata.expression.Expression;
import com.scudata.expression.Function;
import com.scudata.expression.FunctionLib;
import com.scudata.thread.ThreadPool;

public class ClusterPseudo extends IPseudo implements IClusterObject {
	public static final int TYPE_TABLE = 0;
	public static final int TYPE_NEW = 1;
	public static final int TYPE_NEWS = 2;
	public static final int TYPE_DERIVE = 3;
	
	private ClusterFile clusterFile; // ?ڵ????Ϣ
	private int []pseudoProxyIds; // ??Ӧ?Ľڵ???????????ʶ
	private Sequence cache;//??import?Ľ????cache
	private boolean hasZone;
	private ClusterPhyTable table;
	private Context ctx;
	
	public ClusterPseudo(ClusterFile clusterFile, boolean hasZone, int[] pseudoProxyIds) {
		this.clusterFile = clusterFile;
		this.pseudoProxyIds = pseudoProxyIds;
		this.hasZone = hasZone;
	}

	private static Sequence toSequence(int[] arr) {
		if (arr == null) return null;
		Sequence seq = new Sequence();
		for (int v : arr) {
			seq.add(v);
		}
		return seq;
	}
	
	public static ClusterPseudo createClusterPseudo(Record rec, Machines hs, int n, Context ctx) {
		Sequence zone = (Sequence) PseudoDefination.getFieldValue(rec, PseudoDefination.PD_ZONE);
		String file = (String) PseudoDefination.getFieldValue(rec, PseudoDefination.PD_FILE);
		ClusterFile clusterFile;
		boolean hasZone;
		
		Cluster cluster = new Cluster(hs.getHosts(), hs.getPorts(), ctx);
		if (zone != null) {
			hasZone = true;
			clusterFile = new ClusterFile(cluster, file, zone, null);
		} else {
			hasZone = false;
			clusterFile = new ClusterFile(cluster, file, null);
		}
		
		ClusterPhyTable table = clusterFile.openGroupTable(ctx);
		
		int count = clusterFile.getUnitCount();
		int[] newPseudoProxyIds = new int[count];
		Record record = new Record(rec.dataStruct(), rec.getFieldValues());
		PartitionFile[] pfs = clusterFile.getPartitionFiles();
		
		for (int i = 0; i < count; ++i) {
			UnitClient client = new UnitClient(clusterFile.getHost(i), clusterFile.getPort(i));

			try {
				UnitCommand command = new UnitCommand(UnitCommand.PSEUDO_CREATE);
				command.setAttribute("jobSpaceId", cluster.getJobSpaceId());
				Sequence z = toSequence(pfs[i].getParts());
				if (z == null) {
					PseudoDefination.setFieldValue(record, PseudoDefination.PD_ZONE, null);
				} else {
					PseudoDefination.setFieldValue(record, PseudoDefination.PD_ZONE, z);
				}
				command.setAttribute("rec", record);
				command.setAttribute("n", new Integer(n));
				
				Response response = client.send(command);
				Integer id = (Integer) response.checkResult();
				newPseudoProxyIds[i] = id.intValue();
			} finally {
				client.close();
			}
		}
		ClusterPseudo result = new ClusterPseudo(clusterFile, hasZone, newPseudoProxyIds);
		result.table = table;
		return result;
	}
	
	
	public static Response executeCreateClusterPseudo(HashMap attributes) {
		String jobSpaceID = (String) attributes.get("jobSpaceId");
		IPseudo pseudo = null;
		try {
			JobSpace js = JobSpaceManager.getSpace(jobSpaceID);
			ResourceManager rm = js.getResourceManager();
			Context ctx = ClusterUtil.createContext(js, attributes);
			
			Record rec = (Record) attributes.get("rec");
			Integer n = (Integer) attributes.get("n");
			Integer ptableId = (Integer) attributes.get("ptableId");
			String option = (String) attributes.get("option");
			Integer type = (Integer) attributes.get("type");
			
			if (type == null) {
				pseudo = PseudoTable.create(rec, n, ctx);
			} else {
				PseudoProxy pseudoProxy = (PseudoProxy) rm.getProxy(ptableId.intValue());
				IPseudo ptable = pseudoProxy.getPseudo();
				PseudoDefination pd = new PseudoDefination(rec, ctx);
				if (type == TYPE_NEW) {
					pseudo = new PseudoNew(pd, ptable, option);
				} else if (type == TYPE_NEWS) {
					pseudo = new PseudoNews(pd, ptable, option);
				} else if (type == TYPE_DERIVE) {
					pseudo = new PseudoDerive(pd, ptable, option);
				}
			}
			
			IProxy proxy = new PseudoProxy(pseudo);
			rm.addProxy(proxy);
			return new Response(new Integer(proxy.getProxyId()));
		} catch (Exception e) {
			Response response = new Response();
			response.setException(e);
			return response;
		}
	}
	
	public Cluster getCluster() {
		return clusterFile.getCluster();
	}

	public void addColNames(String[] nameArray) {
		for (String name : nameArray) {
			addColName(name);
		}
	}

	public void addColName(String name) {
		Cluster cluster = getCluster();
		int count = cluster.getUnitCount();
		
		for (int i = 0; i < count; ++i) {
			UnitClient client = new UnitClient(cluster.getHost(i), cluster.getPort(i));
			
			try {
				UnitCommand command = new UnitCommand(UnitCommand.PSEUDO_ADD_COLNAME);
				command.setAttribute("jobSpaceId", cluster.getJobSpaceId());
				command.setAttribute("pseudoProxyId", new Integer(pseudoProxyIds[i]));
				command.setAttribute("name", name);
				
 				Response response = client.send(command);
				response.checkResult();
			} finally {
				client.close();
			}
		}
	}
	
	public static Response executeAddColName(HashMap attributes) {
		String jobSpaceID = (String)attributes.get("jobSpaceId");
		Integer pseudoProxyId = (Integer)attributes.get("pseudoProxyId");
		String name = (String)attributes.get("name");
		
		try {
			JobSpace js = JobSpaceManager.getSpace(jobSpaceID);
			
			ResourceManager rm = js.getResourceManager();
			PseudoProxy pseudo = (PseudoProxy)rm.getProxy(pseudoProxyId.intValue());
			pseudo.getPseudo().addColName(name);
			return new Response();
		} catch (Exception e) {
			Response response = new Response();
			response.setException(e);
			return response;
		}
	}
	
	public ICursor cursor(Expression[] exps, String[] names) {
		return cursor(exps, names, false);
	}
	
	public ICursor cursor(Expression[] exps, String[] names, boolean isColumn) {
		Cluster cluster = getCluster();
		int count = cluster.getUnitCount();
		int[] cursorProxyIds = new int[count];
		
		String []expStrs = null;
		if (exps != null) {
			int len = exps.length;
			expStrs = new String[len];
			for (int i = 0; i < len; ++i) {
				if (exps[i] != null) {
					expStrs[i] = exps[i].toString();
				}
			}
		}
		
		//û??zoneʱ????Ϊ?Ǹ?д?ڱ?????ʱ???ڱ??????α?
		if (!hasZone) {
			ClusterMemoryTable table = (ClusterMemoryTable) memory(null, null);
			return table.cursor(exps, names, null, 0, null, getContext());
		}
		
		for (int i = 0; i < count; ++i) {
			UnitClient client = new UnitClient(cluster.getHost(i), cluster.getPort(i));

			try {
				UnitCommand command = new UnitCommand(UnitCommand.PSEUDO_CURSOR);
				command.setAttribute("jobSpaceId", cluster.getJobSpaceId());
				command.setAttribute("pseudoProxyId", new Integer(pseudoProxyIds[i]));
				
				command.setAttribute("expStrs",  expStrs);
				command.setAttribute("names", names);
				command.setAttribute("isColumn", isColumn);
				command.setAttribute("unit", new Integer(i));
				
				Response response = client.send(command);
				Integer id = (Integer) response.checkResult();
				cursorProxyIds[i] = id.intValue();
			} finally {
				client.close();
			}
		}

		ClusterCursor result = new ClusterCursor(this, cursorProxyIds, true);
		result.setDistribute(table.getDistribute());
		result.setSortedColNames(getAllSortedColNames());
		return result;
	}

	public static Response executeCreateCursor(HashMap attributes) {
		String jobSpaceID = (String) attributes.get("jobSpaceId");
		Integer pseudoProxyId = (Integer) attributes.get("pseudoProxyId");
		String []expStrs = (String[]) attributes.get("expStrs");
		String []names = (String[]) attributes.get("names");
		Boolean isColumn = (Boolean) attributes.get("isColumn");
		Integer unit = (Integer) attributes.get("unit");
		
		try {
			JobSpace js = JobSpaceManager.getSpace(jobSpaceID);
			ResourceManager rm = js.getResourceManager();
			PseudoProxy pseudoProxy = (PseudoProxy) rm.getProxy(pseudoProxyId.intValue());
			IPseudo pseudo = pseudoProxy.getPseudo();
			Context ctx = ClusterUtil.createContext(js, attributes, "cursor", null);
			
			Expression []exps = null;
			if (expStrs != null) {
				int len = expStrs.length;
				exps = new Expression[len];
				for (int i = 0; i < len; ++i) {
					exps[i] = new Expression(ctx, expStrs[i]);
				}
			}
			
			ICursor cursor = pseudo.cursor(exps, names, isColumn);
			IProxy proxy = new CursorProxy(cursor, unit);
			rm.addProxy(proxy);
			return new Response(new Integer(proxy.getProxyId()));
		} catch (Exception e) {
			Response response = new Response();
			response.setException(e);
			return response;
		}
	}
	
	public void addPKeyNames() {
		throw new RQException("never run to here");
	}

	public boolean isColumn(String col) {
		throw new RQException("never run to here");
	}

	public Context getContext() {
		return ctx;
	}

	public Object clone(Context ctx) throws CloneNotSupportedException {
		int count = clusterFile.getUnitCount();
		int[] newPseudoProxyIds = new int[count];
		
		for (int i = 0; i < count; ++i) {
			UnitClient client = new UnitClient(clusterFile.getHost(i), clusterFile.getPort(i));

			try {
				UnitCommand command = new UnitCommand(UnitCommand.PSEUDO_CLONE);
				command.setAttribute("jobSpaceId", clusterFile.getJobSpaceId());
				command.setAttribute("pseudoProxyId", new Integer(pseudoProxyIds[i]));
				
				Response response = client.send(command);
				Integer id = (Integer) response.checkResult();
				newPseudoProxyIds[i] = id.intValue();
			} finally {
				client.close();
			}
		}

		ClusterPseudo result = new ClusterPseudo(clusterFile, hasZone, newPseudoProxyIds);
		result.table = table;
		return result;
	}
	
	public static Response executeClone(HashMap attributes) {
		String jobSpaceID = (String) attributes.get("jobSpaceId");
		Integer pseudoProxyId = (Integer) attributes.get("pseudoProxyId");
		
		try {
			JobSpace js = JobSpaceManager.getSpace(jobSpaceID);
			ResourceManager rm = js.getResourceManager();
			PseudoProxy pseudoProxy = (PseudoProxy) rm.getProxy(pseudoProxyId.intValue());
			IPseudo pseudo = pseudoProxy.getPseudo();
			Context ctx = ClusterUtil.createContext(js, attributes, "cursor", null);
			
			Object obj = pseudo.clone(ctx);
			IProxy proxy = new PseudoProxy((IPseudo) obj);
			rm.addProxy(proxy);
			return new Response(new Integer(proxy.getProxyId()));
		} catch (Exception e) {
			Response response = new Response();
			response.setException(e);
			return response;
		}
	}
	
	public void append(ICursor cursor, String option) {
		// TODO Auto-generated method stub
		
	}

	public Sequence update(Sequence data, String opt) {
		// TODO Auto-generated method stub
		return null;
	}
	
	public Sequence delete(Sequence data, String opt) {
		// TODO Auto-generated method stub
		return null;
	}
	
	public Operable addOperation(Operation op, Context ctx) {
		Cluster cluster = getCluster();
		int count = cluster.getUnitCount();
		Function function = op.getFunction();
		String functionName = function.getFunctionName();
		String option = function.getOption();
		String param = function.getParamString();
		int[] newPseudoProxyIds = new int[count];
		
		for (int i = 0; i < count; ++i) {
			UnitClient client = new UnitClient(cluster.getHost(i), cluster.getPort(i));
			
			try {
				UnitCommand command = new UnitCommand(UnitCommand.PSEUDO_ADD_OPERATION);
				command.setAttribute("jobSpaceId", cluster.getJobSpaceId());
				command.setAttribute("pseudoProxyId", new Integer(pseudoProxyIds[i]));
				command.setAttribute("functionName", functionName);
				command.setAttribute("option", option);
				command.setAttribute("param", param);
				ClusterUtil.setParams(command, function, ctx);
				
 				Response response = client.send(command);
 				Integer id = (Integer) response.checkResult();
				newPseudoProxyIds[i] = id.intValue();
			} finally {
				client.close();
			}
		}
		
		ClusterPseudo result = new ClusterPseudo(clusterFile, hasZone, newPseudoProxyIds);
		result.table = table;
		return result;
	}
	
	public static Response executeAddOperation(HashMap attributes) {
		String jobSpaceID = (String)attributes.get("jobSpaceId");
		Integer pseudoProxyId = (Integer)attributes.get("pseudoProxyId");
		String functionName = (String)attributes.get("functionName");
		String option = (String)attributes.get("option");
		String param = (String)attributes.get("param");
		
		try {
			JobSpace js = JobSpaceManager.getSpace(jobSpaceID);
			Context ctx = ClusterUtil.createContext(js, attributes, functionName, option);
			
			ResourceManager rm = js.getResourceManager();
			PseudoProxy pseudo = (PseudoProxy)rm.getProxy(pseudoProxyId.intValue());
			Object obj = FunctionLib.executeMemberFunction(pseudo.getPseudo(), functionName, param, option, ctx);
			
			IProxy proxy = new PseudoProxy((IPseudo) obj);
			rm.addProxy(proxy);
			return new Response(new Integer(proxy.getProxyId()));		
		} catch (Exception e) {
			Response response = new Response();
			response.setException(e);
			return response;
		}
	}
	
	public void setCache(Sequence cache) {
		this.cache = cache;
	}
	
	public Sequence getCache() {
		return cache;
	}
	
	/**
	 * ???????е?ά?ֶ???
	 * @return ?ֶ???????
	 */
	public String[] getAllSortedColNames() {
		return table.getAllSortedColNames();
	}
	
	/**
	 * ????????ֶγɼ?Ⱥ?ڱ?
	 * @param fields Ҫ???????ֶ???????
	 * @param filter ????????
	 * @param ctx ??????????
	 * @return ??Ⱥ?ڱ?
	 */
	public Object memory(String option, Context ctx) {
		Cluster cluster = getCluster();
		int count = cluster.getUnitCount();
		
		UnitJob []jobs = new UnitJob[count];
		ThreadPool pool = TaskManager.getPool();
		for (int i = 0; i < count; ++i) {
			UnitClient client = new UnitClient(cluster.getHost(i), cluster.getPort(i));
			UnitCommand command = new UnitCommand(UnitCommand.PSEUDO_MEMORY);
			command.setAttribute("jobSpaceId", cluster.getJobSpaceId());
			command.setAttribute("pseudoProxyId", new Integer(pseudoProxyIds[i]));
			command.setAttribute("option", option);
			command.setAttribute("unit", new Integer(i));
			
			jobs[i] = new UnitJob(client, command);
			pool.submit(jobs[i]);
		}

		for (int i = 0; i < count; ++i) {
			// ?ȴ?????ִ?????
			jobs[i].join();
		}
		
		if (jobs[0].getResult() instanceof Integer) {
			int []proxyIds = new int[count];
			for (int i = 0; i < count; ++i) {
				proxyIds[i] = (Integer)jobs[i].getResult();
			}
			return new ClusterPhyTable(clusterFile, proxyIds, ctx);
		} else {
			RemoteMemoryTable[] tables = new RemoteMemoryTable[count];
			for (int i = 0; i < count; ++i) {
				tables[i] = (RemoteMemoryTable)jobs[i].getResult();
			}
			ClusterMemoryTable result = new ClusterMemoryTable(getCluster(), tables, hasZone);
			result.setDistribute(table.getDistribute());
			result.setSortedColNames(getAllSortedColNames());
			return result;
		}
	}
	
	/**
	 * ?ڵ????ִ?ж?ȡ???ݳ??ڱ?
	 * @param attributes ????
	 * @return Response ???????Ļ?Ӧ
	 */
	public static Response executeMemory(HashMap attributes) {
		throw new RuntimeException();
//		String jobSpaceID = (String) attributes.get("jobSpaceId");
//		Integer pseudoProxyId = (Integer) attributes.get("pseudoProxyId");
//		String option = (String) attributes.get("option");
//		Integer unit = (Integer) attributes.get("unit");
//
//		try {
//			JobSpace js = JobSpaceManager.getSpace(jobSpaceID);
//			ResourceManager rm = js.getResourceManager();
//
//			PseudoProxy pseudoProxy = (PseudoProxy) rm.getProxy(pseudoProxyId.intValue());
//			IPseudo pseudo = pseudoProxy.getPseudo();
//			Context ctx = ClusterUtil.createContext(js, attributes);
//			IProxy proxy;
//			
//			Object table = Memory.createMemory(pseudo, null, option, ctx);
//			MemoryTable memoryTable = (MemoryTable) table;
//			
//			if (pseudo instanceof PseudoTable) {
//				PseudoTable ptable = (PseudoTable) pseudo;
//				String distribute = ptable.getPd().getDistribute();
//				Integer partition = ptable.getPd().getPartition();
//				if (partition != null) {
//					memoryTable.setDistribute(distribute);
//					memoryTable.setPart(partition);
//				}
//			}
//
//			proxy = new TableProxy(memoryTable, unit);
//			rm.addProxy(proxy);
//			RemoteMemoryTable rmt = ClusterMemoryTable.newRemoteMemoryTable(proxy.getProxyId(), memoryTable);
//			return new Response(rmt);
//		} catch (Exception e) {
//			Response response = new Response();
//			response.setException(e);
//			return response;
//		}
	}

	public Sequence Import(Expression[] exps, String[] names) {
		return cursor(exps, names).fetch();
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy