開發與維運

基於OOS實現包年包月實例到期後提前一天轉按量

OOS簡介
Operation Orchestration Service,簡稱OOS,是全面、免費的雲上自動化運維平臺,提供運維任務的管理和執行。典型使用場景包括:事件驅動運維,批量操作運維,定時運維任務,跨地域運維等,OOS為重要運維場景提供審批,通知等功能。OOS幫您實現標準化運維任務,從而實踐運維即代碼(Operations as Code)的先進理念。關於OOS更詳細的介紹請參見什麼是運維編排服務

場景介紹
當賬戶下有一批自動續費的ECS實例,在實例到期當天如果不能及時釋放實例或轉成按量,實例會自動續費,產生一批額外的費用。使用OOS可以實現把到期實例提前一天轉成按量付費,以降低成本,節省費用。

創建模板
1.登陸OOS控制檯,找到我的模板,點擊創建模板。
image.png
2.選擇空白模版。
image.png
3.複製下文提供的模板到YAML欄中,輸入模板名稱,點擊創建模板。
image.png

模板內容:

Description: Modify prepaid instance charge type.
FormatVersion: OOS-2019-06-01
Parameters:
  regionId:
    Type: String
    Description:
      en: The id of region.
      zh-cn: 地域ID。
    AssociationProperty: RegionId
    Default: '{{ ACS::RegionId }}'
  targets:
    Type: Json
    AssociationProperty: Targets
    AssociationPropertyMetadata:
      ResourceType: 'ALIYUN::ECS::Instance'
      RegionId: regionId
  rateControl:
    Description:
      en: Concurrency ratio of task execution.
      zh-cn: 任務執行的併發比率。
    Type: Json
    AssociationProperty: RateControl
    Default:
      Mode: Concurrency
      MaxErrors: 0
      Concurrency: 10
  OOSAssumeRole:
    Description:
      en: The RAM role to be assumed by OOS.
      zh-cn: OOS扮演的RAM角色。
    Type: String
    Default: OOSServiceRole
RamRole: '{{ OOSAssumeRole }}'
Tasks:
  - Name: getInstance
    Description:
      en: Views the ECS instances.
      zh-cn: 獲取ECS實例。
    Action: 'ACS::SelectTargets'
    Properties:
      ResourceType: 'ALIYUN::ECS::Instance'
      RegionId: '{{ regionId }}'
      Filters:
        - '{{ targets }}'
    Outputs:
      instanceIds:
        Type: List
        ValueSelector: 'Instances.Instance[].InstanceId'
  - Name: describeInstances
    Action: 'ACS::ExecuteAPI'
    Description:
      zh-cn: Get Instance by expired time.
      en: 根據到期時間過濾實例。
    Properties:
      Service: ECS
      API: DescribeInstances
      Parameters:
        RegionId: '{{ regionId }}'
        InstanceIds: '{{ getInstance.instanceIds }}'
        InstanceChargeType: PrePaid
        Filter3Key: ExpiredStartTime
        Filter4Key: ExpiredEndTime
        Filter3Value:
          'Fn::FormatUTCTime':
            - 'Fn::AddHour':
                - '{{ACS::CurrentUTCTime}}'
                - 24
            - '%Y-%m-%dT00:00Z'
        Filter4Value:
          'Fn::FormatUTCTime':
            - 'Fn::AddHour':
                - '{{ACS::CurrentUTCTime}}'
                - 48
            - '%Y-%m-%dT00:00Z'
    Outputs:
      instanceIds:
        Type: List
        ValueSelector: 'Instances.Instance[].InstanceId'
  - Name: modifyInstanceChargeType
    Description:
      en: Modify instance charge type.
      zh-cn: 修改實例計費方式。
    Action: 'ACS::ECS::ModifyInstanceChargeType'
    Properties:
      regionId: '{{ regionId }}'
      instanceId: '{{ ACS::TaskLoopItem }}'
      instanceChargeType: PostPaid
    Loop:
      RateControl: '{{ rateControl }}'
      Items: '{{ describeInstances.instanceIds }}'
Outputs:
  InstanceIds:
    Type: List
    Value: '{{ describeInstances.instanceIds }}'

定時執行模版
1.找到定時運維,點擊創建,選擇週期性重複執行,設置定時執行的規則。
截圖所示規則:截止規則結束時間,每天0點0分定時執行制指定模板。
image.png
2.模板選擇,選擇上文創建的模板。
image.png
3.參數設置,設置目標地域,選擇對應的實例。點擊立即執行。
image.png
4.在執行詳情頁中可以查看定時執行列表和所操作的資源。
image.png

Leave a Reply

Your email address will not be published. Required fields are marked *