diff --git a/.classpath b/.classpath
index bb13dba0..84b01679 100644
--- a/.classpath
+++ b/.classpath
@@ -3,8 +3,17 @@
-
+
+
+
+
+
+
+
+
+
+
diff --git a/.project b/.project
index c9ff485b..766e275f 100644
--- a/.project
+++ b/.project
@@ -37,5 +37,6 @@
org.eclipse.wst.common.project.facet.core.nature
org.eclipse.jdt.core.javanature
org.eclipse.wst.jsdt.core.jsNature
+ com.sysdeo.eclipse.tomcat.tomcatnature
diff --git a/WebContent/WEB-INF/config/config.properties b/WebContent/WEB-INF/config/config.properties
index ead793d5..65bc7518 100644
--- a/WebContent/WEB-INF/config/config.properties
+++ b/WebContent/WEB-INF/config/config.properties
@@ -41,11 +41,16 @@ jdbc.minEvictableIdleTimeMillis=300000
#
#==============================================================================================================
table-suffix=_20152016
-extract-log-localtion=/home/log/
+extract-log-localtion=/home/web_manage/log/
gather-tablespace-name=TS_TTSSS
-gather-tablespace-path=1
-gather-table-user-password=1
+
+gather-tablespace-path=
+gather-table-user-password=
kubeMasterUrl=http://192.168.0.110:8080/
+
collect-user-name=system
collect-password=oracle
collect-service-name=orcl
+
+gfs_control_ip=192.168.0.110
+gfs_control_rootPassWd=root
diff --git a/WebContent/WEB-INF/config/log4j-config.xml b/WebContent/WEB-INF/config/log4j-config.xml
index fb905a3f..fb39773b 100644
--- a/WebContent/WEB-INF/config/log4j-config.xml
+++ b/WebContent/WEB-INF/config/log4j-config.xml
@@ -8,17 +8,25 @@
+
+
+
+
-
+
+
+
+
+
diff --git a/WebContent/WEB-INF/config/mybatis-applicationConfig.xml b/WebContent/WEB-INF/config/mybatis-applicationConfig.xml
index 4bb8e731..b2c5e781 100644
--- a/WebContent/WEB-INF/config/mybatis-applicationConfig.xml
+++ b/WebContent/WEB-INF/config/mybatis-applicationConfig.xml
@@ -11,6 +11,7 @@
+
@@ -18,5 +19,6 @@
+
\ No newline at end of file
diff --git a/WebContent/WEB-INF/web.xml b/WebContent/WEB-INF/web.xml
index 2d425519..304a7726 100644
--- a/WebContent/WEB-INF/web.xml
+++ b/WebContent/WEB-INF/web.xml
@@ -60,7 +60,7 @@
-
+
\ No newline at end of file
diff --git a/src/com/base/BaseController.java b/src/com/base/BaseController.java
index 804f833a..395cd09e 100644
--- a/src/com/base/BaseController.java
+++ b/src/com/base/BaseController.java
@@ -30,7 +30,7 @@ import com.platform.utils.Configs;
public class BaseController {
/** log4j */
- public static Logger log = Logger.getRootLogger();
+ public static Logger log = Configs.DAILY_ROLLING_LOGGER;
/**
* <一句话功能简述> 基于@ExceptionHandler异常处理----全局异常处理
diff --git a/src/com/base/Custom4exception.java b/src/com/base/Custom4exception.java
index 0e109c86..959a5f87 100644
--- a/src/com/base/Custom4exception.java
+++ b/src/com/base/Custom4exception.java
@@ -29,9 +29,12 @@ public class Custom4exception {
/**
* 抽取汇总--的-获取抽取动作异常
*/
- public final static String threadVolume_Oracle_Except = "3002001002";
+ public final static String threadVolume_Oracle_Except = "3002001001";
/** * SQL执行错误 */
public final static String OracleSQL_Except = "3002001002";
+ /** * MySQL错误 */
+ public final static String MySQL_Except = "3002002003";
+
}
diff --git a/src/com/base/CustomException.java b/src/com/base/CustomException.java
index e40f5697..e59bb6bd 100644
--- a/src/com/base/CustomException.java
+++ b/src/com/base/CustomException.java
@@ -94,7 +94,7 @@ public class CustomException extends Exception {
sbuf.append("\r\n");
// 是否 写入 文件
- log.debug(sbuf.toString());
+ log.error(sbuf.toString());
}
/**
diff --git a/src/com/dao/mapper/VolumeMapper.xml b/src/com/dao/mapper/VolumeMapper.xml
new file mode 100644
index 00000000..29f0a59b
--- /dev/null
+++ b/src/com/dao/mapper/VolumeMapper.xml
@@ -0,0 +1,95 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ UPDATE
+ volume_info
+
+
+
+ name= #{name},
+
+
+ ip= #{ip},
+
+
+ path= #{path},
+
+
+ mark= #{mark},
+
+
+
+
+ id = #{id}
+
+
+
+
+ INSERT INTO
+ volume_info(
+
+
+ name,
+
+
+ ip,
+
+
+ path,
+
+
+ mark,
+
+
+ )
+ VALUES(
+
+
+ #{name},
+
+
+ #{ip},
+
+
+ #{path},
+
+
+ #{mark},
+
+
+ )
+
+
+
+ DELETE FROM
+ volume_info
+ WHERE
+ name = #{name}
+
+
+
\ No newline at end of file
diff --git a/src/com/dao/mapper/data-details-mapper.xml b/src/com/dao/mapper/data-details-mapper.xml
index 8aa8b58f..f4b79e5d 100644
--- a/src/com/dao/mapper/data-details-mapper.xml
+++ b/src/com/dao/mapper/data-details-mapper.xml
@@ -76,7 +76,7 @@ PUBLIC "-//ibatis.apache.org//DTD Mapper 3.0//EN"
- AND CONCAT(regionalism_code,system_code,city_name,district_name,system_name) LIKE CONCAT('%',CONCAT(#{item},'%'))
+ AND CONCAT(regionalism_code,system_code,city_name,district_name,system_name,data_year) LIKE CONCAT('%',CONCAT(#{item},'%'))
@@ -220,10 +220,10 @@ PUBLIC "-//ibatis.apache.org//DTD Mapper 3.0//EN"
#{year},
- #{start_year},
+ #{startYear},
- #{end_year},
+ #{endYear},
#{volumeIp},
diff --git a/src/com/dao/mapper/dataInfoMoveTmpmapper.xml b/src/com/dao/mapper/dataInfoMoveTmpmapper.xml
index e35029a5..6d7b843d 100644
--- a/src/com/dao/mapper/dataInfoMoveTmpmapper.xml
+++ b/src/com/dao/mapper/dataInfoMoveTmpmapper.xml
@@ -49,7 +49,7 @@ PUBLIC "-//ibatis.apache.org//DTD Mapper 3.0//EN"
- regionalism_code,system_code,dst_path,lasttime,fkid
+ regionalism_code,system_code,dst_path,lasttime,fkid,dst_volume_ip,dst_volume_path
@@ -120,6 +120,12 @@ PUBLIC "-//ibatis.apache.org//DTD Mapper 3.0//EN"
fkid,
+
+ dst_volume_ip,
+
+
+ dst_volume_path,
+
)
VALUES(
@@ -146,7 +152,13 @@ PUBLIC "-//ibatis.apache.org//DTD Mapper 3.0//EN"
#{lastTime},
- #{fkid),
+ #{fkid},
+
+
+ #{dstVolumeIp},
+
+
+ #{dstVolumePath},
)
@@ -156,7 +168,7 @@ PUBLIC "-//ibatis.apache.org//DTD Mapper 3.0//EN"
INSERT INTO move_data_tmp ( )
VALUES
- (#{item.regionalismCode,jdbcType=VARCHAR},#{item.systemCode,jdbcType=INTEGER},#{item.dstPath,jdbcType=VARCHAR},#{item.lastTime,jdbcType=VARCHAR},#{item.fkid})
+ (#{item.regionalismCode,jdbcType=VARCHAR},#{item.systemCode,jdbcType=INTEGER},#{item.dstPath,jdbcType=VARCHAR},#{item.lastTime,jdbcType=VARCHAR},#{item.fkid},#{item.dstVolumeIp},#{item.dstVolumePath})
diff --git a/src/com/platform/controller/DataModelController.java b/src/com/platform/controller/DataModelController.java
index b5c5cf25..528aa89a 100644
--- a/src/com/platform/controller/DataModelController.java
+++ b/src/com/platform/controller/DataModelController.java
@@ -94,7 +94,7 @@ public class DataModelController extends BaseController {
PagerOptions pagerOptions = (PagerOptions) UtilsHelper
.newObjAndSetAttrsByClass(PagerOptions.class, params);
//冷热区查询字段mark
- pagerOptions.setMark(String.valueOf(pagerOptions.getVolumeType()));
+ pagerOptions.setMark(pagerOptions.getVolumeType());
return dfs.getPagerTableData(pagerOptions);
}
diff --git a/src/com/platform/controller/VolumeController.java b/src/com/platform/controller/VolumeController.java
new file mode 100644
index 00000000..a486e2d8
--- /dev/null
+++ b/src/com/platform/controller/VolumeController.java
@@ -0,0 +1,53 @@
+package com.platform.controller;
+
+import javax.annotation.Resource;
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpServletResponse;
+
+import org.apache.log4j.Logger;
+import org.springframework.stereotype.Controller;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestMethod;
+import org.springframework.web.bind.annotation.ResponseBody;
+
+import com.base.BaseController;
+import com.platform.entities.VolumeEntity;
+import com.platform.entities.VolumeForm;
+import com.platform.entities.VolumeInitEntity;
+import com.platform.service.IVolumeService;
+import com.platform.utils.Configs;
+import com.platform.utils.ThreadVolume;
+import com.platform.utils.ThreadVolumeImm;
+
+@Controller
+public class VolumeController extends BaseController{
+
+ public static Logger log = Configs.DAILY_ROLLING_LOGGER;
+
+ @Resource(name = "volumeService")
+ private IVolumeService volumeService;
+
+
+ @RequestMapping(value = "/volume/update", method = RequestMethod.POST)
+ @ResponseBody
+ public void volumeUpdate(HttpServletRequest res, HttpServletResponse req,
+ @RequestBody VolumeEntity form) throws Exception {
+ Configs.CONSOLE_LOGGER.error("/oracle/update");
+ volumeService.save(form);
+ req.setStatus(200);
+ new ThreadVolumeImm("ThreadVolumeImm-in-VolumeController-update").start();
+ }
+
+ @RequestMapping(value = "/volume/delete", method = RequestMethod.POST)
+ @ResponseBody
+ public void volumeDelete(HttpServletRequest res, HttpServletResponse req,
+ @RequestBody VolumeEntity entity) throws Exception {
+ Configs.CONSOLE_LOGGER.error("/oracle/delete");
+ volumeService.delete(entity);
+ req.setStatus(200);
+ new ThreadVolumeImm("ThreadVolumeImm-in-VolumeController-delete").start();
+ }
+
+
+}
diff --git a/src/com/platform/dao/VolumeDao.java b/src/com/platform/dao/VolumeDao.java
new file mode 100644
index 00000000..1d1d0232
--- /dev/null
+++ b/src/com/platform/dao/VolumeDao.java
@@ -0,0 +1,27 @@
+package com.platform.dao;
+
+import java.util.List;
+
+import org.springframework.stereotype.Repository;
+
+import com.platform.entities.VolumeInitEntity;
+
+/**
+ * @author chen
+ * 数据迁移状态 临时 存放 ,
+ */
+@Repository(value = "volumeDao")
+public interface VolumeDao {
+
+ /** 查
+ * @return
+ * @throws Exception
+ */
+ List findAll() throws Exception;
+
+ int update(VolumeInitEntity data) throws Exception;
+
+ int save(VolumeInitEntity data) throws Exception;
+
+ int remove(String name) throws Exception;
+}
diff --git a/src/com/platform/entities/DataInfoEntity.java b/src/com/platform/entities/DataInfoEntity.java
index e74dee30..2c227aa6 100644
--- a/src/com/platform/entities/DataInfoEntity.java
+++ b/src/com/platform/entities/DataInfoEntity.java
@@ -23,7 +23,7 @@ public class DataInfoEntity {
private String collectorName; // 采集人姓名
private String year; // 数据年度
- /** 是否抽取 */
+ /** 是否抽取 ,0标示为未汇总,1标示汇总中,2标示汇总完成 */
private int extractStatus;
/** 数据年度起始 */
private String startYear;
@@ -35,7 +35,7 @@ public class DataInfoEntity {
/** volume的path */
private String volumePath;
- private int volumeType;
+ private String volumeType;
private String mark;
@@ -258,14 +258,14 @@ public class DataInfoEntity {
/**
* @return the volumeType
*/
- public int getVolumeType() {
+ public String getVolumeType() {
return volumeType;
}
/**
* @param volumeType the volumeType to set
*/
- public void setVolumeType(int volumeType) {
+ public void setVolumeType(String volumeType) {
this.volumeType = volumeType;
}
diff --git a/src/com/platform/entities/VolumeEntity.java b/src/com/platform/entities/VolumeEntity.java
index ae2604ea..b562e9c1 100644
--- a/src/com/platform/entities/VolumeEntity.java
+++ b/src/com/platform/entities/VolumeEntity.java
@@ -37,7 +37,7 @@ public class VolumeEntity {
private String path;
/** * exist,正常返回状态Started,Stopped,Created */
- private String status;
+ private boolean status;
private String type;
@@ -103,17 +103,18 @@ public class VolumeEntity {
this.path = path;
}
+
/**
* @return the status
*/
- public String getStatus() {
+ public boolean isStatus() {
return status;
}
/**
* @param status the status to set
*/
- public void setStatus(String status) {
+ public void setStatus(boolean status) {
this.status = status;
}
@@ -159,4 +160,5 @@ public class VolumeEntity {
this.brick = brick;
}
+
}
diff --git a/src/com/platform/entities/VolumeForm.java b/src/com/platform/entities/VolumeForm.java
new file mode 100644
index 00000000..5baab4fe
--- /dev/null
+++ b/src/com/platform/entities/VolumeForm.java
@@ -0,0 +1,23 @@
+package com.platform.entities;
+
+import java.util.List;
+
+public class VolumeForm {
+
+ List volumes;
+
+ /**
+ * @return the volumes
+ */
+ public List getVolumes() {
+ return volumes;
+ }
+
+ /**
+ * @param volumes the volumes to set
+ */
+ public void setVolumes(List volumes) {
+ this.volumes = volumes;
+ }
+
+}
diff --git a/src/com/platform/entities/VolumeInitEntity.java b/src/com/platform/entities/VolumeInitEntity.java
new file mode 100644
index 00000000..8f340164
--- /dev/null
+++ b/src/com/platform/entities/VolumeInitEntity.java
@@ -0,0 +1,104 @@
+package com.platform.entities;
+
+import java.util.List;
+
+public class VolumeInitEntity {
+
+ private int id;
+
+ private String name;
+
+ private String ip;
+ /** 挂载点 */
+ private String path;
+
+ private String mark;
+
+ private List bricks;
+
+
+ /**
+ * @return the id
+ */
+ public int getId() {
+ return id;
+ }
+
+ /**
+ * @param id the id to set
+ */
+ public void setId(int id) {
+ this.id = id;
+ }
+
+ /**
+ * @return the name
+ */
+ public String getName() {
+ return name;
+ }
+
+ /**
+ * @param name the name to set
+ */
+ public void setName(String name) {
+ this.name = name;
+ }
+
+ /**
+ * @return the ip
+ */
+ public String getIp() {
+ return ip;
+ }
+
+ /**
+ * @param ip the ip to set
+ */
+ public void setIp(String ip) {
+ this.ip = ip;
+ }
+
+ /**
+ * @return the path
+ */
+ public String getPath() {
+ return path;
+ }
+
+ /**
+ * @param path the path to set
+ */
+ public void setPath(String path) {
+ this.path = path;
+ }
+
+ /**
+ * @return the mark
+ */
+ public String getMark() {
+ return mark;
+ }
+
+ /**
+ * @param mark the mark to set
+ */
+ public void setMark(String mark) {
+ this.mark = mark;
+ }
+
+ /**
+ * @return the bricks
+ */
+ public List getBricks() {
+ return bricks;
+ }
+
+ /**
+ * @param bricks the bricks to set
+ */
+ public void setBricks(List bricks) {
+ this.bricks = bricks;
+ }
+
+}
diff --git a/src/com/platform/glusterfs/ClusterInfo.java b/src/com/platform/glusterfs/ClusterInfo.java
index 793b86ca..df56469a 100644
--- a/src/com/platform/glusterfs/ClusterInfo.java
+++ b/src/com/platform/glusterfs/ClusterInfo.java
@@ -5,6 +5,7 @@ package com.platform.glusterfs;
import java.io.File;
+import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
@@ -16,6 +17,8 @@ import org.apache.log4j.PropertyConfigurator;
import com.platform.utils.Constant;
+import ch.ethz.ssh2.Connection;
+
/**
* 获取集群信息
* @author liliy
@@ -32,12 +35,13 @@ public class ClusterInfo {
* 如果ip在集群中且联通状态为PeerinCluster(Connected)
* 如果ip在集群中且但不连通为PeerinCluster(Disconnected)
* @return
+ * @throws IOException
* @see [类、类#方法、类#成员]
*/
public Map showClusterInfo() {
- log.info("get cluster info");
+// log.info("get cluster info");
Map peerIps = new HashMap();
-
+ peerIps.put(Constant.hostIp, Constant.peerincluster_connected);
List reStrings = Constant.ganymedSSH.execCmdWaitAcquiescent(Constant.glusterPeerStatus);
if (reStrings == null) {
log.error("1101 command get result is null");
@@ -47,9 +51,12 @@ public class ClusterInfo {
log.error("1102 command get result is nothing");
return null;
}
-
+
+ if (reStrings.get(0).contains("No peers present")) {
+ return peerIps;
+ }
+
if (!(reStrings.get(0).split(":")[0].contains("Number of Peers"))) {
-
log.error("1103 get result string wrong");
return null;
}
@@ -86,6 +93,28 @@ public class ClusterInfo {
}
}
+
+// for (Map.Entry entry:peerIps.entrySet()){
+// String key=entry.getKey();
+// if(key.equals(Constant.hostIp)){
+// continue;
+// }
+// String value=entry.getValue();
+// if(Constant.ganymedSSH.otherConns==null){
+// Constant.ganymedSSH.otherConns=new HashMap();
+// }
+// if(!Constant.ganymedSSH.otherConns.containsKey(key)){
+// Connection connection=null;
+// try {
+// connection = Constant.ganymedSSH.getOpenedConnection(key, Constant.rootUser, Constant.rootPasswd, Constant.port);
+// } catch (IOException e) {
+// // TODO Auto-generated catch block
+// e.printStackTrace();
+// }
+// Constant.ganymedSSH.otherConns.put(key,connection);
+// }
+// }
+
return peerIps;
}
diff --git a/src/com/platform/glusterfs/CopyData.java b/src/com/platform/glusterfs/CopyData.java
index 0b226c77..d99d6b65 100644
--- a/src/com/platform/glusterfs/CopyData.java
+++ b/src/com/platform/glusterfs/CopyData.java
@@ -61,7 +61,7 @@ public class CopyData {
log.info("3202 "+sourceFolderName+" is not exists");
return -2;
}
- String command = "cp -r " + sourceFolderName+" "+destFolderName;
+ String command = "cp -rp " + sourceFolderName+" "+destFolderName;
Constant.ganymedSSH.execCmdNoWaitAcquiescent(command);
@@ -92,7 +92,7 @@ public class CopyData {
log.info("3202 "+sourceFolderName+"/"+fileName+" is not exists");
return -2;
}
- String command = "cp -r " + sourceFolderName + "/" + fileName+" "+destFolderName;
+ String command = "cp -rp " + sourceFolderName + "/" + fileName+" "+destFolderName;
/*
* RunCommand runCommand = new RunCommand();
diff --git a/src/com/platform/glusterfs/SetVolume.java b/src/com/platform/glusterfs/SetVolume.java
index 8a361b18..6d9fc1e2 100644
--- a/src/com/platform/glusterfs/SetVolume.java
+++ b/src/com/platform/glusterfs/SetVolume.java
@@ -280,7 +280,7 @@ public class SetVolume {
if (new VolumeInfo().getVolumeStatus(volumeName).equals("Stopped")) {
log.error("3502 the volume is already stoped");
System.out.println("3502 the volume is already stoped");
- return -1;
+ return 0;
} else {
String command = "echo -e \"y\"| gluster volume stop " + volumeName;
List reStrings = Constant.ganymedSSH.execCmdWaitAcquiescent(command);
diff --git a/src/com/platform/glusterfs/SizeInfo.java b/src/com/platform/glusterfs/SizeInfo.java
index 4d639be2..03f74228 100644
--- a/src/com/platform/glusterfs/SizeInfo.java
+++ b/src/com/platform/glusterfs/SizeInfo.java
@@ -23,7 +23,7 @@ public class SizeInfo {
* @return
*/
public long showAllSize() {
- log.info("get AllSize ");
+// log.info("get AllSize ");
List volumeNames = volumeInfo.showAllVolumeName();
if (volumeNames == null) {
log.error("1201 showAllVolumeName error");
diff --git a/src/com/platform/glusterfs/VolumeInfo.java b/src/com/platform/glusterfs/VolumeInfo.java
index f3583102..f30d5d53 100644
--- a/src/com/platform/glusterfs/VolumeInfo.java
+++ b/src/com/platform/glusterfs/VolumeInfo.java
@@ -37,7 +37,7 @@ public class VolumeInfo {
* @see [类、类#方法、类#成员]
*/
public List showAllVolumeName() {
-// log.info("get volume name");
+// log.info(Constant.ganymedSSH+"get volume name");
List volNames = new ArrayList();
/*
@@ -46,6 +46,7 @@ public class VolumeInfo {
* runCommand = new RunCommand(); List reStrings =
* runCommand.runCommandWait(command);
*/
+
List reStrings = Constant.ganymedSSH
.execCmdWaitAcquiescent(Constant.glusterVolumeInfo + "|grep ^Volume.Name");
// System.out.println(reStrings);
@@ -176,7 +177,12 @@ public class VolumeInfo {
log.error("1801 " + volumeName + " is not exists!");
return -1L;
}
- allSize = Long.parseLong(reStrings.get(0));
+ Pattern pattern2 = Pattern.compile("^\\d+$");
+ Matcher matcher2 = pattern2.matcher(reStrings.get(0));
+ // 如果是数字
+ if (matcher2.find()) {
+ allSize = Long.parseLong(reStrings.get(0));
+ }
return allSize;
}
@@ -207,7 +213,12 @@ public class VolumeInfo {
log.error("1902 " + volumeName + " is not exists!");
return -1L;
}
- usedSize = Long.parseLong(reStrings.get(0));
+ Pattern pattern2 = Pattern.compile("^\\d+$");
+ Matcher matcher2 = pattern2.matcher(reStrings.get(0));
+ // 如果是数字
+ if (matcher2.find()) {
+ usedSize = Long.parseLong(reStrings.get(0));
+ }
return usedSize;
}
diff --git a/src/com/platform/oracle/OracleConnector.java b/src/com/platform/oracle/OracleConnector.java
index 923d578b..16f9d09a 100644
--- a/src/com/platform/oracle/OracleConnector.java
+++ b/src/com/platform/oracle/OracleConnector.java
@@ -8,6 +8,7 @@ import java.sql.Statement;
import com.base.Custom4exception;
import com.base.CustomException;
+import com.platform.entities.OracleConnectorParams;
import com.platform.utils.Configs;
import com.platform.utils.FileOperateHelper;
@@ -25,19 +26,23 @@ public class OracleConnector {
public synchronized static Connection ConnectionBuilder(String url, String user,
- String password) {
+ String password, OracleConnectorParams oc) {
Connection conn=null;
try {
conn = DriverManager.getConnection(url, user, password);
} catch (SQLException e) {
new CustomException(Custom4exception.OracleSQL_Except, e);
Configs.CONSOLE_LOGGER.info("创建oracle连接失败: [" + e.getMessage() + "]");
+ if (null != oc) {
+ FileOperateHelper.fileWrite(Configs.EXTRACT_LOG_LOCALTION
+ + oc.getName(), "创建oracle连接失败: [" + e.getMessage() + "]\r\n");
+ }
}
return conn;
}
public synchronized static boolean canConnect(String url, String user, String password) {
- return (null != ConnectionBuilder(url, user, password));
+ return (null != ConnectionBuilder(url, user, password, null));
}
public synchronized static ResultSet getSQLExecResultSet(Connection conn, String sql, String filePath) {
@@ -60,7 +65,7 @@ public class OracleConnector {
public synchronized static ResultSet getSQLExecResultSet(String url, String user,
String password, String sql, String filePath) {
- return getSQLExecResultSet(ConnectionBuilder(url, user, password), sql, filePath);
+ return getSQLExecResultSet(ConnectionBuilder(url, user, password, null), sql, filePath);
}
/**
diff --git a/src/com/platform/service/DataInfoServiceImp.java b/src/com/platform/service/DataInfoServiceImp.java
index 47db7781..b6613af1 100644
--- a/src/com/platform/service/DataInfoServiceImp.java
+++ b/src/com/platform/service/DataInfoServiceImp.java
@@ -1,24 +1,37 @@
package com.platform.service;
import java.util.ArrayList;
+import java.util.Arrays;
import java.util.List;
import java.util.Map;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
import javax.annotation.Resource;
+import org.apache.log4j.Logger;
import org.springframework.stereotype.Service;
import org.springframework.ui.ModelMap;
+import com.base.Custom4exception;
import com.base.CustomException;
import com.platform.dao.DataInfoDao;
import com.platform.entities.DataInfoEntity;
import com.platform.entities.PagerOptions;
+import com.platform.glusterfs.RemoveData;
import com.platform.utils.Bean2MapUtils;
+import com.platform.utils.Configs;
@Service(value = "dataInfoService")
public class DataInfoServiceImp implements DataInfoService {
+
+ /** log4j */
+ public static Logger log = Configs.DAILY_ROLLING_LOGGER;
+
@Resource(name = "dataInfoDao")
private DataInfoDao dfdDao;
+
+ private RemoveData removedata = new RemoveData();
public void setDfdDao(DataInfoDao dfdDao) {
this.dfdDao = dfdDao;
@@ -30,25 +43,56 @@ public class DataInfoServiceImp implements DataInfoService {
String querystr = pagerOptions.getKeyQuery();
String[] querys = null;
try {
+ List removelist = new ArrayList();
+ List alllist = new ArrayList();
+ List list = new ArrayList();
+ //去掉版本字段
+ Pattern pattern = Pattern.compile("^版本\\d+$");
if (null != querystr && !"".equals(querystr)) {
querys = querystr.split(" ");
+ list = Arrays.asList(querys);
+ }
+ //遍历 list
+ for (String ss : alllist) {
+ ss = ss.trim();
+ alllist.add(ss);
+ }
+ for (String ss : alllist) {
+ Matcher matcher2 = pattern.matcher(ss);
+ // 去掉 最后 的 / 符合
+ if (matcher2.find()) {
+ String s2 = matcher2.group();
+ removelist.add(ss);
+ }
+ }
+ alllist.removeAll(removelist);
+ Object[] strs = alllist.toArray();
+ int length = strs.length;
+ String[] arrays = new String[length];
+ for (int i = 0; i < length; i++) {
+ arrays[i] = strs[i].toString();
+ }
+ for (String version : removelist) {
+ pagerOptions.setDataVersion(Integer.valueOf(version.replace("版本", "")));
+ }
+ if (arrays.length > 0) {
+ pagerOptions.setArray(arrays);
}
- pagerOptions.setArray(querys);
int count = dfdDao.getLimitedDataCount(pagerOptions); //获取总记录条数
- System.out.println("total colume " + count);
+ log.info("total colume " + count);
int offset = 0;
if (pagerOptions.getCurrentPageNum() > 1) {
pagerOptions.setTotalLimit((pagerOptions.getCurrentPageNum() - 1)
* pagerOptions.getPriorTableSize());
offset = dfdDao.getLimitedBeginId(pagerOptions); //获取起始查询id
- System.out.println(offset);
+ log.info(offset);
}
pagerOptions.setOffset(offset + 1);
List result = dfdDao
.getLimitedDataInfoEntities(pagerOptions);
if (null != result) {
for (DataInfoEntity dataInfoEntity : result) {
- dataInfoEntity.setVolumeType(Integer.valueOf(dataInfoEntity.getMark()));
+ dataInfoEntity.setVolumeType(dataInfoEntity.getMark());
}
}
modelMap.addAttribute("data", result);
@@ -70,9 +114,24 @@ public class DataInfoServiceImp implements DataInfoService {
//数据在不在?
List paths = dfdDao.getIdIsExist(ids);
if(paths.size()>0){
- //删除文件操作
+ //TODO 删除文件操作
+ Pattern pattern = Pattern
+ .compile("\\/$");
for (int i = 0; i < paths.size(); i++) {
- System.out.println(paths.get(i));
+ String folderPath = paths.get(i);
+ Matcher matcher = pattern.matcher(folderPath);
+ String tailPath = "";
+ if (matcher.find()) {
+ tailPath = matcher.group();
+ }
+ folderPath = folderPath.substring(0, folderPath.length()-tailPath.length());
+ int res = removedata.deleteFolder(folderPath);
+ if (res != 1) {
+ log.error( folderPath+ " 删除失败!\n");
+ }
+ else {
+ log.info( folderPath+ " 删除成功!\n");
+ }
}
//删除数据库记录
dfdDao.removes(ids);
@@ -86,8 +145,8 @@ public class DataInfoServiceImp implements DataInfoService {
try {
result = dfdDao.save(data);
} catch (Exception e) {
- // TODO: handle exception
- System.out.println("");
+ result = -1;
+ new CustomException(Custom4exception.MySQL_Except, e, data);
}
return result;
}
diff --git a/src/com/platform/service/IVolumeService.java b/src/com/platform/service/IVolumeService.java
new file mode 100644
index 00000000..653bded8
--- /dev/null
+++ b/src/com/platform/service/IVolumeService.java
@@ -0,0 +1,16 @@
+package com.platform.service;
+
+import com.platform.entities.VolumeEntity;
+import com.platform.entities.VolumeInitEntity;
+
+public interface IVolumeService {
+
+ public int save(VolumeEntity entity) throws Exception;
+
+ public int delete(VolumeEntity entity) throws Exception;
+
+ public int start(VolumeEntity entity) throws Exception;
+
+ public int stop(VolumeEntity entity) throws Exception;
+
+}
diff --git a/src/com/platform/service/OracleExtractHelper.java b/src/com/platform/service/OracleExtractHelper.java
index 26d5643d..d2e688a9 100644
--- a/src/com/platform/service/OracleExtractHelper.java
+++ b/src/com/platform/service/OracleExtractHelper.java
@@ -35,7 +35,7 @@ public class OracleExtractHelper {
.fileWrite(filePath, sql+ "\r\n"+"OK \r\n");
} catch (Exception e) {
FileOperateHelper
- .fileWrite(filePath, sql+ "\r\n"+ e.getMessage() + " \r\n");
+ .fileWrite(filePath, sql+ "\r\n"+ e.getMessage() + "\r\n,连接异常! \r\n");
new CustomException(Custom4exception.threadVolume_Oracle_Except, e, rSet);
}
return flag;
diff --git a/src/com/platform/service/OracleExtractService.java b/src/com/platform/service/OracleExtractService.java
index 1b23ed7c..23df97ce 100644
--- a/src/com/platform/service/OracleExtractService.java
+++ b/src/com/platform/service/OracleExtractService.java
@@ -13,7 +13,7 @@ public class OracleExtractService extends Thread implements Runnable {
public OracleExtractService(OracleConnectorParams ocp){
this.ocp=ocp;
String url = "";
- this.conn=OracleConnector.ConnectionBuilder(url, Configs.GATHER_USER_NAME, Configs.GATHER_USER_PASSWORD);
+ this.conn=OracleConnector.ConnectionBuilder(url, Configs.GATHER_USER_NAME, Configs.GATHER_USER_PASSWORD, null);
}
@Override
public void run() {
diff --git a/src/com/platform/service/impl/MoveDataServiceImpl.java b/src/com/platform/service/impl/MoveDataServiceImpl.java
index 7adb04dd..b3aca0e8 100644
--- a/src/com/platform/service/impl/MoveDataServiceImpl.java
+++ b/src/com/platform/service/impl/MoveDataServiceImpl.java
@@ -14,9 +14,11 @@ import org.springframework.stereotype.Service;
import com.platform.dao.DataInfoDao;
import com.platform.dao.DataInfoMoveTmpDao;
+import com.platform.dao.VolumeDao;
import com.platform.entities.DataInfoEntity;
import com.platform.entities.DataInfoEntityMoveTmp;
import com.platform.entities.FolderNode;
+import com.platform.entities.VolumeInitEntity;
import com.platform.glusterfs.CheckoutMD5;
import com.platform.glusterfs.CopyData;
import com.platform.glusterfs.RemoveData;
@@ -32,6 +34,9 @@ public class MoveDataServiceImpl implements IMoveDataService {
@Resource(name = "dataInfoDao")
private DataInfoDao dataInfoDao;
+
+ @Resource(name = "volumeDao")
+ private VolumeDao volumeDao;
private RemoveData removeservice = new RemoveData();
@@ -63,12 +68,17 @@ public class MoveDataServiceImpl implements IMoveDataService {
if (null ==node.getPath() ||"".equals(node.getPath())) {
return false;
}
+ List listVolume = volumeDao.findAll();
+ if (null == listVolume || listVolume.size() == 0) {
+ return false;
+ }
String tailPath = "";
if (null != data) {
// XXX/320198_16/1,or XXX/320122KFQ_15/1 ---> /320198_16/1, or
// /320122KFQ_15/1
List exist = dataInfoMoveTmpDao.findAll();
List existIds = new ArrayList();
+ List fkIds = new ArrayList();
if (null != exist) {
for (DataInfoEntityMoveTmp dataInfoEntityMoveTmp : exist) {
if ("0".equals(dataInfoEntityMoveTmp.getCompleteStatus())
@@ -77,6 +87,7 @@ public class MoveDataServiceImpl implements IMoveDataService {
if (null != dataInfoEntityMoveTmp.getDataPath()) {
existIds.add(dataInfoEntityMoveTmp.getDataPath());
}
+ fkIds.add(dataInfoEntityMoveTmp.getFkid());
}
}
}
@@ -95,6 +106,12 @@ public class MoveDataServiceImpl implements IMoveDataService {
if (existIds.contains(dataInfoEntity.getDataPath())) {
continue;
}
+ if (dataInfoEntity.getId() == 0) {
+ continue;
+ }
+ if (fkIds.contains(dataInfoEntity.getId())) {
+ continue;
+ }
// TODO 正则:取出 data 的后面 的 路径,eg: XXX/320198_16/1,or
// XXX/320122KFQ_15/1)
Matcher matcher = pattern.matcher(dataInfoEntity.getDataPath());
@@ -114,11 +131,30 @@ public class MoveDataServiceImpl implements IMoveDataService {
dataMove.setDstPath(finalDestPath);
dataMove.setLastTime(DateForm.date2StringBysecond(new Date()));
dataMove.setFkid(dataInfoEntity.getId());
- dataMove.setVolumePath(node.getName());
+ // 末尾 含有 /
+ Matcher matcher3 = pattern2.matcher(node.getPath());
+ // 去掉 最后 的 / 符合
+ String volumePath = "";
+ if (!matcher3.find()) {
+ volumePath = node.getPath()+"/";
+ }
+ else {
+ volumePath = node.getPath();
+ }
+ for ( VolumeInitEntity ve : listVolume) {
+ if (volumePath.contains(ve.getPath())) {
+ dataMove.setDstVolumePath(ve.getPath());
+ dataMove.setDstVolumeIp(ve.getIp());
+ break;
+ }
+ }
moveList.add(dataMove);
}
if (moveList.size() > 0) {
dataInfoMoveTmpDao.insertBatch(moveList);
+// for (DataInfoEntityMoveTmp dataInfoEntityMoveTmp2 : moveList) {
+// dataInfoMoveTmpDao.save(dataInfoEntityMoveTmp2);
+// }
isSuccess = true;
}
}
diff --git a/src/com/platform/service/impl/MySqlServiceImpl.java b/src/com/platform/service/impl/MySqlServiceImpl.java
index 7efaa3f8..5f3d1a44 100644
--- a/src/com/platform/service/impl/MySqlServiceImpl.java
+++ b/src/com/platform/service/impl/MySqlServiceImpl.java
@@ -1,5 +1,6 @@
package com.platform.service.impl;
+import java.sql.Connection;
import java.util.List;
import javax.annotation.Resource;
@@ -8,6 +9,7 @@ import org.springframework.stereotype.Service;
import com.platform.dao.GatherOracleDao;
import com.platform.entities.GatherOracleInfo;
+import com.platform.oracle.OracleConnector;
import com.platform.service.IMySqlService;
@Service(value = "mySqlService")
@@ -37,12 +39,20 @@ public class MySqlServiceImpl implements IMySqlService{
}
public int insertOracle(GatherOracleInfo oracle) throws Exception {
+ //TODO 连接oracle,
int result = gatherOracleDao.insertOracle(oracle);
return result;
}
@Override
public int updateOracle(GatherOracleInfo oracle) throws Exception {
+ int status = 1;
+ Connection conn = null /*OracleConnector.ConnectionBuilder("jdbc:oracle:thin:@" + oracle.getIp() + ":" + oracle.getPort() + ":"
+ + oracle.getDatabaseName(), oracle.getUser(), oracle.getPassword())*/;
+ if (null == conn) {
+ status = 0;
+ }
+ oracle.setStatus(status);
int result;
if (oracle.getId() > 0) {
result = gatherOracleDao.updateOracleById(oracle);
diff --git a/src/com/platform/service/impl/OracleExtractServiceImpl.java b/src/com/platform/service/impl/OracleExtractServiceImpl.java
index 908dc4c9..a53bef9b 100644
--- a/src/com/platform/service/impl/OracleExtractServiceImpl.java
+++ b/src/com/platform/service/impl/OracleExtractServiceImpl.java
@@ -19,6 +19,7 @@ import com.platform.service.IOracleExtractService;
import com.platform.service.OracleExtractHelper;
import com.platform.utils.Configs;
import com.platform.utils.Constant;
+import com.platform.utils.FileOperateHelper;
@Service(value = "OracleExtract")
public class OracleExtractServiceImpl implements IOracleExtractService {
@@ -48,8 +49,16 @@ public class OracleExtractServiceImpl implements IOracleExtractService {
GatherOracleInfo oracleModel = oracleConnect;
//采集库连接参数
List datainfos = dataInfolist;
+ if (datainfos.size() == 0) {
+ return false;
+ }
Connection conn = OracleConnector.ConnectionBuilder("jdbc:oracle:thin:@" + oracleModel.getIp() + ":" + oracleModel.getPort() + ":"
- + oracleModel.getDatabaseName(), oracleModel.getUser(), oracleModel.getPassword());
+ + oracleModel.getDatabaseName(), oracleModel.getUser(), oracleModel.getPassword(),dataInfolist.get(0));
+ if (null == conn) {
+ FileOperateHelper.fileWrite(Configs.EXTRACT_LOG_LOCALTION
+ + dataInfolist.get(0).getName(), "创建oracle连接失败: [" + conn + "]\r\n");
+ return false;
+ }
for (OracleConnectorParams collectOracle : datainfos) {
if(null != collectOracle.getDataId() && !"".equals(collectOracle.getDataId())){
diff --git a/src/com/platform/service/impl/VolumeServiceImpl.java b/src/com/platform/service/impl/VolumeServiceImpl.java
new file mode 100644
index 00000000..1884d8c9
--- /dev/null
+++ b/src/com/platform/service/impl/VolumeServiceImpl.java
@@ -0,0 +1,166 @@
+package com.platform.service.impl;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+import javax.annotation.Resource;
+
+import org.springframework.stereotype.Service;
+
+import com.platform.dao.VolumeDao;
+import com.platform.entities.Brick;
+import com.platform.entities.VolumeEntity;
+import com.platform.entities.VolumeInitEntity;
+import com.platform.glusterfs.SetVolume;
+import com.platform.service.IGfsService;
+import com.platform.service.IVolumeService;
+
+@Service(value = "volumeService")
+public class VolumeServiceImpl implements IVolumeService {
+
+ /** gfs的api */
+ SetVolume volumeService = new SetVolume();
+
+ @Resource(name = "gfsService")
+ private IGfsService gfsService;
+
+ @Resource(name = "volumeDao")
+ private VolumeDao volumeDao;
+
+
+ @Override
+ public int save(VolumeEntity entity) throws Exception {
+ //createVolume("lili_test1", 0, "distributed", bricksToCreate, "/home/lili_test1_point")
+ List result = gfsService.getAllVolumes();
+ List addVolumes = new ArrayList();
+ VolumeEntity volumeTmp = null;
+ if (null != result) {
+ boolean isExits = false;
+ //.trim() 去掉空格
+ for (VolumeEntity volumeOnServer : result) {
+ if(entity.getName().trim().equals(volumeOnServer.getName().trim())){
+ isExits = true;
+ //TODO 服务器上有该volume,
+ volumeTmp = volumeOnServer;
+ break;
+ }
+ }
+ //如果服务器上没有该volume,
+ if (!isExits) {
+ addVolumes.add(entity);
+ }
+
+ }
+ boolean isContinue = true;
+ // 对比volume信息--原数据没有该volume,则新增volume:
+ for (VolumeEntity add : addVolumes) {
+ List bristr = new ArrayList();
+ if (null == add.getName() || "".equals(add.getName())) {
+ continue;
+ }
+ if (null == add.getPath() || "".equals(add.getPath())) {
+ continue;
+ }
+ for ( Brick bri : add.getBrick()) {
+ if (null == bri.getIp() || "".equals(bri.getIp())) {
+ continue;
+ }
+ if (null == bri.getPath() || "".equals(bri.getPath())) {
+ continue;
+ }
+ bristr.add(bri.getIp()+":"+bri.getPath());
+ };
+
+ //创建volume
+ if (bristr.size() > 0) {
+ volumeService.createVolume(add.getName(), 0, "distributed", bristr, add.getPath());
+ }
+ //记录volume信息,
+ VolumeInitEntity volInSql = new VolumeInitEntity();
+ volInSql.setName(add.getName());
+ volInSql.setPath(add.getPath());
+ volumeDao.save(volInSql);
+ isContinue = false;
+ }
+ // 修改 brick
+ if (isContinue && null != volumeTmp) {
+ List newBricks = entity.getBrick();
+ List serverBricks = volumeTmp.getBrick();
+ Map newMap = new HashMap();
+ Map serverMap = new HashMap();
+ for (Brick brick : newBricks) {
+ //IP + path 才 确认唯一的 brick
+ newMap.put(brick.getIp().trim() + ":" + brick.getPath().trim(), null);
+ }
+ for (Brick brick : serverBricks) {
+ serverMap.put(brick.getIp().trim() + ":" + brick.getPath().trim(), null);
+ }
+ // ----对比volume信息--原数据有该volume,则对比brick信息,确认那几个brick是新增的,那几个brick是待删除的----start
+ Set newBrickKeys = newMap.keySet();
+ Set serverBrickKeys = serverMap.keySet();
+ //新增的Brick的 Keys
+ List newKeys = new ArrayList();
+ newBrickKeys.removeAll(serverBrickKeys);
+ newKeys.addAll(newBrickKeys);
+ // 新增brick s,
+ if (newKeys.size() > 0) {
+ volumeService.addBrickVolume(entity.getName(), newKeys, 0, "distributed");
+ }
+ //待删除的Brick的 Keys
+ for (Brick brick : newBricks) {
+ //IP + path 才 确认唯一的 brick
+ newMap.put(brick.getIp().trim() + ":" + brick.getPath().trim(), null);
+ }
+ newBrickKeys = newMap.keySet();
+ serverBrickKeys.removeAll(newBrickKeys);
+ List deleteKeys = new ArrayList();
+ deleteKeys.addAll(serverBrickKeys);
+ // 删除brick s,
+ if (deleteKeys.size() > 0) {
+ volumeService.deleteBrickVolume(entity.getName(), deleteKeys, 0, "distributed");
+ }
+ // ---对比volume信息--原数据有该volume,则对比brick信息,确认那几个brick是新增的,那几个brick是待删除的----- end
+
+ //TODO 查看状态 状态Started,Stopped,Created
+ if (volumeTmp.isStatus() != entity.isStatus()) {
+ if (entity.isStatus()) {
+ this.start(entity);
+ }
+ else{
+ this.stop(entity);
+ }
+ }
+ }
+ return 0;
+ }
+
+ @Override
+ public int delete(VolumeEntity entity) throws Exception {
+ if (null == entity.getName() || "".equals(entity.getName())) {
+ return -1;
+ }
+ volumeService.deleteVolume(entity.getName());
+ volumeDao.remove(entity.getName());
+ return 0;
+ }
+
+ @Override
+ public int start(VolumeEntity entity) throws Exception {
+ if (null == entity.getName() || "".equals(entity.getName())) {
+ return -1;
+ }
+ return volumeService.startVolume(entity.getName());
+ }
+
+ @Override
+ public int stop(VolumeEntity entity) throws Exception {
+ if (null == entity.getName() || "".equals(entity.getName())) {
+ return -1;
+ }
+ return volumeService.stopVolume(entity.getName());
+ }
+
+}
diff --git a/src/com/platform/service/thread/ThreadMoveData.java b/src/com/platform/service/thread/ThreadMoveData.java
index a178ff0a..569a62b0 100644
--- a/src/com/platform/service/thread/ThreadMoveData.java
+++ b/src/com/platform/service/thread/ThreadMoveData.java
@@ -101,12 +101,20 @@ public class ThreadMoveData{
srcSizeTemp = show.getFolderSize(dataMove.getDataPath());
long srcSize = (long) (srcSizeTemp * 0.998);
dstSize = show.getFolderSize(dataMove.getDstPath());
+ boolean isExist = false;
if (srcSize < 0) {
log.error(dataMove.getDataPath() + " : 路径不存在! ");
- continue;
+ isExist = true;
}
if (dstSize < 0) {
log.error(dataMove.getDstPath() + " : 路径不存在! ");
+ isExist = true;
+ }
+ if (isExist) {
+ // 3:表示 迁移失败
+ dataMove.setLastTime(DateForm.date2StringBysecond(new Date()));
+ dataMove.setCompleteStatus("3");
+ dataInfoMoveTmpDao.update(dataMove);
continue;
}
if (srcSize > 0 && dstSize > 0) {
@@ -138,11 +146,13 @@ public class ThreadMoveData{
data.setDataPath(dataMove.getDstPath());
data.setVolumeIp(dataMove.getDstVolumeIp());
data.setVolumePath(dataMove.getDstVolumePath());
- data.setYear(DateForm.date2StringByMin(new Date()));
+ data.setVolumeIp(dataMove.getVolumeIp());
+ data.setId(0);
dataInfoDao.save(data);
}
else {
// 3:表示 迁移失败
+ dataMove.setLastTime(DateForm.date2StringBysecond(new Date()));
dataMove.setCompleteStatus("3");
}
}
diff --git a/src/com/platform/utils/CacheTreeData.java b/src/com/platform/utils/CacheTreeData.java
index 742df9a2..18bde5ce 100644
--- a/src/com/platform/utils/CacheTreeData.java
+++ b/src/com/platform/utils/CacheTreeData.java
@@ -16,7 +16,7 @@ public class CacheTreeData {
return folders;
}
- public static void setFolders(List folders) {
+ public synchronized static void setFolders(List folders) {
CacheTreeData.folders = folders;
}
@@ -30,7 +30,7 @@ public class CacheTreeData {
/**
* @param volumeList the volumeList to set
*/
- public static void setVolumeList(List volumeList) {
+ public synchronized static void setVolumeList(List volumeList) {
CacheTreeData.volumeList = volumeList;
}
diff --git a/src/com/platform/utils/ConfigsLoader.java b/src/com/platform/utils/ConfigsLoader.java
index 56745ce0..342f493d 100644
--- a/src/com/platform/utils/ConfigsLoader.java
+++ b/src/com/platform/utils/ConfigsLoader.java
@@ -1,10 +1,13 @@
package com.platform.utils;
+import java.util.HashMap;
import java.util.Properties;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
+import ch.ethz.ssh2.Connection;
+
public class ConfigsLoader implements ServletContextListener {
private static ConfigPropertyReader cReader = null;
@@ -23,7 +26,7 @@ public class ConfigsLoader implements ServletContextListener {
+ "WEB-INF/config/config.properties";
this.cReader = ConfigPropertyReader.Builder(contextPath);
init();
- new ThreadVolume("").start();
+ new ThreadVolume("ThreadVolume-in-ConfigsLoader").start();
}
public static void init() {
@@ -60,6 +63,12 @@ public class ConfigsLoader implements ServletContextListener {
.getProperty("gather-tablespace-path");
Configs.GATHER_TABLE_PASSWORD=properties.getProperty("gather-table-user-password");
+
+
+ Constant.hostIp=properties.getProperty("gfs_control_ip").trim();
+ Constant.rootPasswd=properties.getProperty("gfs_control_rootPassWd").trim();
+ Constant.ganymedSSH = new GanymedSSH(Constant.hostIp, Constant.rootUser, Constant.rootPasswd, Constant.port);
+
}
public ConfigPropertyReader getcReader() {
diff --git a/src/com/platform/utils/Constant.java b/src/com/platform/utils/Constant.java
index d0eb303b..1f283d67 100644
--- a/src/com/platform/utils/Constant.java
+++ b/src/com/platform/utils/Constant.java
@@ -1,49 +1,50 @@
-
-package com.platform.utils;
-
-
-public class Constant {
- public static String rootUser = "root";
- public static String rootPasswd = "root";
- public static String hostIp = "192.168.0.110";
- // public static String hostIp = "192.168.1.105";
- public static int port = 22;
- public static String glusterPeerStatus = "gluster peer status";
- public static String glusterVolumeInfo = "gluster volume info ";
- public static String df = "df -k ";
- public static String peerincluster_connected = "PeerinCluster(Connected)";
- public static String peerincluster_disconnected = "PeerinCluster(Disconnected)";
- public static String peerNotinCluster = "PeerNotinCluster";
- public static String distributed = "distributed";
- public static String replica = "replica";
- public static String stripe = "stripe";
- public static String noVolume = "No volumes present";
- public static String success = "success";
- public static String failed = "failed";
- public static String noSuchFile = "No such file or directory";
- public static GanymedSSH ganymedSSH = new GanymedSSH(hostIp, rootUser, rootPasswd, port);
- public static String fileGetTreeData = "WebContent\\WEB-INF\\config\\getTreedata.sh";
- public static String AutoMountfile="/gfsAutoMount/AutoRun.sh";
- public static String MountRecord="/gfsAutoMount/mountPoint.record";
- public static String strGetTreeData = "function ergodic(){\n "
- + "for file in \\`ls \\$1\\`\n do\n if [ \"\\$file\" != \"app\" -a -d \\$1\\\"/\\\"\\$file ]\n "
- + "then\n ergodic \\$1\"/\"\\$file\n else\n local path=\\$1\"/\"\\$file\n "
- + "echo \\$path \n fi\n done\n}\n\nIFS=\\$\\'\\n\\' "
- + "#这个必须要,否则会在文件名中有空格时出错\nINIT_PATH=\".\";\nergodic \\$1\n";
-
- /**
- * volume 获取的线程休眠时间
- */
- public final static int moveFileMaxNum = 1;
-
- /**
- * volume 获取的线程休眠时间
- */
- public final static int get_volume_sleep_time = 600000;
-
- /**
- * volume 获取的线程休眠时间
- */
- public final static int update_dataInfo_sleep_time = 30000;
-
-}
+
+package com.platform.utils;
+
+import java.util.HashMap;
+
+public class Constant {
+ public static String rootUser = "root";
+ public static String rootPasswd = "root";
+// public static String hostIp = "192.168.191.23";
+ public static String hostIp = "";
+ public static int port = 22;
+ public static String glusterPeerStatus = "gluster peer status";
+ public static String glusterVolumeInfo = "gluster volume info ";
+ public static String df = "df -k ";
+ public static String peerincluster_connected = "PeerinCluster(Connected)";
+ public static String peerincluster_disconnected = "PeerinCluster(Disconnected)";
+ public static String peerNotinCluster = "PeerNotinCluster";
+ public static String distributed = "distributed";
+ public static String replica = "replica";
+ public static String stripe = "stripe";
+ public static String noVolume = "No volumes present";
+ public static String success = "success";
+ public static String failed = "failed";
+ public static String noSuchFile = "No such file or directory";
+ public static GanymedSSH ganymedSSH = null;
+ public static String fileGetTreeData = "WebContent\\WEB-INF\\config\\getTreedata.sh";
+ public static String AutoMountfile="/gfsAutoMount/AutoRun.sh";
+ public static String MountRecord="/gfsAutoMount/mountPoint.record";
+ public static String strGetTreeData = "function ergodic(){\n "
+ + "for file in \\`ls \\$1\\`\n do\n if [ \"\\$file\" != \"app\" -a -d \\$1\\\"/\\\"\\$file ]\n "
+ + "then\n ergodic \\$1\"/\"\\$file\n else\n local path=\\$1\"/\"\\$file\n "
+ + "echo \\$path \n fi\n done\n}\n\nIFS=\\$\\'\\n\\' "
+ + "#这个必须要,否则会在文件名中有空格时出错\nINIT_PATH=\".\";\nergodic \\$1\n";
+
+ /**
+ * volume 获取的线程休眠时间
+ */
+ public final static int moveFileMaxNum = 1;
+
+ /**
+ * volume 获取的线程休眠时间
+ */
+ public final static int get_volume_sleep_time = 10000;
+
+ /**
+ * volume 获取的线程休眠时间
+ */
+ public final static int update_dataInfo_sleep_time = 1500;
+
+}
diff --git a/src/com/platform/utils/GanymedSSH.java b/src/com/platform/utils/GanymedSSH.java
index 194be049..611f4e5e 100644
--- a/src/com/platform/utils/GanymedSSH.java
+++ b/src/com/platform/utils/GanymedSSH.java
@@ -23,8 +23,8 @@ import ch.ethz.ssh2.*;
public class GanymedSSH {
public static Logger log = Logger.getLogger(GanymedSSH.class);
- Connection conn;
-
+ Connection conn;
+ public Map otherConns;
public boolean status = true;// 锟角凤拷锟斤拷锟街达拷锟斤拷锟斤拷锟阶刺�
public GanymedSSH() {
@@ -36,6 +36,7 @@ public class GanymedSSH {
// TODO Auto-generated constructor stub
try {
conn = getOpenedConnection(host, username, password, port);
+ otherConns=new HashMap();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
@@ -44,22 +45,22 @@ public class GanymedSSH {
}
- public Connection getOpenedConnection(String host, String username, String password, int port)
+ public static Connection getOpenedConnection(String host, String username, String password, int port)
throws IOException {
- conn = new Connection(host, port);
- conn.connect(); // make sure the connection is opened
- boolean isAuthenticated = conn.authenticateWithPassword(username, password);
+ Connection conns = new Connection(host, port);
+ conns.connect(); // make sure the connection is opened
+ boolean isAuthenticated = conns.authenticateWithPassword(username, password);
if (isAuthenticated == false)
throw new IOException("Authentication failed.");
- return conn;
+ return conns;
}
public void execCmdNoWaitAcquiescent(String cmd) {
- String host=Constant.hostIp;
- String username=Constant.rootUser;
- String password=Constant.rootPasswd;
- int port=Constant.port;
+// String host=Constant.hostIp;
+// String username=Constant.rootUser;
+// String password=Constant.rootPasswd;
+// int port=Constant.port;
Session sess = null;
try {
@@ -79,9 +80,19 @@ public class GanymedSSH {
public void execCmdNoWait(String host, String username, String password, int port, String cmd) {
Session sess = null;
+ Connection new_conn;
try {
- conn = getOpenedConnection(host, username, password, port);
- sess = conn.openSession();
+ if(Constant.hostIp.equals(host)){
+ new_conn=conn;
+ }
+ else if(otherConns.containsKey(host) && otherConns.get(host)!=null){
+ new_conn=otherConns.get(host);
+ }
+ else{
+ new_conn = getOpenedConnection(host, username, password, port);
+ otherConns.put(host, new_conn);
+ }
+ sess = new_conn.openSession();
// 执锟斤拷cmd
sess.execCommand(cmd);
} catch (IOException e) {
@@ -94,15 +105,15 @@ public class GanymedSSH {
}
public List execCmdWaitAcquiescent(String cmd) {
- String host=Constant.hostIp;
- String username=Constant.rootUser;
- String password=Constant.rootPasswd;
- int port=Constant.port;
+// String host=Constant.hostIp;
+// String username=Constant.rootUser;
+// String password=Constant.rootPasswd;
+// int port=Constant.port;
List reStrings = new ArrayList();
Session sess = null;
try {
-
+// conn = getOpenedConnection(host, username, password, port);
sess = conn.openSession();
// 执锟斤拷cmd
sess.execCommand(cmd);
@@ -112,7 +123,7 @@ public class GanymedSSH {
BufferedReader stdoutReader = new BufferedReader(new InputStreamReader(stdout));
BufferedReader stderrReader = new BufferedReader(new InputStreamReader(stderr));
while (true) {
- String line = stderrReader.readLine();
+ String line = stdoutReader.readLine();
if (line != null) {
// System.out.println(line);
@@ -124,7 +135,7 @@ public class GanymedSSH {
if(reStrings.size()==0){
while (true) {
- String line = stdoutReader.readLine();
+ String line = stderrReader.readLine();
if (line != null) {
// System.out.println(line);
@@ -138,7 +149,9 @@ public class GanymedSSH {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
- sess.close();
+ if (null != sess) {
+ sess.close();
+ }
}
return reStrings;
@@ -148,9 +161,19 @@ public class GanymedSSH {
List reStrings = new ArrayList();
Session sess = null;
+ Connection new_conn;
try {
-
- sess = conn.openSession();
+ if(Constant.hostIp.equals(host)){
+ new_conn=conn;
+ }
+ else if(otherConns.containsKey(host) && otherConns.get(host)!=null){
+ new_conn=otherConns.get(host);
+ }
+ else{
+ new_conn = getOpenedConnection(host, username, password, port);
+ otherConns.put(host, new_conn);
+ }
+ sess = new_conn.openSession();
// 执锟斤拷cmd
sess.execCommand(cmd);
diff --git a/src/com/platform/utils/ThreadVolume.java b/src/com/platform/utils/ThreadVolume.java
index 03832e9e..9023ad79 100644
--- a/src/com/platform/utils/ThreadVolume.java
+++ b/src/com/platform/utils/ThreadVolume.java
@@ -15,111 +15,49 @@ import com.platform.glusterfs.ClusterInfo;
import com.platform.glusterfs.GetTreeData;
import com.platform.glusterfs.VolumeInfo;
-public class ThreadVolume extends Thread implements Runnable{
-
+public class ThreadVolume extends Thread {
+
/**
* 挂载点路径 -- 暂时无用的
*/
private static String pointPath = "/home";
-
- /** Volume信息查询 */
+
+ /** Volume信息查询 */
private VolumeInfo volumeInfo = new VolumeInfo();
-
+
private ClusterInfo cluster = new ClusterInfo();
-
+
public ThreadVolume() {
// TODO Auto-generated constructor stub
}
-
- public ThreadVolume(String path) {
+
+ public ThreadVolume(String name) {
+ setName(name);
+ }
+
+ public ThreadVolume(String name, String path) {
if (null != path && !"".equals(path.trim())) {
ThreadVolume.pointPath = path;
}
}
-
- /** gfs目录树形展示 */
+
+ /** gfs目录树形展示 */
private GetTreeData gfsTree = new GetTreeData();
-
+
@Override
public void run() {
super.run();
- while(true){
- List folderlist = new ArrayList();
- List volumeList = new ArrayList();
- // brick状态 map集合
- Map brickStatusMap = cluster.showClusterInfo();
-
- //查询 volume name
- List volumeNameList = volumeInfo.showAllVolumeName();
- if (null != volumeNameList) {
- for (String volumeName : volumeNameList) {
- try {
- VolumeEntity volume = new VolumeEntity();
- volume.setName(volumeName);
- List path = volumeInfo.getVolumeMountPoint(volumeName);
- //默认加载第一个路径
- if (null != path && path.size() > 0) {
- volume.setPath(path.get(0));
- }
- volume.setAllSize(volumeInfo.getVolumeAvailableSize(volumeName));
- volume.setStatus(volumeInfo.getVolumeStatus(volumeName));
- volume.setUsedSize(volumeInfo.getVolumeUseSize(volumeName));
- volume.setType(volumeInfo.getVolumeType(volumeName));
- //TODO 查询brick--
- //返回 ip:path
- List brickStrs = volumeInfo.getVolumeBricks(volumeName);
- //brick已用大小:
- Map usedSize = volumeInfo.getVolumebricksDataSize(volumeName);
- Map availableSize = volumeInfo.getVolumebricksAvailableSize(volumeName);
-
- List brickList = new ArrayList();
- for (String brickIpPath : brickStrs) {
- Brick b = new Brick();
- String ipAndpath[] = brickIpPath.split(":");
- String brickip = ipAndpath[0];
- String brickpath = ipAndpath[1];
- //iP , path ,
- b.setIp(brickip);
- if(brickStatusMap==null || brickStatusMap.size()==0){
- b.setStatus(false);
- }else if (brickStatusMap.containsKey(brickip)) {
- b.setStatus(true);
- }
- else {
- b.setStatus(false);
- }
- b.setPath(brickpath);
- b.setAvailableSize(availableSize.get(brickIpPath));
- b.setUsedSize(usedSize.get(brickIpPath));
- brickList.add(b);
- }
- volume.setBrick(brickList);
-
-
- //默认加载第一个路径
- if (null != path && path.size() > 0) {
- //装入 folder:
- //查询 每个 volume 下的 folder
- FolderNode foldertmp = gfsTree.getDatas(path.get(0));
- folderlist.add(foldertmp);
- }
- volumeList.add(volume);
- }catch (Exception e) {
- new CustomException(Custom4exception.threadVolume_class_Except,e);
- }
- }
- }
- //TODO 更新folder 目录
- CacheTreeData.setFolders(folderlist);
- CacheTreeData.setVolumeList(volumeList);
- try {
- Thread.sleep(Constant.get_volume_sleep_time);
- } catch (InterruptedException e) {
- new CustomException(Custom4exception.threadVolume_Thread_Except,e);
- }
-
+ while (true) {
+ try {
+ getVolumeMsg();
+ Thread.sleep(Constant.get_volume_sleep_time);
+ } catch (InterruptedException e) {
+ new CustomException(
+ Custom4exception.threadVolume_Thread_Except, e);
+ }
+
}
-
+
}
public static String getPointPath() {
@@ -129,5 +67,93 @@ public class ThreadVolume extends Thread implements Runnable{
public static void setPointPath(String pointPath) {
ThreadVolume.pointPath = pointPath;
}
-
+
+ public void getVolumeMsg() {
+ List folderlist = new ArrayList();
+ List volumeList = new ArrayList();
+ // brick状态 map集合
+ Map brickStatusMap = cluster.showClusterInfo();
+
+ // 查询 volume name
+ List volumeNameList = volumeInfo.showAllVolumeName();
+ if (null != volumeNameList) {
+ for (String volumeName : volumeNameList) {
+ try {
+ VolumeEntity volume = new VolumeEntity();
+ volume.setName(volumeName);
+ List path = volumeInfo
+ .getVolumeMountPoint(volumeName);
+ // 默认加载第一个路径
+ for (String one : path) {
+ if (!one.contains("df")) {
+ volume.setPath(one);
+ }
+ }
+ if (null == volume.getPath()) {
+ volume.setPath("");
+ }
+ volume.setAllSize(volumeInfo
+ .getVolumeAvailableSize(volumeName)
+ + volumeInfo.getVolumeUseSize(volumeName));
+ // 状态Started,Stopped,Created
+ String status = volumeInfo.getVolumeStatus(volumeName);
+ if ("Started".equals(status)) {
+ volume.setStatus(true);
+ } else {
+ volume.setStatus(false);
+ }
+ volume.setUsedSize(volumeInfo.getVolumeUseSize(volumeName));
+ volume.setType(volumeInfo.getVolumeType(volumeName));
+ // TODO 查询brick--
+ // 返回 ip:path
+ List brickStrs = volumeInfo
+ .getVolumeBricks(volumeName);
+ // brick已用大小:
+ Map usedSize = volumeInfo
+ .getVolumebricksDataSize(volumeName);
+ Map availableSize = volumeInfo
+ .getVolumebricksAvailableSize(volumeName);
+
+ List brickList = new ArrayList();
+ for (String brickIpPath : brickStrs) {
+ Brick b = new Brick();
+ String ipAndpath[] = brickIpPath.split(":");
+ String brickip = ipAndpath[0];
+ String brickpath = ipAndpath[1];
+ // iP , path ,
+ b.setIp(brickip);
+ if (brickStatusMap == null
+ || brickStatusMap.size() == 0) {
+ b.setStatus(false);
+ } else if (brickStatusMap.containsKey(brickip)) {
+ b.setStatus(true);
+ } else {
+ b.setStatus(false);
+ }
+ b.setPath(brickpath);
+ b.setAvailableSize(availableSize.get(brickIpPath));
+ b.setUsedSize(usedSize.get(brickIpPath));
+ brickList.add(b);
+ }
+ volume.setBrick(brickList);
+
+ // 默认加载第一个路径
+ if (null != path && path.size() > 0) {
+ // 装入 folder:
+ // 查询 每个 volume 下的 folder
+ FolderNode foldertmp = gfsTree.getDatas(path.get(0));
+ folderlist.add(foldertmp);
+ }
+ volumeList.add(volume);
+ } catch (Exception e) {
+ new CustomException(
+ Custom4exception.threadVolume_class_Except, e);
+ }
+ }
+ }
+ // 更新folder 目录
+ CacheTreeData.setFolders(folderlist);
+ CacheTreeData.setVolumeList(volumeList);
+ }
+
}
diff --git a/src/com/platform/utils/ThreadVolumeImm.java b/src/com/platform/utils/ThreadVolumeImm.java
new file mode 100644
index 00000000..beaa5613
--- /dev/null
+++ b/src/com/platform/utils/ThreadVolumeImm.java
@@ -0,0 +1,18 @@
+package com.platform.utils;
+
+public class ThreadVolumeImm extends Thread{
+
+ public ThreadVolumeImm() {
+ // TODO Auto-generated constructor stub
+ }
+
+ public ThreadVolumeImm(String name) {
+ setName(name);
+ }
+
+ @Override
+ public void run() {
+ new ThreadVolume().getVolumeMsg();
+ }
+
+}