我正在为 Azure 数据工厂管道实现自定义事件,以将 blob 文件从一个容器移动到另一个容器。源/目标文件的名称从管道自定义事件的输入/输出数据集传递到 DotNetActivity。为了简单起见,我们将源文件名设置为“input.txt”,将目标文件名设置为“output.txt”。 “上传”和“已处理”容器都存在。
以下代码执行复制部分,无论如何结果不是我所期望的。
logger.Write("Source filename : {0}", sourceFilename); // => input.txt
logger.Write("Destin. filename : {0}", destinationFileName); // => output.txt
CloudBlobContainer sourceContainer = blobClient.GetContainerReference("upload");
CloudBlockBlob sourceBlob = sourceContainer.GetBlockBlobReference(sourceFilename);
CloudBlobContainer destinationContainer = blobClient.GetContainerReference("processed");
CloudBlockBlob destinationBlob = destinationContainer.GetBlockBlobReference(destinationFileName);
logger.Write("Source blob: {0}", sourceBlob.Name); // => input.txt
logger.Write("Destination blob: {0}", destinationBlob.Name); // => processed/output.txt ???
destinationBlob.StartCopyFromBlob(sourceBlob);
结果,blob“processed/output.txt”被创建到“processed”容器,而目的是将 blob 命名为“output.txt”。
为什么要在目标文件名中添加“processed/”前缀?如何去掉前缀?
最佳答案
注意到,当数据工厂从 VisualStudio 重新部署(发布)到 Azure 时,更改的 .NET 实现不会重建,但部署会加载现有的 .NET DLL。显然问题是由早期版本的 DotNetActivity 引起的。我现在在发布数据工厂更改之前手动构建 DotNetActivity,并且上面的代码按预期工作。 (之前没有指出解决方案)
关于c# - 通过 GetBlockBlobReference() 方法添加到 blob 文件名的容器名称,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44179772/