《Windows Azure Platform 系列文章目录

  本文介绍的是国内由世纪互联运维的Azure China。

  本文是对笔者之前的文档Azure Backup (1) 将SQL Server 2012虚拟机中数据库备份到Azure Storage进行的补充。  

  希望笔者先阅读Azure Automation (1) 入门,对Azure Automation有基本的概念认识。

  需求:

  在之前的文档中Azure Backup (1) 将SQL Server 2012虚拟机中数据库备份到Azure Storage

  笔者介绍了使用SQL Server Job将SQL Database的备份文件bak备份到Azure Storage存储账户中。

  但是这样会产生一个问题,随着这个SQL Job运行的时间越来越长,数据库备份文件bak会越来越多。如何设置Azure Automation计划任务,把老的数据库备份文件定期删除呢?

  在这里笔者详细介绍一下相关的内容。

  本文提到的技术细节有几点:

  1.Azure AD账户,请参考:Windows Azure Active Directory (3) China Azure AD增加新用户

  2.Azure订阅,请参考:Azure PowerShell (4) 使用PowerShell管理多个订阅

  3.Azure存储账户名称,请参考:Windows Azure Storage (1) Windows Azure Storage Service存储服务

  4.Azure存储账户container,请参考:

   Windows Azure Storage (2) Windows Azure Storage Service存储服务之Blob详解(上)

       Windows Azure Storage (3) Windows Azure Storage Service存储服务之Blob详解(中)

       Windows Azure Storage (4) Windows Azure Storage Service存储服务之Blob Share Access Signature

 

  本文的内容分为2个部分:

  1.创建协同管理员Co-admin

  2.定期删除存储账号的Runbook的编写

  2.计划任务的调用

 

  我们开始第一部分的内容,创建协同管理员Co-admin

  1.首先我们根据之前的内容,Windows Azure Active Directory (3) China Azure AD增加新用户,我们增加一个协同管理员Co-Admin

  

  设置这个共同管理员的目的是,这个Azure AD账户(newuser@leizha.partner.onmschina.cn)只是用来运行Azure Automation,没有其他的权限。

  newuser@leizha.partner.onmschina.cn在运行Azure Automation的时候,需要验证newuser的账户和密码

  

  如果我们设置服务管理员admin@leizha.partner.onmschina.cn来运行Azure Automation的话,

  默认的Azure AD密码过期时间是60天,如果超过60天我们将admin账户密码修改,会在验证密码的时候出错。

  所以我们需要单独一个Azure AD账户来运行Azure Automation。

  为了保证Demo的可读性,我们创建一个单独的Azure AD账户automation@leizha.partner.onmschina.cn

  第二部分,创建RunBook

  2.我们创建一个Automation命令为LeiAutomation。点击该Automation,如下图:

  

  3.页面跳转,我们点击RUNBOOKS,然后点击 IMPORT,如下图。

  

  

  同时导入Runbook。Runbook的下载地址:

  https://github.com/leizhang1984/AzureChinaAutomation/blob/master/ASM/RemoveStorageBlobXDaysOld.ps1

  请注意在导入之前修改相应的参数,如下面的方框内容:

                #设置Org ID
