Azure のコンテナーをあるストレージの場所から別の場所にコピーしようとしています。これには AzCopy コマンドを使用しています。まず、すべてのコンテナーのリストを取得してから、C# コードを使用して、コマンド ラインからコンテナー名に基づいて AzCopy を実行します。
私が直面していた問題は、コンテナをある場所から別の場所にコピーすることですが、4 つのコンテナの後、動かなくなったようです。そして、テストは永久に実行され続けます。テストをキャンセルすると、他のすべてのコンテナーもコピーされます。
テストが完了し、すべてのフォルダーがコピーされるというこの問題をどのように解決できるか疑問に思っていました。通話が完了するまで十分な時間を確保するために、通話のたびに待機するようにしました。cmd.WaitForExit(); も使用してみました。各呼び出しの後ですが、それは行き詰まります。
私が見逃している可能性があるものについての提案は、私がやりたかったことの 1 つは、各呼び出しの後に出力を取得することでした。これは、現在、すべてのコマンドが終了すると結果が出力されるためです。コマンドライン呼び出しを順番に実行する方法も考えていたので、最初の呼び出しが終了した後にのみ実行してください。
どんな助けでも大歓迎です!
namespace Test2
{
[TestFixture]
class ContainerList
{
[Test]
public void CopyingContainerData()
{
CloudStorageAccount sourceCloudStorageAccount =
CloudStorageAccount.Parse("StorageAccountKey");
CloudBlobClient sourceCloudBlobClient = sourceCloudStorageAccount.CreateCloudBlobClient();
List<string> outputLines = new List<string>();
IEnumerable<CloudBlobContainer> containers = sourceCloudBlobClient.ListContainers();
Process cmd = new Process();
cmd.StartInfo.FileName = "cmd.exe";
cmd.StartInfo.RedirectStandardInput = true;
cmd.StartInfo.RedirectStandardOutput = true;
cmd.StartInfo.CreateNoWindow = false;
cmd.StartInfo.UseShellExecute = false;
cmd.Start();
int i = 0;
foreach (CloudBlobContainer oneContainer in containers)
{
string outputLine = oneContainer.Name;
outputLines.Add(outputLine);
string container = oneContainer.Name;
string strCmdText = @"AzCopy /Source:https://location1.blob.core.windows.net/" + container + @" /Dest:https://location2.blob.core.windows.net/" + container + @" /SourceKey:abc /DestKey:abc123 /S /NC:8 /XO /Y";
string location = @"cd C:\Program Files (x86)\Microsoft SDKs\Azure\AzCopy";
cmd.StandardInput.WriteLine(location);
cmd.StandardInput.WriteLine(strCmdText);
//System.Threading.Thread.Sleep(20000);
//cmd.WaitForExit();
i++;
if (i == 15)
{
break;
}
}
string[] outputText = outputLines.ToArray();
File.WriteAllLines(@"C:\AzureTests\CopyData.txt", outputText);
cmd.StandardInput.Flush();
cmd.StandardInput.Close();
Console.WriteLine(cmd.StandardOutput.ReadToEnd());
}
}
}