Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练
admin
2023-04-08 15:23:15
0

下边回到我们的原始需求,来看下邮件开关机应该如何解决安全问题

 

分析这个需求,其实可以通过Microsoft Flow + Azure Automation的方式实现,首先O365邮箱接收邮件,然后通过Flow触发Azure Automation的runbook,在runbook里定义好我们需要执行的的任务,这样就可以实现我们需要的功能了

 

而身份验证实际上这里用的是我们之前讲的第二种,也就是service principal的方式,automation本身实际就是使用的service principal的方式,在Azure AD中实际上是可以看到automation注册的application的

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练



而Flow触发runbook,其实可以通过Flow来触发webhook,而automation其实是可以直接创建webhook的,这样其实就可以直接通过Flow触发Azure automation的webhook,我们的需求就可以实现了

 

关于Microsoft Flow,如果说有人了解的不是很多的话,可以这里先做一个简单的介绍

Microsoft Flow实际上是一个在线的workflow的service,可以在多个app之间执行一些自动化的任务,Flow对接的系统非常的多,比如Facebook,Twitter,Dynamic CRM,O365

 

目前来说,可以通过Flow对接超过200个服务,以下是其中的一部分



Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练



通过Flow,我们可以制定一些自动化的流程,举例来说,想实现在Yammer中有负面消息的时候就通知某个人呢,这种需求就可以通过Flow结合其他服务实现

 

首先通过Flow连接到Yammer->调用认知服务文本分析 API 检查情绪是否是负面的->如果是负面的,还可以调用Microsoft Translator将此文本翻译为别的语言->最后调用邮件发送消息通知


这就是一个标准的Flow了

 

对应到我们的需求,则比上边讲的还要简单一些

首先通过调用邮件,识别关键字,如果识别到关键字->触发webhook,在Automation中执行对应的runbook即可,想要复杂一点还可以加一些判断的逻辑,不同的关键字可以调用不同的webhook,实现不同的功能


我们这里准备实现一个简单的逻辑,在email的主题中注明是开机还是关机,然后根据关键字判断调用不同的webhook,想要调用webhook,当然首先这个webhook得存在才行,这里先在Azure automation中把webhook创建好


登陆Azure Portal后,找到automation,创建一个新的开机runbook

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练

Runbook 的类型选择普通的PowerShell即可

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练


之后再依此创建一个关机的runbook,当然创建一个单一的runbook,然后根据参数控制开关机也是可以的

 

创建好之后,点击编辑

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练


编写好对应的代码,点击publish

$connectionName = "AzureRunAsConnection"
$servicePrincipalConnection = Get-AutomationConnection -Name $connectionName

$logonAttempt = 0
$logonResult = $False

write-output "Login to Azure"
while(!($connectionResult) -And ($logonAttempt -le 10))
{
$LogonAttempt++
# Logging in to Azure...
$connectionResult = Connect-AzureRmAccount `
-ServicePrincipal `
-TenantId $servicePrincipalConnection.TenantId `
-ApplicationId $servicePrincipalConnection.ApplicationId `
-CertificateThumbprint $servicePrincipalConnection.CertificateThumbprint

Start-Sleep -Seconds 1
}

write-output "Start auto VM"
import-module Azurerm
Start-AzureRmVM -ResourceGroupName mxyjpwest -Name automationvm


Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练


之后,给这个runbook添加一个webhook

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练



注意,这里一定要保存好webhook的URL,因为这个URL创建好之后就不可见了,保存好之后创建webhook

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练



在webhook里已经可以看到了

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练


之后按照这个方法,创建好关机的webhook,到此Azure方面的准备工作就完成了

 

之后开始准备Flow,Flow其实在Global Office 365的订阅里是包含的,所以直接登录到Global O365,然后选择Flow

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练



选择从空白模板创建

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练



这里选择收到新电子邮件时

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练


选择好收件人,之后添加新步骤

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练



然后选择控制项->条件

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练


按照以下条件设置

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练


之后对如果是添加操作

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练

搜索webhook

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练



输入之前保存下来的webhook URL,注意一点要保证URL的安全,因为这个URL是包含token的,相当于直接就有执行操作的权限

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练


之后设置一个并行的条件,判断邮件主题是否包含stop,然后添加对应stop的webhook

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练


完成后整体是这样的

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练



之后发送一个邮件来进行一波测试

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练


稍等片刻后,可以看到Flow已经被触发了!

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练



在automation中可以看到,runbook也在running了!

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练



片刻后,VM已经是stopped状态

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练


在log里可以很清晰地看到有一条由automation账户触发的shutdown操作

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练



同理,再发一封start的邮件

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练


之后可以看到VM已经自动start了,测试完成!

Azure实践之如何通过邮件实现Azure VM的开关机(二)—— Flow实战演练


当然,这个应用场景是非常简单得了,但是抛砖引玉,Flow和automation真的能创造出很多的场景!希望以后能有时间多研究研究


相关内容

热门资讯

汪苏泷、薛之谦演唱会,出现“发... 演唱会装备党把这个设备拿出来,主办方感觉天都要塌了: 以后前排的票,可怎么卖? 以前年轻人去演唱会,...
拉普拉斯获得实用新型专利授权:... 证券之星消息,根据天眼查APP数据显示拉普拉斯(688726)新获得一项实用新型专利授权,专利名为“...
天舟十号满载科学与梦想 超6吨... 央视网消息:天舟十号货运飞船总长10.6米,由货物舱和推进舱组成,专门用于为空间站运送货物,发射重量...
武大切割OPPO校友:我们到底... OPPO这次的母亲节文案,确实是价值观出了问题。说“我妈有两个老公”,想玩饭圈梗来打破刻板印象,但这...
“我们完全可以相互成就、共同繁... 在华扎根50年,美国企业康明斯与中国伙伴携手成长、共享机遇——“我们完全可以相互成就、共同繁荣”(见...
乌克兰总统办公室前主任被控涉嫌... △乌克兰总统办公室前主任叶尔马克(资料图)当地时间11日,乌克兰国家反腐败局和特别反腐败检察院表示,...
你的蓝牙耳机正在 “偷听”?国... 在科技飞速发展的当下,无线耳机、智能手表、无线键盘等蓝牙设备凭借“一键连接”带来的便捷优势,已广泛应...
光洋股份:公司立足成为最懂制造... 证券日报网5月11日讯 ,光洋股份在接受调研者提问时表示,公司近年来加快布局机器人领域,立足成为最懂...
重庆拟投千亿培育沉浸式与虚拟现... 🤖 由 文心大模型 生成的文章摘要 重庆市发布“十五五”现代服务业发展规划,明确投入1 重庆市发...
内存缩水开倒车!谷歌Pixel... 5月11日消息,据相关媒体报道,受全球DRAM供应紧缺影响,谷歌即将推出的Pixel 11系列在内存...