[parameter(Mandatory=$true)]
[String]$AzureOrgId="[YourAzureOrgID]", #设置Org ID的密码
[Parameter(Mandatory = $true)]
[String]$Password="[YourAzureOrgIDPassword]", #设置订阅名称
[Parameter(Mandatory = $true)]
[String]$AzureSubscriptionName="[YourSubscriptionName]", #设置存储账号
[Parameter(Mandatory = $true)]
[String]$StorageAccountName="[YourStorageAccount]", #设置Container Name
[Parameter(Mandatory = $true)]
[String]$ContainerName="[YourStorageAccountContainerName]", #设置过期时间
[Parameter(Mandatory = $true)]
[Int32]$DaysOld=[XDaysOld]

  这样可以把某个存储账号下超过XDaysOld的旧数据删除,注意$DaysOld这个参数类型是Int32,赋值的参数不包含双引号。

  4.修改参数完毕后,我们可以导入该RunBook。如下图:

  

  5.导入完毕后,我们就可以查看到该RunBook

  

  6.这里有重要的事情强调三遍:

  Azure Automation RunBook的系统时间为UTC时区

  Azure Automation RunBook的系统时间为UTC时区

  Azure Automation RunBook的系统时间为UTC时区

  我们的Automation RunBook的系统时间为UTC时区,我们需要修改为UTC时区为UTC+8北京时间 

  $ChinaTimeZone = [System.TimeZoneInfo]::FindSystemTimeZoneByID("China Standard Time")
  $Start = [System.TimeZoneInfo]::ConvertTimefromUTC((get-date).ToUniversalTime(),$ChinaTimeZone)
  "Starting: " + $Start.ToString("HH:mm:ss.ffffzzz")

  7.记得导入Azure Automation RunBook之后,需要Publish这个RunBook

  

  8.Publish之后,我们就可以在PUBLISHED里面看到发布的RUNBOOK项目

  第三部分,设置计划任务的调度

  9.执行成功后,我们可以在Schedule里面设置计划任务。我们创建一个新的计划任务,选择LINK TO A NEW Schedule,如下图:

  

  10.首先命名这个Schedule(计划任务)

  

  

  11.然后设置计划任务频率。如下图:

  

  我们设置Daily每天运行一次,开始时间为2015-08-28早上11点。

  这里有重要的事情强调三遍:

  Azure Automation Schedule的系统时间为客户端本地时间,我的PC为北京时间,即UTC+8时区

  Azure Automation Schedule的系统时间为客户端本地时间,我的PC为北京时间,即UTC+8时区

  Azure Automation Schedule的系统时间为客户端本地时间,我的PC为北京时间,即UTC+8时区

  12.最后设置这个RunBook的参数,图略。

  这样我们就设计了计划任务,从2015-08-28上午11点开始执行Azure Automation,每天执行一次,没有过期时间。

  这样Schedule(计划任务)每天就会清除Azure Storage Account的老旧数据。

  第四部分,取消计划任务

  当我们遇到10.1长假等情况,这些计划日程的脚本都不需要自动化运行。我们就可以通过Azure Automation计划日程中的取消连接功能。让这个Runbook不需要自动化执行。

  我们可以点击Azure Automation,选择相应的Runbook,如下图:

  

  点击上图的StartAllVM,然后页面跳转。

  点击下图中的计划日程,取消连接按钮。

  

  这样这个StartAllVM的任务就被取消了,将来不会继续执行。

  等我们10-1放假回来后,我们可以针对这个StartAllVM和StopAllVM,在计划日程中新建连接即可。如下图:

  

  本博-三石Blog(下文简称本博),在本博客文章结尾处右下脚未注明转载、来源、出处的作品(内容)均为本博原创,本站对于原创作品内容对其保留版权,请勿随意转载,如若真有需要的朋友可以发Mail联系我;转载本博原创作品(内容)也必须遵循“署名-非商业用途-保持一致”的创作共用协议,请务必以文字链接的形式标明或保留文章原始出处和博客作者(Lei Zhang)的信息,关于本博摄影作品请务必注意保留(www.cnblog.com/threestone)等相关水印版权信息,否则视为侵犯原创版权行为;本博谢绝商业网站转载。版权所有,禁止一切有违中华人民共和国著作权保护法及相关法律和本博(法律)声明的非法及恶意抄袭。

