From b2f8c4bb2b385d5551289d5a9e70f66ab876bde9 Mon Sep 17 00:00:00 2001 From: anthony Date: Wed, 21 Dec 2011 18:43:38 -0800 Subject: [PATCH] SWIFT : big file fix --- .../resource/NfsSecondaryStorageResource.java | 43 ++++++++++--------- 1 file changed, 22 insertions(+), 21 deletions(-) diff --git a/core/src/com/cloud/storage/resource/NfsSecondaryStorageResource.java b/core/src/com/cloud/storage/resource/NfsSecondaryStorageResource.java index 80cd9f29927..7ce5e212a8a 100755 --- a/core/src/com/cloud/storage/resource/NfsSecondaryStorageResource.java +++ b/core/src/com/cloud/storage/resource/NfsSecondaryStorageResource.java @@ -269,9 +269,7 @@ public class NfsSecondaryStorageResource extends ServerResourceBase implements S } String swiftUpload(SwiftTO swift, String container, String lDir, String lFilename) { - Script command = new Script("/bin/bash", s_logger); long SWIFT_MAX_SIZE = 5L * 1024L * 1024L * 1024L; - command.add("-c"); List files = new ArrayList(); if (lFilename.equals("*")) { File dir = new File(lDir); @@ -286,33 +284,36 @@ public class NfsSecondaryStorageResource extends ServerResourceBase implements S } for (String file : files) { - long size = file.length(); + File f = new File(lDir + "/" + file); + long size = f.length(); + Script command = new Script("/bin/bash", s_logger); + command.add("-c"); if (size <= SWIFT_MAX_SIZE) { command.add("cd " + lDir + ";/usr/bin/python /usr/local/cloud/systemvm/scripts/storage/secondary/swift -A " + swift.getUrl() + " -U " + swift.getAccount() + ":" + swift.getUserName() - + " -K " + swift.getKey() + " upload " + container + " " + lFilename); + + " -K " + swift.getKey() + " upload " + container + " " + file); } else { command.add("cd " + lDir + ";/usr/bin/python /usr/local/cloud/systemvm/scripts/storage/secondary/swift -A " + swift.getUrl() + " -U " + swift.getAccount() + ":" + swift.getUserName() - + " -K " + swift.getKey() + " upload -S " + SWIFT_MAX_SIZE + " " + container + " " + lFilename); + + " -K " + swift.getKey() + " upload -S " + SWIFT_MAX_SIZE + " " + container + " " + file); } - } - - OutputInterpreter.AllLinesParser parser = new OutputInterpreter.AllLinesParser(); - String result = command.execute(parser); - if (result != null) { - String errMsg = "swiftUpload failed , err=" + result; - s_logger.warn(errMsg); - return errMsg; - } - if (parser.getLines() != null) { - String[] lines = parser.getLines().split("\\n"); - for (String line : lines) { - if (line.contains("Errno") || line.contains("failed")) { - String errMsg = "swiftUpload failed , err=" + lines.toString(); - s_logger.warn(errMsg); - return errMsg; + OutputInterpreter.AllLinesParser parser = new OutputInterpreter.AllLinesParser(); + String result = command.execute(parser); + if (result != null) { + String errMsg = "swiftUpload failed , err=" + result; + s_logger.warn(errMsg); + return errMsg; + } + if (parser.getLines() != null) { + String[] lines = parser.getLines().split("\\n"); + for (String line : lines) { + if (line.contains("Errno") || line.contains("failed")) { + String errMsg = "swiftUpload failed , err=" + lines.toString(); + s_logger.warn(errMsg); + return errMsg; + } } } } + return null; }