函数计算自动化运维实战 3 -- 事件触发自动创建快照
admin
2023-03-28 06:01:37
0

函数计算

阿里云函数计算是一个事件驱动的全托管计算服务。通过函数计算,您无需管理服务器等基础设施,只需编写代码并上传。函数计算会为您准备好计算资源,以弹性、可靠的方式运行您的代码,并提供日志查询,性能监控,报警等功能。借助于函数计算,您可以快速构建任何类型的应用和服务,无需管理和运维。更棒的是,您只需要为代码实际运行消耗的资源付费,而代码未运行则不产生费用。

云监控

阿里云云监控为云上用户提供开箱即用的企业级开放型一站式监控解决方案。涵盖 IT 设施基础监控,外网网络质量拨测监控,基于事件、自定义指标、日志的业务监控。为您全方位提供更高效、更全面、更省钱的监控服务。

云监控提供了丰富事件,并且事件还在不断丰富中(云产品系统事件监控), 丰富的事件触发自定义处理的函数,可以实现更加完美的的自动化运维。

专题传送门 => 函数计算进行自动化运维专题

示例场景

在本文中,重点关注函数计算对 ecs 的重启事件处理,因为这些 ecs 重启事件是目前用户需要很高优先级用户优先级去响应的;假设之前一台 ecs 发生因系统错误而重启,用户可能会紧急起来做一些验证或者创建快照的处理, 在本示例中,我们对一台因为系统错误实例重启或者因实例错误而重启的机器进行自动化处理,比如成功重启后创建快照处理。

ecs 系统事件

云产品系统事件监控
函数计算自动化运维实战 3 -- 事件触发自动创建快照

操作步骤

  • 创建函数(函数代码在文末),函数创建可参考函数计算helloworld

    注:记得给函数的service的role设置操作ecs的权限

函数计算自动化运维实战 3 -- 事件触发自动创建快照

  • 登录云监控控制台, 创建报警规则, 监控的事件为 ecs 因实例错误或西戎错误重启开始和结束
    函数计算自动化运维实战 3 -- 事件触发自动创建快照

函数计算自动化运维实战 3 -- 事件触发自动创建快照
函数计算自动化运维实战 3 -- 事件触发自动创建快照

  • mock调试
    函数计算自动化运维实战 3 -- 事件触发自动创建快照
    函数计算自动化运维实战 3 -- 事件触发自动创建快照

  • 模拟真实的 ecs 事件

  • 请参考演练系统事件处理程序? So Easy~

函数计算自动化运维实战 3 -- 事件触发自动创建快照

代码

# -*- coding: utf-8 -*-
import logging
import json, random, string, time
from aliyunsdkcore import client
from aliyunsdkecs.request.v20140526.DeleteSnapshotRequest import DeleteSnapshotRequest
from aliyunsdkecs.request.v20140526.CreateSnapshotRequest import CreateSnapshotRequest
from aliyunsdkecs.request.v20140526.DescribeDisksRequest import DescribeDisksRequest
from aliyunsdkcore.auth.credentials import StsTokenCredential
LOGGER = logging.getLogger()
clt = None
def handler(event, context):
  creds = context.credentials
  sts_token_credential = StsTokenCredential(creds.access_key_id, creds.access_key_secret, creds.security_token)
  '''
  {
    "product": "ECS",
    "content": {
        "executeFinishTime": "2018-06-08T01:25:37Z",
        "executeStartTime": "2018-06-08T01:23:37Z",
        "ecsInstanceName": "timewarp",
        "eventId": "e-t4nhcpqcu8fqushpn3mm",
        "eventType": "InstanceFailure.Reboot",
        "ecsInstanceId": "i-bp18l0uopocfc98xxxx" 
    },
    "resourceId": "acs:ecs:cn-hangzhou:123456789:instance/i-bp18l0uopocfc98xxxx",
    "level": "CRITICAL",
    "instanceName": "instanceName",
    "status": "Executing",
    "name": "Instance:SystemFailure.Reboot:Executing", 
    "regionId": "cn-hangzhou"
  }
  '''
  evt = json.loads(event)
  content = evt.get("content");
  ecsInstanceId = content.get("ecsInstanceId");
  regionId = evt.get("regionId");
  global clt
  clt = client.AcsClient(region_id=regionId, credential=sts_token_credential)
  name = evt.get("name");
  name = name.lower()
  if name in ['Instance:SystemFailure.Reboot:Executing'.lower(), "Instance:InstanceFailure.Reboot:Executing".lower()]:
    pass
    # do other things

  if name in ['Instance:SystemFailure.Reboot:Executed'.lower(), "Instance:InstanceFailure.Reboot:Executed".lower()]:
    request = DescribeDisksRequest()
    request.add_query_param("RegionId", "cn-shenzhen")
    request.set_InstanceId(ecsInstanceId)
    response = _send_request(request)
    disks = response.get('Disks').get('Disk', [])
    for disk in disks:
      diskId = disk["DiskId"]
      SnapshotId = create_ecs_snap_by_id(diskId)
      LOGGER.info("Create ecs snap sucess, ecs id = %s , disk id = %s ", ecsInstanceId, diskId)

def create_ecs_snap_by_id(disk_id):
    LOGGER.info("Create ecs snap, disk id is %s ", disk_id)
    request = CreateSnapshotRequest()
    request.set_DiskId(disk_id)
    request.set_SnapshotName("reboot_" + ''.join(random.choice(string.ascii_lowercase) for _ in range(6)))
    response = _send_request(request)
    return response.get("SnapshotId")
# send open api request
def _send_request(request):
    request.set_accept_format('json')
    try:
        response_str = clt.do_action_with_exception(request)
        LOGGER.info(response_str)
        response_detail = json.loads(response_str)
        return response_detail
    except Exception as e:
        LOGGER.error(e)

“阿里巴巴云原生微信公众号(ID:Alicloudnative)关注微服务、Serverless、容器、Service Mesh 等技术领域、聚焦云原生流行技术趋势、云原生大规模的落地实践,做最懂云原生开发者的技术公众号。”

相关内容

热门资讯

为什么美国社会这么相信有外星人... 【文/观察者网专栏作者 白玉京】2026年5月8日,美国国防部一次性释放了约160份与“不明异常现象...
巴基斯坦自杀式爆炸袭击致至少1... 【环球网报道 记者 张江平】综合巴基斯坦联合通讯社、《黎明报》等媒体10日报道,对于巴基斯坦开伯尔-...
美伊谈判陷入僵局,内塔尼亚胡:... 美伊谈判陷入僵局,美国总统特朗普5月10日表示对伊朗的回复十分不满。与此同时,以色列总理内塔尼亚胡暗...
干部明知对方是间谍,还提供22... 一个看似普通的职业社交网络平台,一份令人心动的“课题撰稿”邀请,一笔笔不断加码的“丰厚稿费”……这看...
空调挂机插头安装方法 安装空调挂机插头并不是一项难以完成的任务,我们需要先了解一下安装步骤和需要的材料和工具。下面就来详细...
客厅安装中央空调好吗 在如今的生活中,中央空调已经成为一种常见的家居设备。由于中央空调具有美观、安全、高效、舒适等特点,因...
手机进水放在大米里面真的有用吗 将进水的手机放在大米里是一种常见的应急处理方法,但它并不能保证完全解决问题。大米具有一定的吸水性,可...
光触媒与二氧化氯除甲醛那个比较... 最佳回答 08年前,除甲醛的二氧化氯,但常用的行业,因为两污染,08年后,随着催化剂的发明,纳米二...
广东星艺装饰怎么样? 最佳回答 广东星艺装饰有限公司是一家非常不错的有限公司哦。这家装饰有限公司所做的业务还是比较全面的,...
天舟十号货运飞船点火发射 今天上午,搭载天舟十号货运飞船的长征七号遥十一运载火箭,在我国文昌航天发射场点火发射。