溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》
  • 首頁 > 
  • 教程 > 
  • 服務器 > 
  • 云計算 > 
  • 函數(shù)計算自動化運維實戰(zhàn) 3 -- 事件觸發(fā)自動創(chuàng)建快照

函數(shù)計算自動化運維實戰(zhàn) 3 -- 事件觸發(fā)自動創(chuàng)建快照

發(fā)布時間:2020-08-04 02:05:17 來源:網(wǎng)絡 閱讀:185 作者:阿里系統(tǒng)軟件技術 欄目:云計算

函數(shù)計算

阿里云函數(shù)計算是一個事件驅動的全托管計算服務。通過函數(shù)計算,您無需管理服務器等基礎設施,只需編寫代碼并上傳。函數(shù)計算會為您準備好計算資源,以彈性、可靠的方式運行您的代碼,并提供日志查詢,性能監(jiān)控,報警等功能。借助于函數(shù)計算,您可以快速構建任何類型的應用和服務,無需管理和運維。更棒的是,您只需要為代碼實際運行消耗的資源付費,而代碼未運行則不產(chǎn)生費用。

云監(jiān)控

阿里云云監(jiān)控為云上用戶提供開箱即用的企業(yè)級開放型一站式監(jiān)控解決方案。涵蓋 IT 設施基礎監(jiān)控,外網(wǎng)網(wǎng)絡質量撥測監(jiān)控,基于事件、自定義指標、日志的業(yè)務監(jiān)控。為您全方位提供更高效、更全面、更省錢的監(jiān)控服務。

云監(jiān)控提供了豐富事件,并且事件還在不斷豐富中(云產(chǎn)品系統(tǒng)事件監(jiān)控), 豐富的事件觸發(fā)自定義處理的函數(shù),可以實現(xiàn)更加完美的的自動化運維。

專題傳送門 => 函數(shù)計算進行自動化運維專題

示例場景

在本文中,重點關注函數(shù)計算對 ecs 的重啟事件處理,因為這些 ecs 重啟事件是目前用戶需要很高優(yōu)先級用戶優(yōu)先級去響應的;假設之前一臺 ecs 發(fā)生因系統(tǒng)錯誤而重啟,用戶可能會緊急起來做一些驗證或者創(chuàng)建快照的處理, 在本示例中,我們對一臺因為系統(tǒng)錯誤實例重啟或者因實例錯誤而重啟的機器進行自動化處理,比如成功重啟后創(chuàng)建快照處理。

ecs 系統(tǒng)事件
函數(shù)計算自動化運維實戰(zhàn) 3 -- 事件觸發(fā)自動創(chuàng)建快照cdn.com/31eeef9826151824881ec02ea99b81c2962a640c.png">

云產(chǎn)品系統(tǒng)事件監(jiān)控
函數(shù)計算自動化運維實戰(zhàn) 3 -- 事件觸發(fā)自動創(chuàng)建快照

操作步驟

  • 創(chuàng)建函數(shù)(函數(shù)代碼在文末),函數(shù)創(chuàng)建可參考函數(shù)計算helloworld

    注:記得給函數(shù)的service的role設置操作ecs的權限

函數(shù)計算自動化運維實戰(zhàn) 3 -- 事件觸發(fā)自動創(chuàng)建快照

  • 登錄云監(jiān)控控制臺, 創(chuàng)建報警規(guī)則, 監(jiān)控的事件為 ecs 因實例錯誤或西戎錯誤重啟開始和結束
    函數(shù)計算自動化運維實戰(zhàn) 3 -- 事件觸發(fā)自動創(chuàng)建快照

函數(shù)計算自動化運維實戰(zhàn) 3 -- 事件觸發(fā)自動創(chuàng)建快照
函數(shù)計算自動化運維實戰(zhàn) 3 -- 事件觸發(fā)自動創(chuàng)建快照

  • mock調試
    函數(shù)計算自動化運維實戰(zhàn) 3 -- 事件觸發(fā)自動創(chuàng)建快照
    函數(shù)計算自動化運維實戰(zhàn) 3 -- 事件觸發(fā)自動創(chuàng)建快照

  • 模擬真實的 ecs 事件

  • 請參考演練系統(tǒng)事件處理程序? So Easy~

函數(shù)計算自動化運維實戰(zhàn) 3 -- 事件觸發(fā)自動創(chuàng)建快照

代碼

# -*- 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 等技術領域、聚焦云原生流行技術趨勢、云原生大規(guī)模的落地實踐,做最懂云原生開發(fā)者的技術公眾號。”

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI