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

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

Go to download

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

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

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

import com.scudata.common.MessageManager;
import com.scudata.common.RQException;
import com.scudata.dm.Context;
import com.scudata.dm.FileGroup;
import com.scudata.dm.FileObject;
import com.scudata.dm.JobSpace;
import com.scudata.dm.JobSpaceManager;
import com.scudata.dm.cursor.BFileCursor;
import com.scudata.dw.ColComTable;
import com.scudata.dw.ComTable;
import com.scudata.dw.IPhyTable;
import com.scudata.dw.RowComTable;
import com.scudata.dw.PhyTable;
import com.scudata.resources.EngineMessage;

/**
 * ?ڵ???????ļ?
 * @author RunQian
 *
 */
class PartitionFile {
	private ClusterFile clusterFile; // ?????ļ?Ⱥ?ļ?
	private String host; // IP
	private int port; // ?˿?
	
	//private int partition; // ??????-1??ʾֱ?????ļ???ȡ
	private int []parts; // ?ֱ??????飬?????Ϊ???????????ֱ?????ļ???ȡ
		
	/**
	 * ?????ڵ???????ļ?
	 * @param clusterFile ?????ļ?Ⱥ?ļ?
	 * @param host IP
	 * @param port ?˿?
	 * @param partition ????
	 */
	public PartitionFile(ClusterFile clusterFile, String host, int port, int partition) {
		this.clusterFile = clusterFile;
		this.host = host;
		this.port = port;
		
		//this.partition = partition;
		if (partition != -1) {
			parts = new int[] {partition};
		}
	}
	
	public PartitionFile(ClusterFile clusterFile, String host, int port, int []parts) {
		this.clusterFile = clusterFile;
		this.host = host;
		this.port = port;
		this.parts = parts;
	}
	
	/**
	 * ???ƶ???
	 * @param clusterFile
	 * @return
	 */
	public PartitionFile dup(ClusterFile clusterFile) {
		//return new PartitionFile(clusterFile, host, port, partition);
		return new PartitionFile(clusterFile, host, port, parts);
	}
	
	/**
	 * ???????
	 * @param colNames ?ֶ???????
	 * @param serialBytesLen
	 * @param segmentCol
	 * @param serialLen
	 * @param writePsw
	 * @param readPsw
	 * @param distribute
	 * @param opt
	 * @return
	 */
	public int createGroupTable(String []colNames, String distribute, String opt) {
		UnitClient client = new UnitClient(host, port);
		String fileName = clusterFile.getFileName();
		
		try {
			UnitCommand command = new UnitCommand(UnitCommand.CREATE_GT);
			command.setAttribute("fileName", fileName);
			//command.setAttribute("partition", new Integer(partition));
			command.setAttribute("parts", parts);
			command.setAttribute("jobSpaceId", clusterFile.getJobSpaceId());
			
			command.setAttribute("colNames", colNames);
			command.setAttribute("distribute", distribute);
			command.setAttribute("opt", opt);
			
			Response response = client.send(command);
			Integer id = (Integer)response.checkResult();
			return id.intValue();
		} finally {
			client.close();
		}
	}
	
	/**
	 * ?ڽڵ????ִ?д??????????
	 * @param attributes
	 * @return
	 */
	public static Response executeCreateGroupTable(HashMap attributes) {
		String fileName = (String)attributes.get("fileName");
		//Integer partition = (Integer)attributes.get("partition");
		int []parts = (int[])attributes.get("parts");
		String jobSpaceID = (String)attributes.get("jobSpaceId");
		String []colNames = (String [])attributes.get("colNames");
		String distribute = (String)attributes.get("distribute");
		String opt = (String)attributes.get("opt");
		
		try {
			JobSpace js = JobSpaceManager.getSpace(jobSpaceID);
			Context ctx = ClusterUtil.createContext(js);
			FileObject fo = new FileObject(fileName);
			if (parts != null && parts.length == 1) {
				fo.setPartition(parts[0]);
			}
			
			File file = fo.getLocalFile().file();
			if ((opt == null || opt.indexOf('y') == -1) && file.exists()) {
				MessageManager mm = EngineMessage.get();
				throw new RQException(mm.getMessage("file.fileAlreadyExist", fo.getFileName()));
			} else if (opt != null && opt.indexOf('y') != -1 && file.exists()) {
				try {
					ComTable table = ComTable.open(file, ctx);
					table.delete();
				} catch (IOException e) {
					throw new RQException(e.getMessage(), e);
				}
			}
			
			
			ComTable gt;
			if (opt != null && opt.indexOf('r') != -1) {
				gt = new RowComTable(file, colNames, distribute, opt, ctx);
			} else {
				gt = new ColComTable(file, colNames, distribute, opt, ctx);
			}
			
			if (parts != null && parts.length == 1) {
				gt.setPartition(parts[0]);
			}
			
			PhyTable table = gt.getBaseTable();
			IProxy proxy = new PhyTableProxy(table);
			js.getResourceManager().addProxy(proxy);
			return new Response(new Integer(proxy.getProxyId()));
		} catch (Exception e) {
			Response response = new Response();
			response.setException(e);
			return response;
		}
	}