Azure Automation (2) 定期删除存储账号中的文件的更多相关文章

  1. Azure Automation (3) 定期将某个Azure订阅下的所有虚拟机开关机

    <Windows Azure Platform 系列文章目录> 本文介绍的是国内由世纪互联运维的Azure China. 在笔者之前的文章中,我们介绍了使用Azure Automation ...

  2. 如何永久删除git仓库中敏感文件的提交记录

    如何永久删除git仓库中敏感文件的提交记录 参考: 1. https://help.github.com/articles/remove-sensitive-data/

  3. 【Azure 环境】由为存储账号(Storage Account)拒绝分配权限而引出的Azure 蓝图(Blueprint)使用问题

    问题描述 当打开Azure存储账号(Storage Account)门户页面时,从 "访问控制(标识和访问管理)" 页面中发现有"拒绝分配"的功能,所以就思考, ...

  4. git忽略文件并删除git仓库中的文件

    问题描述 不慎在创建.gitignore  文件之前的时候将文件push到了 git仓库,即使之后在.gitignore文件中写入新的过滤规则,这些规则也不会起作用的,git依然会对所有git仓库中的 ...

  5. 彻底删除 Git 项目中的文件(BFG Repo-Cleaner 用法)

    一些时候由于开发初期经验不足和贪图方便, 会把一些不应该提交到 Git 的文件上传到 Github, 带来一系列安全问题, 更有可能是把一些大文件上传到 GitHub 上, 导致项目非常臃肿, 每次 ...

  6. 【菜鸟学Linux】Cron Job定期删除Log(日志)文件

    以前一直做Windows开发,近期的项目中要求使用Linux.作为小菜鸟一枚,赶紧买了一本经典书<鸟哥的Linux私房菜>学习.最近刚好有一个小任务 - 由于产品产生的Log很多,而且增长 ...

  7. git删除远程仓库中的文件夹

    具体操作如下: git rm -r --cached .history    #删除目录 git commit -m”删除.history文件夹” git push -r表示递归所有子目录,如果你要删 ...

  8. Git_添加、删除远端仓库中的文件

    一.将文件添加到远端仓库 1.新增文件 2.使用git add 将文件添加到本地缓存中 3.使用git commit 将文件添加到本地仓库中 4.使用git push 将本地仓库中的修改同步到远端仓库 ...

  9. gradle 删除指定目录中的文件和目录

    // 删除bakAPk下的所有非母包文件 task deleTask(type: Delete){ FileTree tree = fileTree(dir: bakPath) tree.each { ...

随机推荐

  1. 【leetcode】Pow(x,n)

    马上各种校招要开始了,怎么也得准备一下,之前一直在看看机器学习,NLP方面的东西,收获很多.最近换换脑子,回过头来做做leetcode,感觉还是蛮有意思的.今天刷了个水题,AC不高,然而难度也不高.. ...

  2. Oracle常用函数笔记

    一.字符函数 1.dual 临时表 oracle中的临时变量表,此表只返回第一行第一列 例如:select sysdate from dual 输出:2014-6-9 11:20:39 2.Initc ...

  3. 在Linux上以服务的方式运行ASP.NET Core站点

    更新:用supervisor是更好的解决方法,详见 Linux下为 dotnet 创建守护进程 要在生成环境下在Linux服务器上跑ASP.NET Core站点,首先要解决的问题是以服务的方式运行AS ...

  4. Java IO2:RandomAccessFile

    RandomAccessFile RandomAccessFile类可以说是Java语言中功能最为丰富的文件访问类,它提供了众多的文件访问方法.RandomAccessFile类支持"随机访 ...

  5. .net程序单元测试介绍

    什么是单元测试?为什么要进行单元测试?如需要进一步了解,请移步维基百科. 关于.net程序单元测试的文章,网上已经有很多,但我相信我写的这篇文章的内容是独特的,因为我在网上找了很久,都没找到关于Str ...

  6. Java多线程系列--“JUC锁”11之 Semaphore信号量的原理和示例

    概要 本章,我们对JUC包中的信号量Semaphore进行学习.内容包括:Semaphore简介Semaphore数据结构Semaphore源码分析(基于JDK1.7.0_40)Semaphore示例 ...

  7. ReactMix框架,让你实现一套js代码,基于ReactNative在H5,App都能完美跑起来,Write Once,Run Anywhere

    ReactNative框架推出已经有一段时间了,相信很多小伙伴都在尝试实现Write Once, Run Anywhere的梦想,比如淘宝的ReactWeb等等,但是这些框架都局限于因为ReactNa ...

  8. Spring Trasnaction管理(1)- 线程间事务隔离

    问题导读 Spring中事务是如何实现的 Spring中各个线程间是如何进行连接.事务隔离的 Spring事务配置 Spring的事务管理应该是日常开发中总会碰到的,但是Spring具体是怎么实现线程 ...

  9. 解决URL中文乱码问题

    在做一个HTTPS连接时, 要客户端合成一段HTTPS地址 如果地址含中文的话程序会crash, 检查发现原来是中文没有转码的原因 在NSString库里面找到了下面两个方法 - (NSString ...

  10. 知方可补不足~row_number,rank,dense_rank,ntile排名函数的用法

    回到目录 这篇文章介绍SQL中4个很有意思的函数,我称它的行标函数,它们是row_number,rank,dense_rank和ntile,下面分别进行介绍. 一 row_number:它为数据表加一 ...