使用Logic Apps从Azure Blob存储中删除超过X天的文件


假定我们有某个应用程序会将文件存储到Azure Blob中,存储在Blob中的数据保存七天,七天以后需要对其进行删除。这需求可以使用Azure PowerShell Runbook来完成,但是我想看看是否可以用很少甚至没有代码来完成。经过一番探索我发现Azure Logic App非常适合这种情况。你可以用Logic App创建一些强大的东西。因此,在本文中,我将向各位展示如何在使用Logic App删除Blob中超过X天的文件。

至于Logic App如何创建,在此我就不做过多的说明了,各位如果有兴趣可以参考我之前的Blog。当我们创建好Logic App以后打开新的逻辑应用程序。我们应该会看到“逻辑应用程序设计器”,点击“逻辑应用程序设计器”—“ Blank Logic App”:

clip_image002

在搜索连接器和触发器框中搜索“Recurrence”,单击“Recurrence”触发器:

clip_image004

将间隔设置为您希望逻辑应用程序每隔几天运行一次。在此我选择每天都运行,然后单击“显示高级选项”。在这里选择我们希望逻辑应用程序运行的时区和时间。我选择了UTC+8和midnight。完成后单击下一步。

clip_image006

在搜索连接器和触发器框中搜索“blob”,单击“List blobs”触发器:

clip_image008

输入连接名。我们会看到一个存储帐户列表,单击要清理的存储帐户。然后点击创建,现在要求我们指定Container。单击文件夹图标,然后选择要清理的Container:

扫描二维码关注公众号,回复: 5134382 查看本文章

clip_image010

在搜索连接器和触发器框中搜索“Filte”,单击“Filter array”触发器:

clip_image012

选择list blobs下的Value:

clip_image014

单击“ 在高级模式下编辑”,然后键入以下内容以清除超过7天的文件。然后单击下一步:

@less(item()?['LastModified'], addDays(utcNow(), -7))

clip_image015

在搜索连接器和触发器框中搜索“For each”,单击“For each”触发器:

clip_image016

选择Filter array下的“Body”:

clip_image018

单击“ 添加操作”。

clip_image019

搜索“Delete blob”,点击“Delete Blob”:

clip_image020

选择“Path”:

clip_image022

到此我们的logic app就已经设计完成,点击保存即可:

clip_image024

让我们测试一下Logic App,确保它能够正常攻错。正如您在我的Blob存储中看到的,我有一些文件,它们有不同的修改日期,很大一部分是超过7天的。

clip_image026

对于刚刚创建的Logic app我们如果想要立即运行只需要点击“Run Trigger”就可以了:

clip_image028

点击运行以后可以在下方看到运行记录:

clip_image030

运行完成后我们返回blob可以看到在7天前创建的文件均已被删除:

clip_image032

这种清理Blob存储中文件的方法非常简单,并且不需要像使用Azure自动化Runbook那样需要任何特殊的Azure RunAs帐户。

猜你喜欢

转载自blog.51cto.com/wuyvzhang/2348224