	/**
	 * ?????
	 * @return ?ڵ?????????ID
	 */
	public int openGroupTable() {
		UnitClient client = new UnitClient(host, port);
		
		try {
			UnitCommand command = new UnitCommand(UnitCommand.OPEN_GT);
			command.setAttribute("fileName", clusterFile.getFileName());
			//command.setAttribute("partition", new Integer(partition));
			command.setAttribute("parts", parts);
			command.setAttribute("jobSpaceId", clusterFile.getJobSpaceId());
			Response response = client.send(command);
			Integer id = (Integer)response.checkResult();
			return id.intValue();
		} finally {
			client.close();
		}
	}
	
	/**
	 * ?ڽڵ????ִ?д????????
	 * @param attributes
	 * @return
	 */
	public static Response executeOpenGroupTable(HashMap attributes) {
		String fileName = (String)attributes.get("fileName");
		//Integer partition = (Integer)attributes.get("partition");
		int []parts = (int[])attributes.get("parts");
		String jobSpaceID = (String)attributes.get("jobSpaceId");
		
		try {
			JobSpace js = JobSpaceManager.getSpace(jobSpaceID);
			Context ctx = ClusterUtil.createContext(js);
			IPhyTable table;
			
			if (parts == null || parts.length <= 1) {
				FileObject fo = new FileObject(fileName);
				if (parts != null && parts.length == 1) {
					fo.setPartition(parts[0]);
				}
	
				File file = fo.getLocalFile().file();
				PhyTable tmd = ComTable.openBaseTable(file, ctx);
				table = tmd;
				
				if (parts != null && parts.length == 1) {
					tmd.getGroupTable().setPartition(parts[0]);
				}
			} else {
				FileGroup fileGroup = new FileGroup(fileName, parts);
				table = fileGroup.open(null, ctx);
			}
			
			IProxy proxy = new PhyTableProxy(table);
			js.getResourceManager().addProxy(proxy);
			return new Response(new Integer(proxy.getProxyId()));
		} catch (Exception e) {
			Response response = new Response();
			response.setException(e);
			return response;
		}
	}
	
	/**
	 * ??????Ⱥ???ļ??α?
	 * @param fields ѡ???ֶ???????
	 * @param opt ѡ??
	 * @param segSeq ?ֶκ?
	 * @param segCount ?ֶ???
	 * @param unit ?ڵ?????
	 * @return ?ڵ???α??????
	 */
	public int createBinaryCursor(String []fields, String opt, int segSeq, int segCount, int unit) {
		UnitClient client = new UnitClient(host, port);
		String fileName = clusterFile.getFileName();
		
		try {
			UnitCommand command = new UnitCommand(UnitCommand.CREATE_BINARY_CURSOR);
			command.setAttribute("fileName", fileName);
			//command.setAttribute("partition", new Integer(partition));
			command.setAttribute("segSeq", new Integer(segSeq));
			command.setAttribute("segCount", new Integer(segCount));
			command.setAttribute("unit", new Integer(unit));
			command.setAttribute("jobSpaceId", clusterFile.getJobSpaceId());
			command.setAttribute("fields", fields);
			command.setAttribute("opt", opt);
			
			Response response = client.send(command);
			Integer id = (Integer)response.checkResult();
			return id.intValue();
		} finally {
			client.close();
		}
	}
	
