¶Ô±ÈÐÂÎļþ |
| | |
| | | package com.product.system.backup.service; |
| | | |
| | | import java.io.BufferedReader; |
| | | import java.io.File; |
| | | import java.io.FileInputStream; |
| | | import java.io.FileOutputStream; |
| | | import java.io.FileWriter; |
| | | import java.io.IOException; |
| | | import java.io.InputStream; |
| | | import java.io.InputStreamReader; |
| | | import java.nio.charset.StandardCharsets; |
| | | import java.nio.file.Files; |
| | | import java.nio.file.Path; |
| | | import java.nio.file.Paths; |
| | | import java.text.SimpleDateFormat; |
| | | import java.util.Date; |
| | | import java.util.List; |
| | | import java.util.Map; |
| | | import java.util.Properties; |
| | | import java.util.stream.Collectors; |
| | | import java.util.zip.ZipEntry; |
| | | import java.util.zip.ZipOutputStream; |
| | | |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.stereotype.Service; |
| | | |
| | | import com.alibaba.druid.util.StringUtils; |
| | | import com.jcraft.jsch.Channel; |
| | | import com.jcraft.jsch.ChannelSftp; |
| | | import com.jcraft.jsch.JSch; |
| | | import com.jcraft.jsch.JSchException; |
| | | import com.jcraft.jsch.Session; |
| | | import com.jcraft.jsch.SftpException; |
| | | import com.jcraft.jsch.SftpProgressMonitor; |
| | | import com.product.core.config.Global; |
| | | import com.product.core.dao.BaseDao; |
| | | import com.product.core.entity.DataTableEntity; |
| | | import com.product.core.entity.FieldSetEntity; |
| | | import com.product.core.service.support.AbstractBaseService; |
| | | import com.product.system.backup.entity.BackupLogger; |
| | | |
| | | @Service("systemBackService") |
| | | public class SystemBackupService2 extends AbstractBaseService{ |
| | | |
| | | @Autowired |
| | | BaseDao baseDao; |
| | | |
| | | // å¤ä»½é
ç½® |
| | | Properties config; |
| | | |
| | | // å¤ä»½æ¥å¿ |
| | | BackupLogger log; |
| | | |
| | | // æ°åæ¶é´åæ°åæ¥æï¼ç¨åæä»¶å¤¹æè
æä»¶åï¼ |
| | | String NUMBER_TIME; //ä¾å¦ï¼20250428091001ï¼ |
| | | String NUMBER_DATE; //ä¾å¦ï¼20240428ï¼ |
| | | String STANDARD_START_TIME; // ä¾å¦ï¼2024-04-28 09:10:00ï¼ |
| | | String STANDARD_FINAL_TIME; // ä¾å¦ï¼2024-04-28 09:10:00ï¼ |
| | | |
| | | // æ°åæ¥ææ ¼å¼ |
| | | SimpleDateFormat numberTimeFormat = new SimpleDateFormat("yyyyMMddHHmm00"); |
| | | SimpleDateFormat numberDateFormat = new SimpleDateFormat("yyyyMMdd"); |
| | | SimpleDateFormat standardTimeFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:00"); |
| | | |
| | | // å¤ä»½é
ç½®æä»¶ |
| | | private static final String CONFIG_FILE_PATH = "systemBackup.properties"; |
| | | |
| | | /** |
| | | * ç³»ç»å¤ä»½å¤å® |
| | | * è°ç¨å°ç¹ï¼å®æ¶ä»»å¡é
ç½®åè½(bean) |
| | | */ |
| | | public void systemBackupInit() { |
| | | // è·åç³»ç»æ¶é´ |
| | | Date finalTime = new Date(); |
| | | Date startTime = null; |
| | | // è·åç³»ç»å¤ä»½å¨æ(åé) |
| | | int backupCycle = Integer.valueOf(Global.getSystemConfig("SYSTEM_BACK_CYCLE", "20")); |
| | | // è·åç³»ç»æå¤§å¤ä»½æ¶é´ |
| | | StringBuilder sbSql = new StringBuilder(); |
| | | sbSql.append("SELECT TIMESTAMPDIFF(MINUTE, end_time, ?) AS diff_minutes,end_time \n"); |
| | | sbSql.append("FROM product_sys_backup_log \n"); |
| | | sbSql.append("WHERE backup_status = 1 \n"); |
| | | sbSql.append("ORDER BY end_time DESC \n"); |
| | | sbSql.append("LIMIT 1 \n"); |
| | | FieldSetEntity fseMaxLogTime = baseDao.getFieldSetEntityBySQL(sbSql.toString(), new Object[] {standardTimeFormat.format(finalTime)}, false); |
| | | if(fseMaxLogTime != null && !StringUtils.isEmpty(fseMaxLogTime.getString("diff_minutes"))) { |
| | | Integer diffMinutes = fseMaxLogTime.getInteger("diff_minutes"); |
| | | if (diffMinutes < backupCycle) { |
| | | // å°äºå¤ä»½å¨æï¼ä¸å¤ä»½ |
| | | return ; |
| | | } |
| | | startTime = fseMaxLogTime.getDate("end_time"); |
| | | } |
| | | try { |
| | | // æ§è¡å¤ä»½ |
| | | systemBackup(startTime, finalTime); |
| | | } catch (Exception e) { |
| | | e.printStackTrace(); |
| | | } |
| | | FieldSetEntity fseBackLog = new FieldSetEntity("product_sys_backup_log"); |
| | | fseBackLog.setValue("start_time", startTime); |
| | | fseBackLog.setValue("end_time", finalTime); |
| | | fseBackLog.setValue("backup_status", 1); |
| | | baseDao.saveFieldSetEntity(fseBackLog); |
| | | } |
| | | |
| | | /** |
| | | * ç³»ç»å¤ä»½å
¥å£ |
| | | * |
| | | */ |
| | | public void systemBackup(Date startTime, Date finalTime){ |
| | | |
| | | // åå§æ¥å¿æä»¶ |
| | | log = new BackupLogger(); |
| | | // 卿¥å¿ä¸è®°å½æä½ç³»ç»ä¿¡æ¯ï¼ä¾¿äºè°è¯ |
| | | log.writeInfo("ãç³»ç»å¤ä»½å
¥å£ãæä½ç³»ç»: " + System.getProperty("os.name"), BackupLogger.INFO_TYPE); |
| | | log.writeInfo("ãç³»ç»å¤ä»½å
¥å£ãæä»¶åé符: " + File.separator, BackupLogger.INFO_TYPE); |
| | | log.writeInfo("ãç³»ç»å¤ä»½å
¥å£ãç³»ç»å¤ä»½å¼å§..................", BackupLogger.INFO_TYPE); |
| | | NUMBER_TIME = numberTimeFormat.format(finalTime); |
| | | NUMBER_DATE = numberDateFormat.format(finalTime); |
| | | if(startTime == null) { |
| | | STANDARD_START_TIME = "2000-01-01 00:00:00"; |
| | | } else { |
| | | STANDARD_START_TIME = standardTimeFormat.format(startTime); |
| | | } |
| | | STANDARD_FINAL_TIME = standardTimeFormat.format(finalTime); |
| | | log.writeInfo("ãç³»ç»å¤ä»½å
¥å£ãç³»ç»æ¥æï¼" + NUMBER_DATE, BackupLogger.INFO_TYPE); |
| | | log.writeInfo("ãç³»ç»å¤ä»½å
¥å£ãç³»ç»æ¶é´ï¼" + NUMBER_TIME, BackupLogger.INFO_TYPE); |
| | | log.writeInfo("ãç³»ç»æ¬åå
¥å£ãç³»ç»å¤ä»½å¼å§æ¶é´ï¼" + STANDARD_START_TIME, BackupLogger.INFO_TYPE); |
| | | log.writeInfo("ãç³»ç»å¤ä»½å
¥å£ãç³»ç»å¤ä»½æªæ¢æ¶é´ï¼" + STANDARD_FINAL_TIME, BackupLogger.INFO_TYPE); |
| | | // è¿å
¥å¤ä»½è¿ç¨ |
| | | backupProcess(); |
| | | log.closeLogger(); |
| | | } |
| | | |
| | | /** |
| | | * æ°æ®å¤ä»½è¿ç¨ |
| | | */ |
| | | public void backupProcess() { |
| | | log.writeInfo("ãç³»ç»å¤ä»½è¿ç¨ãç³»ç»å¤ä»½è¿ç¨å¼å§..................", BackupLogger.INFO_TYPE); |
| | | long start = System.currentTimeMillis(); |
| | | boolean status= true; |
| | | // ç¬¬ä¸æ¥ï¼åå§é
æä»¶åæ°,å½åç®çææ¶é´æ³çæä»¶å¤¹ |
| | | status = initSystemConfig(); |
| | | if (!status) |
| | | return; |
| | | // ç¬¬äºæ¥ï¼æ§è¡æ°æ®åºå¤ä»½ |
| | | status = runExpDataBase(); |
| | | if (!status) |
| | | return; |
| | | // ç¬¬ä¸æ¥ï¼æ§è¡å¯¹æ°æ®åºæä»¶ãå·¥ç¨ä»£ç ãä¸ä¼ æä»¶åå缩å¤ä»½ |
| | | status = zipDataBackup(); |
| | | if (!status) |
| | | return; |
| | | // ç¬¬åæ¥ï¼ä¸ä¼ å缩å¤ä»½æä»¶å°FTP |
| | | status = sftpTransferService(); |
| | | if (!status) |
| | | return; |
| | | // ç¬¬äºæ¥ï¼æ¸
餿°æ® |
| | | // clearKeepData(); |
| | | |
| | | long end = System.currentTimeMillis(); |
| | | log.writeInfo("ãç³»ç»å¤ä»½è¿ç¨ãç³»ç»å¤ä»½è¿ç¨ç»æï¼èæ¶.................." + ((end - start) / 1000) + "ç§", BackupLogger.INFO_TYPE); |
| | | System.out.println("ç³»ç»å¤ä»½èæ¶.................." + ((end - start) / 1000) + "ç§"); |
| | | } |
| | | |
| | | /** |
| | | * ç¬¬ä¸æ¥ï¼åå§é
ç½®æä»¶åæ°,å½åç®å½çææ¶é´æ³çæä»¶å¤¹ |
| | | */ |
| | | public boolean initSystemConfig() { |
| | | log.writeInfo("ãåå§é
ç½®æä»¶ãå¼å§åå§ç³»ç»é
ç½®æä»¶..................", BackupLogger.INFO_TYPE); |
| | | try (InputStream reader = getClass().getClassLoader().getResourceAsStream(CONFIG_FILE_PATH)) { |
| | | if (reader == null) { |
| | | log.writeInfo("ãåå§é
ç½®æä»¶ãåå§ç³»ç»é
ç½®æä»¶å¤±è´¥ï¼" + CONFIG_FILE_PATH + "é
ç½®æä»¶ä¸åå¨", BackupLogger.ERROR_TYPE); |
| | | } |
| | | // 读åå¤ä»½é
ç½®æä»¶ |
| | | config = new Properties(); |
| | | config.load(reader); |
| | | // è·åç³»ç»æä»¶è·¯å¾ |
| | | String systemFileFolder = Global.getSystemConfig("local.dir", ""); |
| | | File newFile= new File(systemFileFolder); |
| | | // ç³»ç»éä»¶åæ¾ç®å½ |
| | | config.setProperty("DOCUMENT_ROOT", newFile.getAbsolutePath() + File.separator + "00000000-0000-0000-0000-000000000000"); |
| | | // æ°æ®åºå¤ä»½ç®å½ï¼æ°æ®åºå¤ä»½æ ¹ç®å½+æ¶é´æä»¶å+.sqlï¼ |
| | | config.setProperty("DATABASE_BACKUP", config.getProperty("DATABASE_ROOT") + File.separator + NUMBER_TIME + ".sql"); |
| | | // å¤ä»½ç®æ æä»¶ï¼ZIPå¤ä»½æ ¹ç®å½+æ¶é´æä»¶å+.zipï¼ |
| | | config.setProperty("ZIPFILE_BACKUP", config.getProperty("ZIPFILE_ROOT") + File.separator + NUMBER_TIME + ".zip"); |
| | | // å建ZIPæä»¶æ ¹ç®å½ |
| | | File zipFileRoot = new File(config.getProperty("ZIPFILE_ROOT")); |
| | | if (!zipFileRoot.exists()) { |
| | | if (!zipFileRoot.mkdirs()) { |
| | | log.writeInfo("ãåå§é
ç½®æä»¶ãæ æ³å建ç®å½: " + zipFileRoot.getAbsolutePath(), BackupLogger.ERROR_TYPE); |
| | | return false; |
| | | } |
| | | } |
| | | log.writeInfo("ãåå§é
ç½®æä»¶ãDATABASE_ROOT=" + config.getProperty("DATABASE_ROOT"), BackupLogger.INFO_TYPE); |
| | | log.writeInfo("ãåå§é
ç½®æä»¶ãDATABASE_BACKUP=" + config.getProperty("DATABASE_BACKUP"), BackupLogger.INFO_TYPE); |
| | | log.writeInfo("ãåå§é
ç½®æä»¶ãDOCUMENT_ROOT=" + config.getProperty("DOCUMENT_ROOT"), BackupLogger.INFO_TYPE); |
| | | log.writeInfo("ãåå§é
ç½®æä»¶ãDOCUMENT_BACKUP=" + config.getProperty("DOCUMENT_BACKUP"), BackupLogger.INFO_TYPE); |
| | | log.writeInfo("ãåå§é
ç½®æä»¶ãZIPFILE_ROOT=" + config.getProperty("ZIPFILE_ROOT"), BackupLogger.INFO_TYPE); |
| | | log.writeInfo("ãåå§é
ç½®æä»¶ãZIPFILE_BACKUP=" + config.getProperty("ZIPFILE_BACKUP"), BackupLogger.INFO_TYPE); |
| | | log.writeInfo("ãåå§é
ç½®æä»¶ãåå§ç³»ç»é
ç½®æä»¶ç»æ.................", BackupLogger.INFO_TYPE); |
| | | } catch (Exception e) { |
| | | e.printStackTrace(); |
| | | log.writeInfo("ãåå§é
ç½®æä»¶ãç³»ç»åå§é
ç½®æä»¶å¤±è´¥," + new File("config.properties").getAbsolutePath() + "," + e.getMessage(), |
| | | BackupLogger.ERROR_TYPE); |
| | | return false; |
| | | } |
| | | return true; |
| | | } |
| | | |
| | | /** |
| | | * ç¬¬äºæ¥ï¼å¤ä»½æ°æ®åºæä»¶ |
| | | */ |
| | | public boolean runExpDataBase() { |
| | | log.writeInfo("ãå¤ä»½æ°æ®åºãå¼å§å¤ä»½æ°æ®åº..................", BackupLogger.INFO_TYPE); |
| | | String databaseHost = config.getProperty("DATABASE_HOST"); |
| | | String databasePort = config.getProperty("DATABASE_PORT"); |
| | | String databaseName = config.getProperty("DATABASE_NAME"); |
| | | String databaseUser = config.getProperty("DATABASE_USER"); |
| | | String databasePwd = config.getProperty("DATABASE_PWD"); |
| | | |
| | | log.writeInfo("ãå¤ä»½æ°æ®åºãæ°æ®åºHOSTï¼" + databaseHost, BackupLogger.INFO_TYPE); |
| | | log.writeInfo("ãå¤ä»½æ°æ®åºãæ°æ®åºPORTï¼" + databasePort, BackupLogger.INFO_TYPE); |
| | | |
| | | File backupFile = new File(config.getProperty("DATABASE_BACKUP")); |
| | | |
| | | // ç¡®ä¿å¤ä»½æä»¶çç®å½åå¨ |
| | | if (!backupFile.getParentFile().exists()) { |
| | | backupFile.getParentFile().mkdirs(); |
| | | } |
| | | log.writeInfo("ãå¤ä»½æ°æ®åºãæ°æ®åºå¤ä»½æä»¶å®æ´ç®å½ï¼" + backupFile.getAbsolutePath(), BackupLogger.INFO_TYPE); |
| | | |
| | | ProcessBuilder processBuilder = new ProcessBuilder( |
| | | "mysqldump", |
| | | "-h" + databaseHost, |
| | | "-P" + databasePort, |
| | | "-u" + databaseUser, |
| | | "-p" + databasePwd, |
| | | databaseName |
| | | ); |
| | | |
| | | try { |
| | | Process process = processBuilder.start(); |
| | | // 读åmysqldumpçè¾åºå¹¶åå
¥å°å¤ä»½æä»¶ |
| | | try (BufferedReader reader = new BufferedReader(new InputStreamReader(process.getInputStream(), StandardCharsets.UTF_8)); |
| | | FileWriter writer = new FileWriter(backupFile)) { |
| | | |
| | | String line; |
| | | while ((line = reader.readLine()) != null) { |
| | | writer.write(line + System.lineSeparator()); |
| | | } |
| | | } |
| | | |
| | | // 读åé误æµå¹¶è®°å½æ¥å¿ |
| | | try (BufferedReader errorReader = new BufferedReader( |
| | | new InputStreamReader(process.getErrorStream(), StandardCharsets.UTF_8))) { |
| | | String errorLine; |
| | | while ((errorLine = errorReader.readLine()) != null) { |
| | | log.writeInfo("ãå¤ä»½æ°æ®åºãé误è¾åº: " + errorLine, BackupLogger.ERROR_TYPE); |
| | | } |
| | | } |
| | | |
| | | int exitCode = process.waitFor(); |
| | | if (exitCode == 0) { |
| | | log.writeInfo("ãå¤ä»½æ°æ®åºãæ°æ®åºå¤ä»½æåï¼" + backupFile.getAbsolutePath(), BackupLogger.INFO_TYPE); |
| | | // if (!"127.0.0.1".equals(databaseHost)) { |
| | | // è·åæ°æ®åºå¤ä»½æä»¶ |
| | | // return sftpTransferService(false); |
| | | // } |
| | | } else { |
| | | log.writeInfo("ãå¤ä»½æ°æ®åºãæ°æ®åºå¤ä»½å¤±è´¥ï¼éåºç : " + exitCode, BackupLogger.ERROR_TYPE); |
| | | } |
| | | } catch (Exception e) { |
| | | e.printStackTrace(); |
| | | log.writeInfo("ãå¤ä»½æ°æ®åºãæ°æ®åºå¤ä»½å¤±è´¥ï¼" + e.getMessage(), BackupLogger.ERROR_TYPE); |
| | | return false; |
| | | } |
| | | return true; |
| | | } |
| | | |
| | | private static void addFileToZip(File file, String entryName, ZipOutputStream zos) throws IOException { |
| | | try (FileInputStream fis = new FileInputStream(file)) { |
| | | zos.putNextEntry(new ZipEntry(entryName)); |
| | | byte[] buffer = new byte[1024]; |
| | | int length; |
| | | while ((length = fis.read(buffer)) >= 0) { |
| | | zos.write(buffer, 0, length); |
| | | } |
| | | zos.closeEntry(); |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * å缩å¢ééä»¶ |
| | | * @param groupFolderFile å¢éæä»¶å¤¹ï¼æä»¶å |
| | | * @param baseDir éä»¶æ ¹ç®å½ |
| | | * @param outputZipPath å缩æä»¶ |
| | | * @throws IOException |
| | | */ |
| | | public static void compressExistingFiles(Map<Integer, List<String>> groupFolderFile, String baseDir, ZipOutputStream zos) throws IOException { |
| | | for (Map.Entry<Integer, List<String>> entry : groupFolderFile.entrySet()) { |
| | | int folderName = entry.getKey(); // æä»¶å¤¹åï¼å¦ 20250611ï¼ |
| | | List<String> files = entry.getValue(); // 该æä»¶å¤¹ä¸çæä»¶åå表 |
| | | Path folderPath = Paths.get(baseDir).resolve(String.valueOf(folderName)); |
| | | for (String fileName : files) { |
| | | Path filePath = folderPath.resolve(fileName); |
| | | // æ£æ¥æä»¶æ¯å¦åå¨ |
| | | if (Files.exists(filePath) && !Files.isDirectory(filePath)) { |
| | | // è®¡ç® ZIP å
çç¸å¯¹è·¯å¾ï¼å¦ "20250611/file1.txt"ï¼ |
| | | ZipEntry zipEntry = new ZipEntry( |
| | | String.valueOf(folderName) + "/" + fileName |
| | | ); |
| | | zos.putNextEntry(zipEntry); |
| | | |
| | | // åå
¥æä»¶å
å®¹å° ZIP |
| | | Files.copy(filePath, zos); |
| | | zos.closeEntry(); |
| | | } else { |
| | | System.err.println("æä»¶ä¸å卿䏿¯æä»¶: " + filePath); |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | public boolean zipDataBackup() { |
| | | log.writeInfo("ãå缩å¤ä»½æä»¶ãå¼å§å缩å¤ä»½æä»¶..................", BackupLogger.INFO_TYPE); |
| | | String documentPath = config.getProperty("DOCUMENT_ROOT"); |
| | | String databasePath = config.getProperty("DATABASE_BACKUP"); |
| | | String zipFilePath = config.getProperty("ZIPFILE_BACKUP"); |
| | | log.writeInfo("ãå缩å¤ä»½æä»¶ãéä»¶åå¨ç®å½è·¯å¾ï¼" + documentPath, BackupLogger.INFO_TYPE); |
| | | log.writeInfo("ãå缩å¤ä»½æä»¶ãæ°æ®åºå¤ä»½å®æ´è·¯å¾ï¼" + databasePath, BackupLogger.INFO_TYPE); |
| | | log.writeInfo("ãå缩å¤ä»½æä»¶ãå¤ä»½å缩æä»¶å®æ´è·¯å¾ï¼" + zipFilePath, BackupLogger.INFO_TYPE); |
| | | |
| | | try (FileOutputStream fos = new FileOutputStream(zipFilePath); |
| | | ZipOutputStream zos = new ZipOutputStream(fos)){ |
| | | StringBuilder sbSql = new StringBuilder(); |
| | | sbSql.append("SELECT SUBSTRING_INDEX(attachment_url, '/', -1) id,attachment_title AS uuid,attachment_url \n"); |
| | | sbSql.append("FROM product_sys_attachments \n"); |
| | | sbSql.append("WHERE (created_utc_datetime > ? AND created_utc_datetime <= ?) \n"); |
| | | sbSql.append("AND (updated_utc_datetime > ? AND updated_utc_datetime <= ?) \n"); |
| | | DataTableEntity dtTable = baseDao.listTable(sbSql.toString(), new Object[] {STANDARD_START_TIME, STANDARD_FINAL_TIME, STANDARD_START_TIME, STANDARD_FINAL_TIME}); |
| | | if(dtTable != null && dtTable.getRows() > 0) { |
| | | Map<Integer, List<String>> groupFolderFile = dtTable.getData().stream() |
| | | .collect(Collectors.groupingBy( |
| | | FieldSetEntity::getId, |
| | | Collectors.mapping( |
| | | FieldSetEntity::getUUID, |
| | | Collectors.toList() |
| | | ) |
| | | )); |
| | | log.writeInfo("ãå缩å¤ä»½æä»¶ãå缩系ç»å¢ééä»¶", BackupLogger.INFO_TYPE); |
| | | compressExistingFiles(groupFolderFile, documentPath, zos); |
| | | } |
| | | |
| | | log.writeInfo("ãå缩å¤ä»½æä»¶ãåç¼©æ°æ®åºå¤ä»½æä»¶", BackupLogger.INFO_TYPE); |
| | | // å缩SQLæä»¶ï¼æ¾å¨æå®è·¯å¾ä¸ï¼ |
| | | addFileToZip(new File(databasePath), "database/" + NUMBER_TIME + ".sql", zos); |
| | | log.writeInfo("ãå缩å¤ä»½æä»¶ãåç¼©å®æ", BackupLogger.INFO_TYPE); |
| | | } catch (IOException e) { |
| | | e.printStackTrace(); |
| | | } finally { |
| | | File file = new File(databasePath); |
| | | file.delete(); |
| | | log.writeInfo("ãå缩å¤ä»½æä»¶ãæ¸
çæ°æ®åºå¤ä»½æä»¶å®æ", BackupLogger.INFO_TYPE); |
| | | } |
| | | return false; |
| | | } |
| | | |
| | | /** |
| | | * SFTPè¿æ¥ï¼éè¿SFTPå°å¤ä»½æä»¶ä¸ä¼ å¤ç¨æº æ ä»mysqlæå¡å¨ä¸è·åå¤ä»½æä»¶ |
| | | * @param isUpload æ¯å¦ä¸ä¼ |
| | | * @return |
| | | */ |
| | | public boolean sftpTransferService() { |
| | | String sftpTitle = "ä¸ä¼ ç³»ç»å¤ä»½æä»¶";; |
| | | String localFilePath = config.getProperty("ZIPFILE_BACKUP"); // æ¬å°æä»¶è·¯å¾ |
| | | String sftpFilePath = config.getProperty("UPLOAD_BACKUP_DIR") + NUMBER_TIME + ".zip"; // SFTPæå¡æä»¶è·¯å¾; |
| | | |
| | | String host = config.getProperty("UPLOAD_SFTP_HOST"); // SFTPæå¡IPå°å |
| | | String port = config.getProperty("UPLOAD_SFTP_PORT"); // SSHç«¯å£ |
| | | String user = config.getProperty("UPLOAD_SFTP_USER"); // SFTPæå¡çç¨æ·å |
| | | String password = config.getProperty("UPLOAD_SFTP_PWD"); // SFTPæå¡çå¯ç |
| | | log.writeInfo(String.format("ã%sãå¼å§%s..................", sftpTitle, sftpTitle), BackupLogger.INFO_TYPE); |
| | | log.writeInfo(String.format("ã%sãSFTPæå¡å°åï¼", sftpTitle) + host, BackupLogger.INFO_TYPE); |
| | | log.writeInfo(String.format("ã%sãSFTPæå¡ç«¯å£ï¼", sftpTitle) + port, BackupLogger.INFO_TYPE); |
| | | log.writeInfo(String.format("ã%sãSFTPæå¡åå¨ç®å½ï¼", sftpTitle) + sftpFilePath, BackupLogger.INFO_TYPE); |
| | | log.writeInfo(String.format("ã%sãå½åæå¡åå¨ç®å½ï¼", sftpTitle) + localFilePath, BackupLogger.INFO_TYPE); |
| | | if (StringUtils.isEmpty(host) || StringUtils.isEmpty(port) || StringUtils.isEmpty(user) || StringUtils.isEmpty(password)) { |
| | | log.writeInfo(String.format("ã%sãSFTPä¿¡æ¯æªé
ç½®å®æ´ï¼ä¸äºè¿æ¥ä¼ è¾æä»¶", sftpTitle), BackupLogger.INFO_TYPE); |
| | | return true; |
| | | } |
| | | try { |
| | | JSch jsch = new JSch(); |
| | | Session session = jsch.getSession(user, host, Integer.valueOf(port)); |
| | | session.setPassword(password); |
| | | session.setConfig("StrictHostKeyChecking", "no"); // ä»
éæµè¯ç¯å¢ |
| | | session.connect(5000); // è®¾ç½®è¿æ¥è¶
æ¶æ¶é´ |
| | | |
| | | Channel channel = session.openChannel("sftp"); |
| | | channel.connect(5000); // 设置ééè¶
æ¶æ¶é´ |
| | | ChannelSftp sftpChannel = (ChannelSftp) channel; |
| | | |
| | | // ç¡®ä¿ç®å½åå¨ï¼å
³é®æ¥éª¤ï¼ |
| | | String remoteDir = sftpFilePath.substring(0, sftpFilePath.lastIndexOf('/')); |
| | | if (!remoteDir.startsWith("/")) { |
| | | remoteDir = "/" + remoteDir; |
| | | } |
| | | // å建对åºç®å½æä»¶å¤¹ |
| | | createRemoteDirectory(sftpChannel, remoteDir); |
| | | sftpChannel.put(localFilePath, sftpFilePath, new SftpProgressMonitor() { |
| | | public void init(int op, String src, String dest, long max) { |
| | | log.writeInfo("ãä¸ä¼ ç³»ç»å¤ä»½æä»¶ãå¼å§ä¼ è¾: " + src + " -> " + dest, BackupLogger.INFO_TYPE); |
| | | } |
| | | public boolean count(long count) { return true; } |
| | | public void end() { log.writeInfo("ãä¸ä¼ ç³»ç»å¤ä»½æä»¶ãä¼ è¾å®æ", BackupLogger.INFO_TYPE); } |
| | | }); |
| | | sftpChannel.exit(); |
| | | session.disconnect(); |
| | | log.writeInfo(String.format("ã%sã%sæå", sftpTitle, sftpTitle), BackupLogger.INFO_TYPE); |
| | | } catch (JSchException | SftpException e) { |
| | | e.printStackTrace(); |
| | | log.writeInfo(String.format("ã%sã%s失败ï¼", sftpTitle, sftpTitle) + e.getMessage(), BackupLogger.ERROR_TYPE); |
| | | return false; |
| | | } |
| | | return true; |
| | | } |
| | | |
| | | /** |
| | | * SFTPéå½å建è¿ç¨ç®å½ |
| | | * @param sftpChannel |
| | | * @param remoteDir |
| | | * @throws SftpException |
| | | */ |
| | | private void createRemoteDirectory(ChannelSftp sftpChannel, String remoteDir) throws SftpException { |
| | | try { |
| | | sftpChannel.cd(remoteDir); |
| | | } catch (SftpException e) { |
| | | if (e.id == ChannelSftp.SSH_FX_NO_SUCH_FILE) { |
| | | if (remoteDir.length() == 3 && remoteDir.charAt(1) == ':') { |
| | | // è·³è¿æ ¹ç®å½ |
| | | return; |
| | | } |
| | | int pos = remoteDir.lastIndexOf('/'); |
| | | if (pos > 0) { |
| | | createRemoteDirectory(sftpChannel, remoteDir.substring(0, pos)); |
| | | } |
| | | sftpChannel.mkdir(remoteDir); |
| | | log.writeInfo("ãä¸ä¼ å¤ä»½æä»¶ãå建ç®å½æå: " + remoteDir, BackupLogger.INFO_TYPE); |
| | | } else { |
| | | throw e; |
| | | } |
| | | } |
| | | } |
| | | } |