频道栏目
首页 > 资讯 > 云计算 > 正文

使用LogicApps从AzureBlob存储中删除超过X天的文件教程

19-02-11        来源:[db:作者]  
收藏   我要投稿

假定我们有某个应用程序会将文件存储到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:

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帐户。

相关TAG标签
上一篇:CentOS 7 vs CentOS 6新特性简介
下一篇:python常用命令—查看模块所在位置
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站