	/**
	 * ?ڽڵ????ִ?д??????ļ??α?????
	 * @param attributes
	 * @return
	 */
	public static Response executeCreateBinaryCursor(HashMap attributes) {
		String fileName = (String)attributes.get("fileName");
		//Integer partition = (Integer)attributes.get("partition");
		Integer segSeq = (Integer)attributes.get("segSeq");
		Integer segCount = (Integer)attributes.get("segCount");
		Integer unit = (Integer)attributes.get("unit");
		String jobSpaceID = (String)attributes.get("jobSpaceId");
		String []fields = (String[])attributes.get("fields");
		String opt = (String)attributes.get("opt");
		
		FileObject fo = new FileObject(fileName);
		//if (partition.intValue() > 0) {
		//	fo.setPartition(partition);
		//}
		
		try {
			JobSpace js = JobSpaceManager.getSpace(jobSpaceID);
			Context ctx = ClusterUtil.createContext(js, attributes);
			BFileCursor cursor;
			if (segCount > 1) {
				cursor = new BFileCursor(fo, fields, segSeq, segCount, opt, ctx);
			} else {
				cursor = new BFileCursor(fo, fields, opt, ctx);
			}
			
			IProxy proxy = new CursorProxy(cursor, unit);
			js.getResourceManager().addProxy(proxy);
			return new Response(new Integer(proxy.getProxyId()));
		} catch (Exception e) {
			Response response = new Response();
			response.setException(e);
			return response;
		}
	}
	
	/**
	 * ???????
	 * @param file ???????Ӧ???ļ???ʡ???򸲸?Դ?ļ?
	 * @param option ѡ??
	 * @param distribute ?·ֲ?????ʽ
	 * @param blockSize ???????С
	 * @return true???ɹ???false??ʧ??
	 */
	public boolean resetGroupTable(String file, String option, String distribute, Integer blockSize) {
		UnitClient client = new UnitClient(host, port);
		
		try {
			UnitCommand command = new UnitCommand(UnitCommand.GT_RESET);
			command.setAttribute("fileName", clusterFile.getFileName());
			//command.setAttribute("partition", new Integer(partition));
			command.setAttribute("parts", parts);
			command.setAttribute("file", file);
			command.setAttribute("option", option);
			command.setAttribute("jobSpaceId", clusterFile.getJobSpaceId());
			command.setAttribute("distribute", distribute);
			command.setAttribute("blockSize", blockSize);
			
			Response response = client.send(command);
			Boolean result = (Boolean)response.checkResult();
			return result;
		} finally {
			client.close();
		}
	}
	
	/**
	 * ?ڽڵ????ִ?????????????
	 * @param attributes
	 * @return
	 */
	public static Response executeResetGroupTable(HashMap attributes) {
		String fileName = (String)attributes.get("fileName");
		//Integer partition = (Integer)attributes.get("partition");
		int []parts = (int[])attributes.get("parts");
		String file = (String)attributes.get("file");//new file name
		String option = (String)attributes.get("option");
		String jobSpaceID = (String)attributes.get("jobSpaceId");
		String distribute = (String)attributes.get("distribute");
		Integer blockSize = (Integer)attributes.get("blockSize");
		try {
			JobSpace js = JobSpaceManager.getSpace(jobSpaceID);
			Context ctx = ClusterUtil.createContext(js);
			boolean result;
			
			if (parts == null || parts.length <= 1) {
				FileObject fo = new FileObject(fileName);
				if (parts != null && parts.length == 1) {
					fo.setPartition(parts[0]);
				}
				
				ComTable table = ComTable.open(fo.getLocalFile().file(), ctx);
				if (file == null) {
					result = table.reset(null, option, ctx, distribute);
				} else {
					FileObject newFile = new FileObject(file);
					if (parts != null && parts.length == 1) {
						newFile.setPartition(parts[0]);
					}
					
					result = table.reset(newFile.getLocalFile().file(), option, ctx, distribute);
				}
			} else {
				FileGroup fileGroup = new FileGroup(fileName, parts);
				if (file == null) {
					result = fileGroup.resetGroupTable(option, blockSize, null, ctx);
				} else {
					FileGroup newFileGroup = new FileGroup(file, parts);
					result = fileGroup.resetGroupTable(newFileGroup, option, distribute, blockSize, null, ctx);
				}
			}
			
			return new Response(Boolean.valueOf(result));
		} catch (Exception e) {
			Response response = new Response();
			response.setException(e);
			return response;
		}
	}

	/**
	 * ȡ?ڵ??IP
	 * @return String
	 */
	public String getHost() {
		return host;
	}

	/**
	 * ȡ?ڵ???˿?
	 * @return int
	 */
	public int getPort() {
		return port;
	}

	/**
	 * ȡ????
	 * @return int
	 */
	public int getPartition() {
		//return partition;
		if (parts != null && parts.length > 0) {
			return parts[0];
		} else {
			return -1;
		}
	}
	
	public int[] getParts() {
		return parts;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy